aop的使用场景
在我们service层中有多个方法,我们想要统计这些方法运行时的每次耗时,但是我们在多个方法中加入耗时统计未免有点太冗余了,所以我们可以使用aop来进行统一的使用,使用aop需要导入aop的依赖
aop概念
1.连接点
joinpoint可以被aop控制的方法叫 连接点,比如我们统计方法的执行耗时,统计的这些方法就都是连接点
2.通知 advice
指那些在aop中 重复的逻辑代码,也就是共性功能
比如 耗时统计这个方法需要 得到 方法开始前的时间和结束后时间,我们用后者减去前者得到执行耗时,但是这个统计耗时的方法需要在所有的service方法中统计,这种共性的 功能也叫通知
3.切入点
在通知当中,我们所定义的共性功能到底要应用在哪些方法上?此时就涉及到了切入点pointcut 概念。切入点指的是匹配连接点的条件。通知仅会在切入点方法运行时才会被应用。
4.切面 aspect
当通知和切入点结合在一起,就形成了一个切面。通过切面就能够描述当前aop程序需要针对于哪 个原始方法,在什么时候执行什么样的操作
5.目标对象 Target,通知所应用的对象
目标对象指的就是通知所应用的对象,我们就称之为目标对象
aop运行流程
首先 我们会为目标对象生成一个代理对象,代理对象注入 controller层的 service方法,然后运行切面类的中的方法,运行一次之后,调用目标对象的原始方法,然后继续运行切面类的方法,直到结束
aop通知类型
当我们的通知类型中的切入点表达式 相同重复的多的话 可以用@pointcut注解来进行 切入点表达式的抽取,需要的时候引入该方法就行
通知类型执行顺序
当我们的对一个目标方法加入了不同的切面类时候,通知默认按照切面类的类名字母排序执行
也可以使用@order注解进行顺序的调控
aop切入点表达式
描述切入点方法的一种表达式
主要来决定项目中哪些方法需要加入通知
然后在切面类的通知类型中加入自己注解的全路径名
连接点
nginx 反向代理以及部署
我们在下载nodejs之后和npm安装之后,可以在vue图形化界面vue ui当中创建一个vue项目,写完项目代码之后,我们用打包好文件内容之后,把打包好的文件放入到nginx中的html文件夹中即可完成部署
点击第二个build即可进行文件打包,打包好之后,
在自己下载的nginx全英文目录中找到html文件,把打包好的文件放入html文件中即可完成部署
完成部署之后,点击exe启动nginx,这时候只需要我们在自己电脑中访问 自己在conf文件中设置的端口号就可以 查看自己的前端项目了
可以看到我的文件中设置的是 80端口号,只需要在网志中输入 localhost:80 就可以访问,但是这样比较不安全,会暴露我们的后端服务,我们就可以用反向代理 来使我们的后端更安全,访问速度更快,可以进行负载均衡总结来说 就是 前端发送的动态请求 nginx会帮我转发到后端tomcat服务器等,
就是一个拼接的过程,在请求的网址 api前面 会拼接 反向代理设置的网址