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

做宣传页的网站seo入门培训教程

做宣传页的网站,seo入门培训教程,营销策划公司 采纳策划,定制网络开发软件JWT 本身是无状态的,这意味着服务器不会保存任何关于 Token 的状态信息。但为了支持 JWT 的状态管理(例如:强制使某些 Token 失效),可以借助 Redis 这样的外部存储来维护一个黑名单或白名单。 安装必要的 NuGet 包 首…

JWT 本身是无状态的,这意味着服务器不会保存任何关于 Token 的状态信息。但为了支持 JWT 的状态管理(例如:强制使某些 Token 失效),可以借助 Redis 这样的外部存储来维护一个黑名单或白名单。

  1. 安装必要的 NuGet 包
    首先需要安装以下 NuGet 包:
StackExchange.Redis;//用于与 Redis 数据库交互。
Microsoft.AspNetCore.Authentication.JwtBearer;//用于处理 JWT 认证。
  1. 配置 Redis 连接
    在 appsettings.json 文件中添加 Redis 配置:
{"Redis": {"ConnectionString": "localhost:6379"}
}

3.创建 Redis 缓存服务
接口

 public interface IRedisCacheService{/// <summary>/// 设置redis/// </summary>/// <param name="key"></param>/// <param name="value"></param>/// <param name="expiry"></param>void Set(string key, string value, TimeSpan expiry);/// <summary>/// 删除/// </summary>/// <param name="key"></param>void Remove(string key);/// <summary>/// 获取/// </summary>/// <param name="key"></param>/// <returns></returns>string Get(string key);/// <summary>/// 判断是否存在/// </summary>/// <param name="key"></param>/// <returns></returns>bool Exists(string key);}

实现类

 public class RedisCacheService : IRedisCacheService{private readonly IDatabase _redisDb;public RedisCacheService(IConnectionMultiplexer redis){_redisDb = redis.GetDatabase();}public void Set(string key, string value, TimeSpan expiry){_redisDb.StringSet(key, value, expiry);}public void Remove(string key){_redisDb.KeyDelete(key);}public string Get(string key){return _redisDb.StringGet(key);}public bool Exists(string key){return _redisDb.KeyExists(key);}}

自定义一个扩展类

 public static IServiceCollection AddRedisCacheService(this IServiceCollection services){return services.AddSingleton<IRedisCacheService, RedisCacheService>();}
  1. 注册依赖注入服务
    在Program.cs注册服务
在这里插入代码片builder.Services.AddControllers(opt =>{opt.Filters.Add<Filter.JWTAuthorizationFilter>(); // 添加 JWT 授权过滤器});// 配置 Redis服务 builder.Services.Configure<RedisSetting>(builder.Configuration.GetSection("RedisConnection")); // 注入 Redis 配置var redisSetting = builder.Configuration.GetSection("RedisConnection").Get<RedisSetting>();builder.Services.AddSingleton<IConnectionMultiplexer>(ConnectionMultiplexer.Connect(redisSetting.ConnectionString));
builder.Services.AddRedisCacheService();// 创建个DTO保存redis配置public class RedisSetting{public string ConnectionString { get; set; }}
  1. 登录时保存Redis信息
    a.登录成功后,将用户的 JWTVersion 写入 Redis。每次登录版本号不一致,可以解决跨浏览器登录和跨地区登录。
    b.如果登录人状态被禁用了,重新设置下Redis的值即可。
 /// <summary>/// 登录/// </summary>/// <param name="login"></param>/// <returns></returns>[HttpPost][NoAuthAttribute]public async Task<IActionResult> Login([FromBody] LoginModel login){var user = await _userManager.FindByNameAsync(login.UserName);if (user == null){return new JsonResult(new { Code = 400, Message = "用户不存在" });}if (!await _userManager.CheckPasswordAsync(user, login.Password)){return new JsonResult(new { Code = 400, Message = "密码错误" });}var guid = Guid.NewGuid().ToString();var redisKey = $"{user.Id}_user.Id";var roles = await _userManager.GetRolesAsync(user);var token = _jwtService.GenerateToken(user.Id, user.UserName, guid, roles.ToList());// 设置redis和redis1小时过期_redisDb.Set(redisKey, guid, TimeSpan.FromHours(1));return new JsonResult(new { Code = 200, Message = "登录成功", Token = token });}
// 使用自定义注解,去掉登录时的过滤拦截public class NoAuthAttribute : Attribute{}
  1. 使用过滤器来过滤请求中的数据是否有效
public class JWTAuthorizationFilter : IAsyncActionFilter
{private readonly UserManager<MyUser> userManager;private readonly IRedisCacheService redisDb;public JWTAuthorizationFilter(UserManager<MyUser> userManager, IRedisCacheService redisCache){this.userManager = userManager;this.redisDb = redisCache;}public async Task OnActionExecutionAsync(ActionExecutingContext context, ActionExecutionDelegate next){// 排除掉登录不需要校验的问题var controllerAttr = context.Controller.GetType().GetCustomAttributes(typeof(NoAuthAttribute), true).Any();if (controllerAttr){await next();return;}var haveNoAuth = context.ActionDescriptor.EndpointMetadata.Any(p => p is NoAuthAttribute || p is AllowAnonymousAttribute);if (haveNoAuth){await next();return;}// 这里可以添加 JWT 验证逻辑// 如果验证失败,可以返回 401// 如果验证成功,继续执行下一个操作if (!context.HttpContext.Request.Headers.TryGetValue("Authorization", out var token)){context.Result = new ObjectResult("请求头,没有Authorization参数") { StatusCode = 401 };return;}token = token.ToString().Replace("Bearer ", "");if (string.IsNullOrEmpty(token)){context.Result = new ObjectResult("请求头,token为空") { StatusCode = 401 };return;}var jwtVersion = context.HttpContext.User.FindFirstValue("JWTVersion");var userId = context.HttpContext.User.FindFirstValue(ClaimTypes.NameIdentifier);if (string.IsNullOrEmpty(jwtVersion) || string.IsNullOrEmpty(userId)){context.Result = new ObjectResult("JWTVersion或NameIdentifier为空") { StatusCode = 401 };return;}var redisKey = $"{userId}_user.Id";var sourceGuid = redisDb.Get(redisKey);// 判断当前的版本号是否一致,不一致校验token失效if (string.IsNullOrEmpty(sourceGuid) || sourceGuid != jwtVersion){context.Result = new ObjectResult("token已失效") { StatusCode = 401 };return;}await next();}
}
http://www.dtcms.com/wzjs/407200.html

相关文章:

  • 湘潭网站建设 真好磐石网络360推广登陆
  • 哪个网站做自考题目免费百度信息流优化
  • 在线甜品网站开发书谷歌seo招聘
  • 女生适合计算机哪个专业网络推广优化招聘
  • 做旅游网站的网站优化的方法与技巧
  • 广东网站建设引流推广营销
  • 找个做网站的 优帮云百度人工服务
  • wordpress右下角设置免费seo排名优化
  • 官方网站建设银行年利息是多少钱北京搜索排名优化
  • 有哪些网站可以做海报如何快速推广app
  • 营销型网站排友情下载网站
  • 网站怎么做关键词库cnzz
  • 建站公司哪个平台最好营销策略怎么写
  • 用dw如何做网站链接免费的黄冈网站有哪些平台
  • 网络营销相关理论电商网站怎样优化
  • 网站文字特效广东广州网点快速网站建设
  • 苏州网站建设选苏州梦易行网站排名seo教程
  • 中央廉政建设网站磁力猫torrent kitty
  • 企业宣传网站系统建设方案长沙官网seo技巧
  • 山西营销型网站建设互联网搜索引擎有哪些
  • 网站建设合同 域名商务软文写作300字
  • 网站建设师怎么在百度上发布信息
  • 京东网站建设现状搜索引擎网页
  • 广州力yang网站建设微信群发软件
  • 温州做网站多少钱app001推广平台
  • 阿里云网站全部清空怎么做创新营销方式有哪些
  • 自己怎么做直播网站吗seo排名规则
  • 苏州做手机网站广州seo优化排名公司
  • 旅游网站建设推广百度合伙人答题兼职赚钱
  • h5制作工具网站网络优化的流程