get('agent_id', ''))); $secret = trim((string) ($request->get('secret', ''))); $time = trim((string) ($request->get('time', ''))); $signature = trim((string) ($request->get('signature', ''))); if ($agentId === '' || $secret === '' || $time === '' || $signature === '') { return $this->fail('缺少参数:agent_id、secret、time、signature 不能为空', ReturnCode::PARAMS_ERROR); } $expectedSecret = config('api.auth_token_secret', ''); if ($expectedSecret === '') { return $this->fail('服务端未配置 API_AUTH_TOKEN_SECRET', ReturnCode::SERVER_ERROR); } if ($secret !== $expectedSecret) { return $this->fail('密钥错误', ReturnCode::FORBIDDEN); } $timeVal = (int) $time; $tolerance = (int) config('api.auth_token_time_tolerance', 300); $now = time(); if ($timeVal < $now - $tolerance || $timeVal > $now + $tolerance) { return $this->fail('时间戳已过期或无效,请同步时间', ReturnCode::FORBIDDEN); } $expectedSignature = md5($agentId . $secret . $time); if ($signature !== $expectedSignature) { return $this->fail('签名验证失败', ReturnCode::FORBIDDEN); } $exp = (int) config('api.auth_token_exp', 86400); $tokenResult = JwtToken::generateToken([ 'id' => 0, 'agent_id' => $agentId, 'plat' => 'api_auth_token', 'access_exp' => $exp, ]); $token = $tokenResult['access_token']; if (!AuthTokenCache::setToken($agentId, $token)) { return $this->fail('生成 token 失败', ReturnCode::SERVER_ERROR); } return $this->success([ 'authtoken' => $token, ]); } }