在线办公系统目录在线办公系统1.开发环境的搭建及项目介绍2.登录模块及配置框架搭建Jwt工具类及对Token的处理1.1根据用户信息生成Token1.2根据Token生成用户名1.3判断Token是否有效1.4判断Token是否可以被刷新1.5刷新Token,获取新的Token登录功能的实现退出登录获取当前登录用户信息SpringSecurity的配置类SecurityConfig5.1覆盖SpringSecurity默认生成的账号密码,并让他走我们自定义的登录逻辑5.2进行资源的拦截,权限设置,登录过滤器设置5.2.1登录过滤器的配置5.2.2添加未登录结果处理器5.2.3添加权限不足结果处
在线办公系统目录在线办公系统1.开发环境的搭建及项目介绍2.登录模块及配置框架搭建Jwt工具类及对Token的处理1.1根据用户信息生成Token1.2根据Token生成用户名1.3判断Token是否有效1.4判断Token是否可以被刷新1.5刷新Token,获取新的Token登录功能的实现退出登录获取当前登录用户信息SpringSecurity的配置类SecurityConfig5.1覆盖SpringSecurity默认生成的账号密码,并让他走我们自定义的登录逻辑5.2进行资源的拦截,权限设置,登录过滤器设置5.2.1登录过滤器的配置5.2.2添加未登录结果处理器5.2.3添加权限不足结果处
在用MyBatis操作数据库的时候相信很多人都用到,当在判断null,大于,大于等于,小于,小于等于时,判断条件为不等于或者等于时估计蛮多人遇到坑了。明明看上去代码中传递的值和SQL中if判断的值一致。却不生效。当MyBatis判断条件为等于的时候,常量需要加.toString() 来转换,这种方法是稳定的,推荐使用andxxx='1'其中判断ifHide!='1'时,人为认为成功,但实际上是不成功的,需要改为 ifHide!='1'.toString()方可成功,原因具体没有细入研究,根据实际使用推测应该是“不等于”和"等于"在java中是个比较复杂问题,涉及的“等于”有可能是变量地址相
在用MyBatis操作数据库的时候相信很多人都用到,当在判断null,大于,大于等于,小于,小于等于时,判断条件为不等于或者等于时估计蛮多人遇到坑了。明明看上去代码中传递的值和SQL中if判断的值一致。却不生效。当MyBatis判断条件为等于的时候,常量需要加.toString() 来转换,这种方法是稳定的,推荐使用andxxx='1'其中判断ifHide!='1'时,人为认为成功,但实际上是不成功的,需要改为 ifHide!='1'.toString()方可成功,原因具体没有细入研究,根据实际使用推测应该是“不等于”和"等于"在java中是个比较复杂问题,涉及的“等于”有可能是变量地址相
Spring框架集成Mybtis为啥学习集成MybatisORM框架实现步骤为啥学习集成MybatisORM框架虽然Spring中提供了JDBCTemplate模块,已经很大程度了解决了JDBC代码的复杂度,但它仍然是和Java代码写在一起的。反观Mybatis将Sql语句写在配置文件中,使得SQL语句和程序实现了松耦合。而且提供了些许标签,使得SQL可以是动态的。在ORM基础上想要更好的用Spring的DI、AOP、事务处理、Junit支持等实现成果,学会使用Spring框架集成Mybatis是大势所趋。实现步骤第一步:准备数据库表第二步:IDEA中创建一个模块,并引入以下依赖spring-
Spring框架集成Mybtis为啥学习集成MybatisORM框架实现步骤为啥学习集成MybatisORM框架虽然Spring中提供了JDBCTemplate模块,已经很大程度了解决了JDBC代码的复杂度,但它仍然是和Java代码写在一起的。反观Mybatis将Sql语句写在配置文件中,使得SQL语句和程序实现了松耦合。而且提供了些许标签,使得SQL可以是动态的。在ORM基础上想要更好的用Spring的DI、AOP、事务处理、Junit支持等实现成果,学会使用Spring框架集成Mybatis是大势所趋。实现步骤第一步:准备数据库表第二步:IDEA中创建一个模块,并引入以下依赖spring-
packageorg.nobject.common.db;/***TODO**@authorgaozhengxing*@date2023-04-0811:55*/importjavassist.ClassPool;importorg.nobject.common.db.model.ORMPOJO;importorg.nobject.common.exception.DBException;importorg.nobject.common.lang.CollectionUtils;importorg.nobject.common.lang.MapUtils;importorg.nobject.c
packageorg.nobject.common.db;/***TODO**@authorgaozhengxing*@date2023-04-0811:55*/importjavassist.ClassPool;importorg.nobject.common.db.model.ORMPOJO;importorg.nobject.common.exception.DBException;importorg.nobject.common.lang.CollectionUtils;importorg.nobject.common.lang.MapUtils;importorg.nobject.c
分页查询1、分页查询的好处MyBatis作为持久层框架,主要任务就是操作数据库,即是对数据的增、删、查、改,其中大多数业务是查询功能,这也是这四个操作中最常用操作。所以为了减少数据库的负担,我们使用对数据进行分页查询,这样的话在面对查询大量数据时,每次只需要查询小部分数据,随之查询的次数随增加了。2、使用分页的方式第一种(常用):使用LIMIT通用语法:select*from[表名]limitstratIndex,pageSize;stratIndex:开始下标pageSize:一页的大小如:select*fromstulimit5,10;表示:查询表中的第6个数据,保存10条记录特殊语法se
分页查询1、分页查询的好处MyBatis作为持久层框架,主要任务就是操作数据库,即是对数据的增、删、查、改,其中大多数业务是查询功能,这也是这四个操作中最常用操作。所以为了减少数据库的负担,我们使用对数据进行分页查询,这样的话在面对查询大量数据时,每次只需要查询小部分数据,随之查询的次数随增加了。2、使用分页的方式第一种(常用):使用LIMIT通用语法:select*from[表名]limitstratIndex,pageSize;stratIndex:开始下标pageSize:一页的大小如:select*fromstulimit5,10;表示:查询表中的第6个数据,保存10条记录特殊语法se