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

重庆科技网站建设直播营销的优势有哪些

重庆科技网站建设,直播营销的优势有哪些,大型网站建设完全教程,企业网盘收费标准内容参考自以下两个链接1、springboot中使用AOP切面完成全局日志_aop全局日志_邹飞鸣的博客-CSDN博客使用AOP记录日志_aop日志_trusause的博客-CSDN博客第一个链接思路很清晰,讲的也很详细,第二个链接讲了自定义注解为了便于自己理解做了以下整理目录 1.aspectj基本概念 2.添加…
内容参考自以下两个链接
1、springboot中使用AOP切面完成全局日志_aop全局日志_邹飞鸣的博客-CSDN博客
使用AOP记录日志_aop日志_trusause的博客-CSDN博客
第一个链接思路很清晰,讲的也很详细,第二个链接讲了自定义注解
为了便于自己理解做了以下整理

目录

1.aspectj基本概念

2.添加aop依赖

3.进行切面处理

(1)切面类

(2)自定义注解

(3)controller和serviceimpl

4.定义切点时包扫描路径的表达式怎么写


1.aspectj基本概念

下面两个类JoinPoint和ProceedingJoinPoint,ProceedingJoinPoint类在切面类中最后一个方法doAround()中用到了(已注释的部分),用于获取自定义注解

2.添加aop依赖

<!-- aop 依赖 -->
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-aop</artifactId>
</dependency>

3.进行切面处理

主要是在切面类中设置切入点(指定包扫描路径),然后定义织入方式(方法前,方法后等)
也可以自定义注解,但是在我看来,最终还是要在切面类指定包扫描路径的,自定义注解无非是传入一些自定义参数,暂时没有探索别的用处
自定义注解的部分已被注释,直接放开注释就能使用

(1)切面类

import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.*;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;
import javax.servlet.http.HttpServletRequest;
import java.util.Arrays;@Aspect
@Component
public class WebLogAspect {// 获取日志类,方便直接在控制台输出统一格式的日志信息private final static Logger logger = LoggerFactory.getLogger(WebLogAspect.class);/*** 以 controller 包下定义的所有请求为切入点*/@Pointcut("execution(public * com.tt.test.controller.*.*(..))")public void webLog() {}/*** 在切点之前织入** @param joinPoint* @throws Throwable*/@Before("webLog()") // webLog():是你@Pointcut注解的方法名public void doBefore(JoinPoint joinPoint) throws Throwable {// 开始打印请求日志ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();HttpServletRequest request = attributes.getRequest();// 打印请求相关参数logger.info("========================================== Start ==========================================");}/*** 在切点之后织入** @throws Throwable*/@After("webLog()")public void doAfter() throws Throwable {logger.info("=========================================== End ===========================================");// 每个请求之间空一行logger.info("");}/*** 环绕** @param proceedingJoinPoint* @return* @throws Throwable*/@Around("webLog()")public Object doAround(ProceedingJoinPoint proceedingJoinPoint) throws Throwable {long startTime = System.currentTimeMillis();Object result = proceedingJoinPoint.proceed();//获取自定义注解中传入的desc/*Signature signature = proceedingJoinPoint.getSignature();MethodSignature methodSignature = (MethodSignature) signature;Method method = methodSignature.getMethod();EagleEye eagleEye = method.getAnnotation(EagleEye.class);String desc=eagleEye.desc();logger.info("Request desc   : {}", desc);*/logger.info("Request Args   : {}", Arrays.asList(result).toString());// 执行耗时logger.info("Time-Consuming : {} ms", System.currentTimeMillis() - startTime);return result;}
}

(2)自定义注解

import java.lang.annotation.*;@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
@Documented
public @interface EagleEye {//描述,默认为空String desc() default "";
}

(3)controller和serviceimpl

要想serviceimpl中的方法也被aop织入,需要把serviceimpl文件移动到controller文件夹中,因为切面类中定义了包扫描路径,或者不移动文件夹而是在切面类中定义切点的时候把serviceimpl的包路径也包含进去
controller
import com.tt.test.config.EagleEye;
import com.tt.test.service.EagleService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;/**
* 测试aop全局日志
*/
@RestController
@RequestMapping("/eagle")
public class EagleController {@Autowiredprivate EagleService eagleService;@RequestMapping("/h1")
//    @EagleEye(desc = "hello1")public String h1(){return eagleService.h1();}@RequestMapping("/h2")
//    @EagleEye(desc = "hello2")public String h2(){return eagleService.h2();}
}
serviceimpl实现类(service层接口省略)
import com.tt.test.config.EagleEye;
import com.tt.test.service.EagleService;
import org.springframework.stereotype.Service;@Service
public class EagleServiceImpl implements EagleService {@Override
//    @EagleEye(desc = "hello1-service")public String h1() {String s="s1";return s;}@Override
//    @EagleEye(desc = "hello2-service")public String h2() {String s="s2";return s;}
}

4.定义切点时包扫描路径的表达式怎么写

http://www.khdw.cn/news/18320.html

相关文章:

  • 做网络推广常用网站小说推广平台有哪些
  • 网站如何维护今日新闻简报
  • 上海正规做网站公司有哪些灵宝seo公司
  • tk域名官方网站app推广拉新一手渠道
  • 网站建设官方商城百度热搜榜第一
  • 单位做网站图片素材免费b站推广入口2023
  • 我的世界做指令的网站成都网站快速排名优化
  • 黄浦网站建设百度关键词流量查询
  • 做网站要下载的软件seo营销工具
  • 湖南网站开发公司windows优化大师会员
  • 网站所有权查询百度推广手机客户端
  • 网站建设优化公司呼和浩特电脑培训班
  • 大邑做网站网络兼职平台
  • 北京商城网站建设费用西安网站seo服务
  • 给客户做网站seo零基础教学视频
  • 密云做网站的杭州网站建设网页制作
  • 校园文化建设图片网站seo快速排名外包
  • 通化网站建设四种营销模式
  • 如何做网站站长广告网站
  • 网站建设 的公引流推广效果好的app
  • 网站建设公司起名怎么营销推广
  • 网站模板下宝鸡seo培训
  • 网站建设公司做前端网络推广seo教程
  • 怎么做浏览器网站seo软件工具
  • asp 个人网站seo人员的职责
  • 风车网站做花盆磨具各大免费推广网站
  • 网站 怎么 做压力测试惠州抖音seo策划
  • 军事内参消息seo查询友情链接
  • 网站搭建合作协议百度推广账号登录入口
  • wordpress使用插件seo关键词优化推广哪家好