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

ops/2025/1/22 14:18:10/

  为进一步测试通过请求头传递token进行身份验证,在main.htm中增加layui的数据表格组件,并调用后台服务分页显示数据,后台分页查询数据接口如下所示(测试时,直接将数据写死到代码中,没有查询数据库),这里需注意返回的状态码需为0,其它值返回到前台都被认为是调用异常。

[Authorize]
[HttpGet]
public async Task<ApiResult> GetDataByPage(int page,int limit)
{ApiResult result = new ApiResult();result.StatusCode = 0;List<User> users = new List<User>();if(page==1){users.Add(new User { Name="张三",Age=12,Sex="男"});users.Add(new User { Name = "李四", Age = 32, Sex = "男" });users.Add(new User { Name = "王五", Age = 22, Sex = "男" });}else{users.Add(new User { Name = "李磊", Age = 12, Sex = "男" });users.Add(new User { Name = "韩梅梅", Age = 32, Sex = "女" });users.Add(new User { Name = "王巧", Age = 22, Sex = "男" });users.Add(new User { Name = "柳桥", Age = 45, Sex = "男" });}Users data = new Users();data.Data = users;data.Count = 20;result.Data = data;return result;
}

  main.html文件的JavaScript代码中使用table.render函数渲染表格数据,需要注意以下两点:
  1)render函数中通过设置headers属性添加并传递token,这点在layui的官网文档中没有写,百度相关内容才查到的,具体介绍请见参考文献1;
  2)后台数据查询接口返回数据格式与table模块的数据格式不一致,需设置数据映射,否则无法显示返回的数据集合。
  主要的JavaScript代码设置如下所示:

table.render({elem: '#data',height: 315,url: 'https://localhost:7051/Login/GetDataByPage' //数据接口,headers: {'Authorization': 'Bearer '+sessionStorage.getItem("token")},parseData: function(res){ // 数据映射处理return {"code": res.statusCode,"msg": res.msg,"count": res.data.count,"data": res.data.data };}    ,page: true ,cols: [[ {field: 'name', title: '用户名', width:80},{field: 'sex', title: '性别', width:80, sort: true},{field: 'age', title: '年龄', width:80}]]});

  身份认证成功后,分页显示数据的截图如下所示:
在这里插入图片描述
在这里插入图片描述
  未通过身份认证时,调用后台数据服务则直接显示请求异常,如下图所示:

  后续文章准备增加数据库查询,替换现在用户身份认证及数据查询都是写死到代码中的情况,同时搜索并查询基于Cookie传递token的实现方式(目前没找到多少有用的内容)。

参考文献:
[1]https://huaweicloud.csdn.net/63a56328b878a54545946043.html
[2]https://blog.csdn.net/yufengaotian/article/details/82190933


http://www.ppmy.cn/ops/152207.html

相关文章

去哪儿kafka优化案例

一、背景介绍 集群概况 去哪儿旅行当前KAFKA日志集群节点145台。单机配置&#xff1a;3TSSD盘&#xff0c;40核&#xff0c;128G内存。 业务背景 日志KAFKA集群承载了全司的APPCODE日志&#xff0c;比如我们常用的QTRACE日志&#xff0c;以及实时离线数仓数据。体量非常大。…

【25】Word:林涵-科普文章❗

目录 题目​ NO1.2.3 NO4.5.6 NO7.8 NO9.10 NO11.12 不连续选择&#xff1a;按住ctrl按键&#xff0c;不连续选择连续选择&#xff1a;按住shift按键&#xff0c;选择第一个&#xff0c;选择最后一个。中间部分全部被选择 题目 NO1.2.3 布局→纸张方向&#xff1a;横向…

使用Python爬虫获取1688网站item_get_company API接口的公司档案信息

一、引言 在当今的商业环境中&#xff0c;获取供应商的详细信息对于采购决策、市场分析和供应链管理至关重要。1688作为中国领先的B2B电子商务平台&#xff0c;提供了丰富的供应商档案信息。通过使用1688的item_get_company API接口&#xff0c;我们可以方便地获取这些信息。本…

【useTransition Hook】将某些状态更新标记为“过渡”,优化渲染性能

文章目录 引言语法参数返回值基本用法总结 引言 useTransition 是 React 中用于优化渲染性能的 Hook。它允许你将某些状态更新标记为“过渡”&#xff08;transition&#xff09;&#xff0c;从而在高优先级更新&#xff08;如用户输入&#xff09;发生时&#xff0c;低优先级…

【AI论文】GameFactory:利用生成式互动视频创造新游戏

摘要&#xff1a;生成式游戏引擎有望通过自主创建新内容并减轻手工工作量&#xff0c;从而彻底改变游戏开发领域。然而&#xff0c;现有的基于视频的游戏生成方法未能解决场景泛化的关键挑战&#xff0c;限制了它们仅适用于具有固定风格和场景的现有游戏。在本文中&#xff0c;…

人类大脑与大规模神经网络的对比及未来展望

引言 随着人工智能&#xff08;AI&#xff09;技术的迅猛发展&#xff0c;研究人员不断尝试构建更加复杂和强大的模型&#xff0c;以期实现与人类大脑相媲美的智能水平。本文将探讨当前大规模神经网络&#xff08;LLM, Large Language Models&#xff09;的发展现状&#xff0…

黑马Java面试教程_P1_导学与准备篇

系列博客目录 文章目录 系列博客目录导学Why?举例 准备篇企业是如何筛选简历的(筛选简历的规则)HR如何筛选简历部门负责人筛选简历 简历注意事项简历整体结构个人技能该如何描述项目该如何描述 应届生该如何找到合适的练手项目项目来源找到项目后&#xff0c;如何深入学习项目…

借助 .pth 文件完成多个 Python 解释器的合并

相关搜索 conda 虚拟环境如何使用 ROS 的 Python 模块conda 虚拟环境找不到 catkin_pkg 问题描述 如果你在 Ubuntu 20.04 中装了 conda&#xff0c;那么你的 Ubuntu 会有这些 Python 解释器&#xff1a; /usr/bin/python3&#xff1a;系统的解释器 (版本为 3.8.10&#xff0…