学习ASP.NET Core的身份认证(基于JwtBearer的身份认证9)

测试数据库中只有之前记录温湿度及烟雾值的表中数据较多,在该数据库中增加AppUser表,用于登录用户身份查询,数据库表如下所示:

  项目中安装SqlSugarCore包,然后修改控制器类的登录函数及分页查询数据函数,将之前函数中的固定数据修改为从数据库中查询数据,并将分页查询数据函数中返回数据集合修改为返回环境检测数据的集合,主要调整的代码如下所示。客户端页面中的JavaScript代码主要修改了数据表格的列定义,在此不在列出来。

csharp 复制代码
 [HttpPost]
 public async Task<ApiResult> Login([FromBody]UserInfo info)
 {
     try
     {
         if (_dbClient.Queryable<AppUser>().Any(r => (r.Account == info.Name) && (r.Password == info.Password)))
         {
             AppUser curUser = _dbClient.Queryable<AppUser>().First(r => (r.Account == info.Name) && (r.Password == info.Password));
             
             ApiResult result = new ApiResult();
             result.UserName = curUser.Name;
             result.Msg = GetToken(info.Name);
             return result;
         }
         else
         {
             return new ApiResult("身份验证失败", 500, false);
         }
     }
     catch(Exception ex)
     {
         return new ApiResult(ex.Message, 500, false);
     }
 }
 
[Authorize]
[HttpGet]
public async Task<ApiResult> GetDataByPage(int page,int limit)
{
    ApiResult result = new ApiResult();
    result.StatusCode = 0;

    Records data = new Records();
    data.Count=_dbClient.Queryable<EnvironmentRecord>().Count();            
    data.Data = _dbClient.Queryable<EnvironmentRecord>().ToPageList(Convert.ToInt32(page), limit).ToList();

    result.Data = data;
    return result;
}

页面运行效果如下所示,唯一值得说的就是token的过期时间。用户登录并跳转到main.html页面后,如果重启后台服务的话,只要token没有过期,页面就可以接着调用后台服务接口,直至token过期为止,或者用户退出登录。所以确实像网上文章中提到的风险,存储到本地存储中很容易被取到并拿做它用。

参考文献:

[1]https://www.jianshu.com/p/a2804e72d296

[2]https://blog.csdn.net/sD7O95O/article/details/85043160

[3]https://www.cnblogs.com/qiongkangle/p/13347283.html

[4]https://www.cnblogs.com/xbhp/p/17401507.html

[5]https://www.cnblogs.com/superstar/p/16491428.html

[6]https://blog.csdn.net/weixin_44877917/article/details/140609294

[7]https://blog.csdn.net/qq_40287041/article/details/143368882

相关推荐
gc_229914 小时前
学习ASP.NET Core的身份认证(基于JwtBearer的身份认证7)
身份认证·jwtbear
gc_229918 小时前
学习ASP.NET Core的身份认证(基于JwtBearer的身份认证6)
身份认证·jwtbear
安 当 加 密2 天前
通过Ukey或者OTP动态口令实现windows安全登录
身份认证·权限控制·远程桌面登录·双因素认证·操作系统登录双因素认证·ukey·otp动态口令
gc_22991 个月前
学习ASP.NET Core的身份认证(基于JwtBearer的身份认证4)
身份认证·jwtbear
gc_22991 个月前
学习ASP.NET Core的身份认证(基于JwtBearer的身份认证2)
身份认证·jwtbearer
gc_22991 个月前
学习ASP.NET Core的身份认证(基于JwtBearer的身份认证3)
jwtbear·jwt token
安 当 加 密1 个月前
中小学教室多媒体电脑安全登录解决方案
数据安全·访问控制·身份认证·日志审计·多因素认证·操作系统登录双因素认证
安 当 加 密1 个月前
【安当产品应用案例100集】032-重塑企业SaaS平台的PostgreSQL凭据管理体系
数据库·数据安全·访问控制·身份认证·加密技术·凭据管理
gc_22992 个月前
学习ASP.NET Core的身份认证(基于Session的身份认证3)
asp.net core·session·身份认证