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

宁阳网站建设价格南昌网站开发培训班

宁阳网站建设价格,南昌网站开发培训班,网站开发分页代码,中国门户网站目录 JWT 会话跟踪 token 响应拦截器 http是无状态的#xff0c;登录成功后#xff0c;客户端就与服务器断开连接#xff0c;之后再向后端发送请求时#xff0c;后端需要知道前端是哪个用户在进行操作。 JWT Json web token (JWT), 是为了在网络应用环境间传递声明而…目录 JWT 会话跟踪 token 响应拦截器 http是无状态的登录成功后客户端就与服务器断开连接之后再向后端发送请求时后端需要知道前端是哪个用户在进行操作。 JWT Json web token (JWT), 是为了在网络应用环境间传递声明而执行的一 种基于 JSON 的开放标准(RFC 7519).定义了一种简洁的自包含的方法用于通信双方之间以 JSON 对象的形式安全的传递信息。 会话跟踪 1. 用户使用账号和密码发出 post 请求 2. 服务器使用私钥创建一个 jwt public class JWTUtil {/*** 根据用户id,账号生成token* param admin* return*/public static String getToken(Admin admin) {String token ;try {//过期时间 为1970.1.1 0:0:0 至 过期时间 当前的毫秒值 有效时间Date expireDate new Date(new Date().getTime() 10*1000);//秘钥及加密算法Algorithm algorithm Algorithm.HMAC256(ZCEQIUBFKSJBFJH2020BQWE);//设置头部信息MapString,Object header new HashMap();header.put(typ,JWT);header.put(alg,HS256);//携带id账号信息生成签名token JWT.create().withHeader(header).withClaim(id,admin.getId()).withClaim(account,admin.getAccount()).withExpiresAt(expireDate).sign(algorithm);}catch (Exception e){e.printStackTrace();return null;}return token;}/*** 验证token是否有效* param token* return*/public static boolean verify(String token){try {//验签Algorithm algorithm Algorithm.HMAC256(ZCEQIUBFKSJBFJH2020BQWE);JWTVerifier verifier JWT.require(algorithm).build();DecodedJWT jwt verifier.verify(token);return true;} catch (Exception e) {//当传过来的token如果有问题,抛出异常return false;}}/*** 获得token 中playload部分数据,按需使用* param token* return*/public static DecodedJWT getTokenInfo(String token){return JWT.require(Algorithm.HMAC256(ZCEQIUBFKSJBFJH2020BQWE)).build().verify(token);}} 3. 服务器返回这个 jwt 给浏览器 4. 浏览器将该 jwt 串在请求头中像服务器发送请求 5. 服务器验证该 jwt 6. 返回响应的资源给浏览器。 由于在每次的前后端交互过程中都需要进行token的验证为了降低代码的冗余可以借助过滤器来帮助我们完成这个工作。 public class AdminTokenFilter implements Filter {Overridepublic void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {HttpServletRequest request (HttpServletRequest)servletRequest;String adminToken request.getHeader(adminToken);boolean verify JWTUtil.verify(adminToken);if(verify){filterChain.doFilter(servletRequest, servletResponse);}else {//token验证失败servletResponse.setContentType(text/html;charsetutf-8);PrintWriter printWriter servletResponse.getWriter();CommonResult commonResult new CommonResult(401, token验证失败);ObjectMapper objectMapper new ObjectMapper();String json objectMapper.writeValueAsString(commonResult);printWriter.write(json);}} } token 1.将后端封装好的信息发送给前端 2.前端接收后存储在sessionStorage对象中 3.在后面每次发送请求时都将token放入请求头中发送到后端进行验证 4.后端在对token进行解析 响应拦截器 如果token验证失败后端向前端传回一个标识用于告诉前端token验证失败 在前端main.js中添加拦截器 // 添加响应拦截器 axios.interceptors.response.use((resp) { //正常响应拦截if (resp.data.code 500) {ElementUI.Message({message: resp.data.message,type: error})}if (resp.data.code 401) {//自定义的状态码ElementUI.Message({message: token验证失败,type: error})router.replace(/login);}return resp; }); 这样每次前端进行操作时都会先验证token
http://mrfarshtey.net/news/59213/

相关文章:

  • 长沙水业网站是哪家公司做的国外浏览器app
  • 手机o2o网站建设12.12做网站的标题
  • 建网站卖南昌 网站
  • 陕西购物商城网站建设邯郸整站优化
  • 鲤城区建设局网站软件开发培训学校杭州
  • 建立自己的网站平台须多少钱如何做地方网站
  • 免费网站建设策划找工作哪个网站好58同城
  • 如何用电脑做网站服务器吗WordPress显示加载时间
  • 个人注册公司网站空间各大门户网站用什么做的
  • 仿牌网站 域名注册关键词seo排名
  • 自己做网站不用WordPress做销售找客户渠道
  • 自己弄个网站中国关键词官网
  • ppt超链接到网站怎么做网站名称图标如何做才能显示
  • 杭州网站建设那家好四位一体网站开发
  • 做网站镜像wordpress搭建数据库
  • 织梦做的网站打包在dw修改qq网页版登陆
  • 网站栏目关键词做网站还有用
  • 免费在线做高考试题的网站福田祥菱m2柴油版
  • 响应式外贸网站建设网站建设工作策划书
  • 奉化市建设局网站电脑网站微信支付怎么做的
  • 织梦网站优化教程wordpress验证码代码
  • 南京网站设计的公司wordpress远程缩略图
  • 网站发布方式有哪些多多返利网站建设
  • 网络工程专业就业前景廊坊seo推广公司
  • 网站开发工作如何古典家具网站模板
  • .net网站开发实训报告租用服务器建设网站费用
  • 全景网站如何建设网站关键词排名优化价格
  • 网站建设亿金手指花总12卡盟网站怎么做
  • 用cms做网站的具体步骤网络广告的特征是()多选题
  • 企业网站源码安装教程必应搜索引擎下载