- 切面编程我们单独作为一个章节进行了分析,这一节我们来看若依framework模块其他部分的内容,其中,关于安全的部分,这个章节暂时不深入,需要单独一个章节结合token认证等一起讨论。
配置 config
- 这个也不需要多展开,比较清楚,让人觉得比较爽的是,各个配置可以直接用对应的类来描述,简介大方。其中关于数据源和重复提交配置是依赖以下几个文件
拦截器、过滤器、切片的区别
- 这几个概念有些容易混,所以有必要深入一下,
过滤器,拦截器,切片可以取到数据的差别
- 过滤器:可以拿到原始的HTTP请求和响应信息,拿不到处理请求的方法值信息。
- 拦截器:可以拿到HTTP请求和响应信息,可以获取到拦截的类名称、方法名称,不能获取到方法参数,原因是在dispatcherservlet源码中,经过preHandle才对方法参数通过request里面开始处理拼接)。
- 切片:可以拿到请求方法的传入参数值,拿不到原始的HTTP请求和响应的对象。
过滤器filter和拦截器Interceptor的区别
1、过滤器和拦截器触发时机不一样,过滤器是在请求进入容器后,但请求进入servlet之前进行预处理的。请求结束返回也是,是在servlet处理完后,返回给前端之前。过滤器可以修改request,而拦截器不能.
2、拦截器可以获取IOC容器中的各个bean,而过滤器就不行,因为拦截器是spring提供并管理的,spring的功能可以被拦截器使用,在拦截器里注入一个service,可以调用业务逻辑。而过滤器是JavaEE标准,只需依赖servlet api ,不需要依赖spring。拦截器是属于spring的一个组件,因此可以使用spring的所有资源,对象,如service对象,数据源,事务控制等,而过滤器就不行。
3、过滤器的实现基于回调函数。而拦截器(代理模式)的实现基于反射,过滤器只能在请求的前后使用,而拦截器可以详细到每个方法,Filter还在servlet前后起作用。而拦截器能够深入到方法前后,异常抛出前后,因此拦截器具有更大的弹性,所有在spring框架中应该优先使用拦截器。
4、Filter是依赖于Servlet容器,属于Servlet规范的一部分,而拦截器则是独立存在的,可以在任何情况下使用。
5、Filter的执行由Servlet容器回调完成,而拦截器通常通过动态代理(反射)的方式来执行。
6、Filter的生命周期由Servlet容器管理,而拦截器则可以通过IoC容器来管理,因此可以通过注入等方式来获取其他Bean的实例,因此使用会更方便。
过滤器应用场景
1)过滤敏感词汇(防止sql注入)
2)设置字符编码
3)URL级别的权限访问控制
4)压缩响应信息
拦截器应用场景
1.登录验证,判断用户是否登录。
2.权限验证,判断用户是否有权限访问资源,如校验token
3.日志记录,记录请求操作日志(用户ip,访问时间等),以便统计请求访问量。
4.处理cookie、本地化、国际化、主题等。
5.性能监控,监控请求处理时长等。
6.通用行为:读取cookie得到用户信息并将用户对象放入请求,从而方便后续流程使用,还有如提取Locale、Theme信息等,只要是多个处理器都需要的即可使用拦截器实现)
切片应用场景
- 事务管理
- 日志操作记录
- 异常处理
- 缓存(页面缓存,方法缓存/查询缓存,数据缓存(对Entity/数据记录进行缓存))
- 权限安全认证
- Persistence 持久化
- Synchronization 同步
- Lazy loading 懒加载
- 性能监控(方法执行时间/调用次数)
正常运行顺序为:filter-interceptor-controllerAdvice-aspect-controller
异常情况下:controller-aspect-controllerAdvice-interceptor-filter
Manager
- 提供了异步任务管理器和异步工厂,这里并没有使用读写分离的技术,这个某种意义上一个目的
- Shutdown Manager,学习这种严谨的方式 确保应用退出时能关闭后台线程
Web
- web相关的信息, 比如cpu,jvm等,使用Service类来设置相关的cpu信息,内存,服务器,虚拟机等。
- GlobalExceptionHandler 挺有价值,需要关注一下,了解 @RestControllerAdvice的注解意义,以及里面常见异常的处理,可能会修订。
各类web service ,其中 注解 的化名挺有意思
@Service("ss")
public class PermissionService
{
应用场景为 @PreAuthorize("@ss.hasPermi('monitor:logininfor:remove')")
总结
框架的部分能够读懂,了解核心的内容即可,并不需要面面俱到,用到的时候能够想起来,并且知道如何用即可,毕竟技术那么多,我们精力那么有限,需要根据自己要解决的目标来学习技术,不然谁的脑袋也受不了那一坨坨的技术。