当前位置: 首页 > news >正文

dede免费手机网站模板.天津网站建设

dede免费手机网站模板,.天津网站建设,接外包网站,冲电气软件 网站建设在 Web 应用开发中#xff0c;用户登录状态的管理至关重要。为了避免用户频繁遇到登录过期的问题#xff0c;我们可以通过实现 JWT#xff08;JSON Web Token#xff09;刷新机制来提升用户体验 推荐: 使用 Refresh Token#xff08;双 Token 机制#xff09; 1. 生成和…在 Web 应用开发中用户登录状态的管理至关重要。为了避免用户频繁遇到登录过期的问题我们可以通过实现 JWTJSON Web Token刷新机制来提升用户体验 推荐: 使用 Refresh Token双 Token 机制 1. 生成和使用双 Token 通常会生成两种 Token访问 Token (Access Token) 和 刷新 Token (Refresh Token)。 • 访问 Token用于客户端与服务器之间的身份验证有效期较短例如 30 分钟以提高安全性。 • 刷新 Token用于获取新的访问 Token有效期较长例如 7 天存储在客户端 。 Tokenservice.cs // 生成 JWT Access Token 和 Refresh Token public (string AccessToken, string RefreshToken) GenerateTokens(string userId, string userName) {var tokenHandler  new JwtSecurityTokenHandler();var key Encoding.ASCII.GetBytes(_configuration[JwtSettings:Secret]);// 生成 Access Tokenvar accessTokenDescriptor  new SecurityTokenDescriptor{Subject  new ClaimsIdentity(new Claim[]{new Claim(ClaimTypes.NameIdentifier, userId),new Claim(ClaimTypes.Name, userName)}),Issuer _configuration[JwtSettings:Issuer],Audience _configuration[JwtSettings:Audience],Expires DateTime.UtcNow.AddMinutes(double.Parse(_configuration[JwtSettings:ExpireMinutes])),SigningCredentials  new SigningCredentials(new SymmetricSecurityKey(key), SecurityAlgorithms.HmacSha256Signature)};var accessToken tokenHandler.CreateToken(accessTokenDescriptor);// 生成 Refresh Tokenvar refreshTokenDescriptor  new SecurityTokenDescriptor{Subject  new ClaimsIdentity(new Claim[]{new Claim(ClaimTypes.NameIdentifier, userId)}),Issuer _configuration[JwtSettings:Issuer],Audience _configuration[JwtSettings:Audience],Expires DateTime.UtcNow.AddDays(7), // Refresh Token 有效期 7 天SigningCredentials  new SigningCredentials(new SymmetricSecurityKey(key), SecurityAlgorithms.HmacSha256Signature)};var refreshToken tokenHandler.CreateToken(refreshTokenDescriptor);return (tokenHandler.WriteToken(accessToken), tokenHandler.WriteToken(refreshToken)); }// 根据旧 JWT 令牌换取新 JWT 令牌public string ExchangeJwtToken(string oldToken){if (!ValidateJwtToken(oldToken)){thrownew InvalidOperationException(Invalid or expired token);}var principal ParseJwtToken(oldToken);var userId principal.FindFirst(ClaimTypes.NameIdentifier)?.Value;var userName principal.FindFirst(ClaimTypes.Name)?.Value;if (string.IsNullOrEmpty(userId) || string.IsNullOrEmpty(userName)){thrownew InvalidOperationException(Invalid token claims);}return GenerateJwtToken(userId, userName);} AuthController.cs private readonly TokenService _tokenService; privatereadonly IAppUser _appUser;public AuthController(IConfiguration configuration, IAppUser appUser, TokenService tokenService) {_tokenService tokenService;_appUser appUser; }[HttpPost(login)] [AllowAnonymous] public IActionResult Login([FromBody] LoginRequest loginRequest) {var token _tokenService.GenerateTokens(loginRequest.Username, loginRequest.Username);return Ok(new { token.RefreshToken,token.AccessToken }); } 2. 前端请求拦截器自动刷新 Token 在前端应用中可以使用请求拦截器来自动处理 Token 刷新逻辑。当访问 Token 过期时拦截器会自动调用刷新接口获取新的访问 Token并重新发起请求 //  请求拦截器 axios.interceptors.request.use( config  {const token  localStorage.getItem(accessToken);if (token) {config.headers[Authorization]  Bearer ${token};}return config;}, error  {returnPromise.reject(error);} );axios.interceptors.response.use( response  response, async error {const originalRequest error.config;if (error.response.status  401  !originalRequest._retry) {originalRequest._retry  true;const refreshToken  localStorage.getItem(refreshToken);const res  await axios.post(/api/auth/refresh-token, { refreshToken });localStorage.setItem(accessToken, res.data.accessToken);returnaxios(originalRequest);}returnPromise.reject(error);} ); 3. 后端提供刷新 Token 的接口 专门的接口来处理刷新 Token 的请求。该接口会验证刷新 Token 的有效性并返回新的访问 Token // 刷新 Access Token [HttpPost(refresh)] public IActionResult RefreshToken([FromBody] RefreshTokenRequest request) {try{var validatetoken _tokenService.ValidateJwtToken(request.RefreshToken);if (validatetoken){return Ok(_tokenService.ExchangeJwtToken(request.RefreshToken));}return Unauthorized(Invalid refresh token);}catch (Exception ex){return Unauthorized(Invalid refresh token);} } 不推荐中间件自动刷新Token 1. 创建中间件创建一个中间件用于检查每个请求的JWT Token过期时间。 2. 读取Token中间件读取请求头中的Authorization字段获取JWT Token。 3. 检查过期时间判断Token的过期时间如果距离过期时间在一定范围内如30分钟内则生成一个新的JWT Token并通过自定义的响应头如X-Refresh-Token返回给客户端。 4. 客户端更新Token客户端检查响应头如果存在X-Refresh-Token则用新Token替换旧Token并在后续请求中使用新Token。 5. 弊端虽然实现起来相对简单但安全性相对较低因为Token的刷新是在客户端自动进行的如果Token被盗用攻击者可能会在Token过期前一直使用该Token 因为存在上述弊端不推荐使用中间件自动刷新 Token故不提供相关代码实现。
http://www.hkea.cn/news/14462794/

相关文章:

  • wordpress网站在线安装企业电子商务网站平台建设
  • 哪些网站做英语比较好普通网站建设费用
  • 如何域名解析网站建设重庆市建立网站的网络公司
  • 用dw做的代码怎么放在网站上wordpress数据库文件
  • asp网站打开上海哪家seo好
  • 网站本地环境搭建软件素材网站设计
  • 我想做个网站怎么做 找谁做好网站查询ip
  • 企业网站管理系统最新4湖南岚鸿牛x1 0Typecho与wordpress
  • wordpress.org建站在阿里云做视频网站需要什么条件
  • iis网站模板建设培训网站办安全员c证
  • 网站设计制作工作室拓者设计吧邀请码免费
  • 湖南省水运建设投资集团网站住房和城乡建设部网站职责
  • 网页制作模板的淘宝网站代码实训做网站收获
  • 广西住房城乡和建设厅网站南乐网站建设
  • 用做网站使用的图片怎样做网站后台
  • 优秀个人博客网站淘客做的领券网站
  • 建设网站免费支持php高新区建网站外包
  • 松岗做网站费用网站 网址 域名
  • 上海英文网站建设网站设计外包协议
  • 学校网站查询给你一个网站你如何做优化
  • 深圳通信管理局网站wordpress开通邮件注册
  • 树莓派做网站服务器性能怎么样wordpress 菜单相册
  • 开源 html5网站模板上海营销网站建设公司
  • 网站提交做外链有什么作用免费广告推广
  • 岳阳网站建设方案黄岛开发区做网站网络公司
  • 沧州网站制作费用wordpress表单提交付费
  • 网站 logfileswordpress 安装 godaddy在哪里 上传的根目录
  • 网站分析内容cn wordpress
  • 网站建设方面的书籍书籍鹰潭网站建设
  • wix做的网站在国内访问不公司网站建设公司排名