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

项目小结二()

一.个人信息的界面  

 这里可以进行用户信息的修改,并渲染数据上去

二.这两天,出现的问题:

        1.mybatis中 字段取别名 (还没验证,是否正确)

问题描述:由于实体类中的变量名,与数据库中的字段名不相同,导致mybatis框架执行错误。

        2.在前端js代码出现问题  

问题描述:因为方式如果不是异步的,就会出现问题,这个原理还不是很了解

        这里的异步函数,如果不使用这个异步就会出现问题

        3.在样式方面

              有时候这个样式 active不同成功加上去,目前也还没发现哪里出现了问题。后面有时间再回来解决。

三. 后端过滤器(检测token是否过期)

package com.csdn.controller;import com.csdn.util.TokenUtil;import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.util.Arrays;
import java.util.List;// 过滤器,过滤掉accessToke过期的
@WebFilter("/token/*")
public class AuthFilter implements Filter {private static final List<String> WHITE_LIST_URLS = Arrays.asList(// 可以根据需要添加更多URL);@Overridepublic void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {HttpServletRequest httpRequest = (HttpServletRequest) servletRequest;HttpServletResponse httpResponse = (HttpServletResponse) servletResponse;httpResponse.setContentType("application/json;charset=utf-8");httpRequest.setCharacterEncoding("utf-8");String accessToken = httpRequest.getHeader("Authorization");String requestURI = httpRequest.getRequestURI();if (WHITE_LIST_URLS.contains(requestURI)) {// 如果在白名单中,则不进行Token验证,直接放行filterChain.doFilter(servletRequest, servletResponse);return;}if (accessToken != null && accessToken.startsWith("Bearer ")) {accessToken = accessToken.substring(7); // 提取Token值try {// 验证Tokenif (TokenUtil.verifyToken(accessToken)) {// Token验证通过,继续执行System.out.println("\n\nToken验证通过,继续执行\n|||||||||||||||||||||||||||||||\n");filterChain.doFilter(servletRequest, servletResponse);} else {// Token验证失败,返回401httpResponse.setStatus(HttpServletResponse.SC_UNAUTHORIZED);httpResponse.getWriter().write("Unauthorized");}} catch (Exception e) {// Token验证异常处理e.printStackTrace();httpResponse.setStatus(HttpServletResponse.SC_INTERNAL_SERVER_ERROR);httpResponse.getWriter().write("Internal Server Error");}} else {// 如果没有Token或者格式不正确,返回401httpResponse.setStatus(HttpServletResponse.SC_UNAUTHORIZED);httpResponse.getWriter().write("没有被允许访问!");}}
}

http://www.lryc.cn/news/435041.html

相关文章:

  • 《论层次架构及其在软件系统中的应用》写作框架,软考高级系统架构设计师
  • 校篮球联赛系统小程序的设计
  • 在 HKCR 新增项和值
  • Spring Boot 注解探秘:JSON 处理的魔法世界
  • 利用AI驱动智能BI数据可视化-深度评测Amazon Quicksight(一)
  • Linux常见指令、ls、pwd、cd、touch、mkdir、rmdir、rm等的介绍
  • 【Kubernetes】常见面试题汇总(八)
  • CentOS 7系统双网卡配置动态链路聚合(bond4)
  • ubuntu 20.04 一直卡在登录界面,即使密码正确也无法登录(失败记录)
  • 【深度学习】神经网络-怎么理解DNN、CNN、RNN?
  • 组织应在其网络安全策略中考虑MLSecOps吗?
  • Windows安装HeidiSQL教程(图文)
  • 存储课程学习笔记5_iouring的练习(io_uring,rust_echo_bench,fio)
  • 前端HTML+CSS+JS的入门学习
  • 通信电路和信道的区别与联系
  • 基于深度学习的蛋白质结构预测
  • 基于 Redis 的分布式锁实现原理及步骤
  • 21_动态规划与数据结构结合
  • React与Vue的对比
  • 精密量测软件(仿KLA免费浏览器程序ProfilmOnline)
  • Java项目: 基于SpringBoot+mybatis+maven实现的IT技术交流和分享平台(含源码+数据库+毕业论文)
  • STL02——手写简单版本的list
  • 基于SpringBoot的校园自助洗衣服务管理系统
  • 音视频入门基础:AAC专题(2)——使用FFmpeg命令生成AAC裸流文件
  • 第 6 篇 自定义 Helm Chart
  • Jenkis部署vue前端项目提示:sh: vue-cli-service: command not found
  • 中介者模式mediator
  • GO语言性能分析
  • 关于 PreparedStatement
  • 漫谈设计模式 [9]:外观模式