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

开发网站合作协议2023年电商市场数据报告

开发网站合作协议,2023年电商市场数据报告,企业信息化平台,江西省内新闻项目中遇到多个模块需要打印Controller请求日志#xff0c;在每个模块里面加AOP并且配置单独的切面笔者认为代码冗余#xff0c;于是乎就打算把AOP日志打印抽离成一个公共模块#xff0c;谁想用就引入Maven坐标就行。 定义公共AOP模块 并编写AOP工具 AOP模块pom.xml如下 在每个模块里面加AOP并且配置单独的切面笔者认为代码冗余于是乎就打算把AOP日志打印抽离成一个公共模块谁想用就引入Maven坐标就行。 定义公共AOP模块 并编写AOP工具 AOP模块pom.xml如下 ?xml version1.0 encodingUTF-8? project xmlns:xsihttp://www.w3.org/2001/XMLSchema-instancexmlnshttp://maven.apache.org/POM/4.0.0xsi:schemaLocationhttp://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsdparent这里根据自己需要引入 公共AOP父模块/parentmodelVersion4.0.0/modelVersionartifactIdxx-common-aop/artifactIddescriptionxx-common-aop切面/descriptiondependencies!-- Lombok --dependencygroupIdorg.projectlombok/groupIdartifactIdlombok/artifactId/dependency!-- SLF4J --dependencygroupIdorg.slf4j/groupIdartifactIdslf4j-api/artifactId/dependencydependencygroupIdorg.springframework.cloud/groupIdartifactIdspring-cloud-starter-bootstrap/artifactId/dependency!-- FastJSON --dependencygroupIdcom.alibaba.fastjson2/groupIdartifactIdfastjson2/artifactId/dependency!-- Hutool --dependencygroupIdcn.hutool/groupIdartifactIdhutool-all/artifactId/dependencydependencygroupIdorg.aspectj/groupIdartifactIdaspectjweaver/artifactId/dependencydependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-web/artifactId/dependency/dependencies/project AOP核心代码 import cn.hutool.extra.servlet.ServletUtil; import com.alibaba.fastjson2.JSON; import lombok.extern.slf4j.Slf4j; import org.aspectj.lang.JoinPoint; import org.aspectj.lang.ProceedingJoinPoint; import org.aspectj.lang.Signature; import org.aspectj.lang.annotation.*; import org.aspectj.lang.reflect.MethodSignature; 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.*;/*** 类名称: ServiceLogAop * 类描述: api入参, 出参打印*/ Aspect Component Slf4j public class ServiceLogAop {/*** 换行符*/private static final String LINE_SEPARATOR System.lineSeparator();/*** 以自定义 ServiceLogAop 注解为切点*/Pointcut(execution(public * com.*.*.controller.*.*(..)))public void webLog() {}//基本类型定义用于判断请求参数的类型private static List typeList new ArrayList();private static String[] types {java.lang.Integer, java.lang.Double,java.lang.Float, java.lang.Long, java.lang.Short,java.lang.Byte, java.lang.Boolean, java.lang.Char,java.lang.String, int, double, long, short, byte,boolean, char, float};static {for (int i 0; i types.length; i) {typeList.add(types[i]);}}/*** 在切点之前织入** param joinPoint* throws Throwable*/Before(webLog())public void doBefore(JoinPoint joinPoint) {// 开始打印请求日志ServletRequestAttributes attributes (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();HttpServletRequest request attributes.getRequest();// 获取 WebLog 注解的描述信息// 打印请求相关参数log.info( Start );// 打印请求 urllog.info(URL : {}, request.getRequestURL().toString());//uriString uri request.getRequestURI();log.info(URI : {}, uri);// 打印 Http methodlog.info(HTTP Method : {}, request.getMethod());// 打印调用 controller 的全路径以及执行方法log.info(Class Method : {}.{}, joinPoint.getSignature().getDeclaringTypeName(), joinPoint.getSignature().getName());//IPlog.info(IP : {}, request.getRemoteAddr());// 打印请求的 IPlog.info(IP : {}, ServletUtil.getClientIP(request));//TokenString authorization request.getHeader(Authorization);log.info(Authorization : {}, authorization); /* //cokieString Cookie request.getHeader(Cookie);log.info(Cookie : {}, Cookie);*///User-AgentString userAgent request.getHeader(User-Agent);log.info(User-Agent : {}, userAgent);StringBuffer requestParam new StringBuffer();//参数EnumerationString paramter request.getParameterNames();while (paramter.hasMoreElements()) {String str (String) paramter.nextElement();String strValue request.getParameter(str);requestParam.append(str strValue );}log.info(Form请求参数 : {}, requestParam.toString());// 打印请求入参// log.info(Json请求参数 : {}, JSONUtil.toJsonStr(joinPoint.getArgs()));Signature signature joinPoint.getSignature();MethodSignature methodSignature (MethodSignature) signature;// 通过这获取到方法的所有参数名称的字符串数组String[] parameterNames methodSignature.getParameterNames();//获取到所有参数的NAMEObject[] args joinPoint.getArgs(); //获取到所有参数的VALUEStringBuilder sb new StringBuilder();Map paramMap new HashMap();if (parameterNames ! null parameterNames.length 0 args ! null args.length 0) {for (int i 0; i parameterNames.length; i) {//考虑入参要么为基础类型参数要么为对象类型。以下方法都适合解析出来if (typeList.contains(args[i].getClass().getTypeName())) {//基本数据类型paramMap.put(parameterNames[i], JSON.toJSONString(args[i]));} else {//实体类paramMap JSON.parseObject(JSON.toJSONString(args[i]));}}}log.info(FormAndJsonPram: paramMap.toString());}/*** 在切点之后织入** throws Throwable*/After(webLog())public void doAfter() {// 接口结束后换行方便分割查看log.info( End LINE_SEPARATOR);}/*** 环绕** param proceedingJoinPoint* return* throws Throwable*/Around(webLog())public Object doAround(ProceedingJoinPoint proceedingJoinPoint) throws Throwable {long startTime System.currentTimeMillis();Object result proceedingJoinPoint.proceed();// 打印出参// log.info(Response Args : {}, JSONUtil.toJsonStr(result));// 执行耗时log.info(Time-Consuming : {} ms, System.currentTimeMillis() - startTime);return result;}} Pointcut(“execution(public * com.ruoyi..controller..*(…))”) 作为AOP切入口 此切入口必须为静态常量 不能为动态参数 所以说从yml读取切入点是干不成。 但 Pointcut 可以同时配置多个参数 这个就可以解决多个不同路径下面的Controller都能被切入进来。 Pointcut(execution(* xx.xx.xxx.xx.*.save*(..)) ||execution(* xx.xx.xx.*.delete*(..)) ||execution(* xx.xx.xx..*.update*(..))) 子模块 使用需要引入公共AOP模块maven 创建图片中目录文件 并引入公共模块定义好的ServiceLogAop ( 这里也可以通过 Bean方式把ServiceLogAop 注册进来 ) 效果
http://www.dnsts.com.cn/news/152731.html

相关文章:

  • 企业网站备案代理公司广州网站提升排名
  • 河池网站制作ajax实现wordpress导航栏
  • 网站打开速度影响因素网站目录做外链
  • 网站域名使用怎么做待摊分录旅游电子商务网站规划书
  • 如何把网站的文字编辑自建网站三种模式
  • 厦门网站开发费用机器人软件开发平台
  • 做网站销售的技巧国家高新技术企业认定机构
  • 现在一般做网站用什么技术广告创意设计图片赏析
  • 如何用front怕个做网站山东手工活外发加工网
  • 伊春网站建设公司在百度怎么推广
  • 网站备案哪个部门美图秀秀在线制作
  • 织梦网站2个模型wordpress更新的文章编辑器不好用
  • 网站建站公司排名网上商城推广13种方法
  • 丰台网站开发联系电话湖北省建设主管部门网站
  • 网站开发swf素材那个网站做logo兼职
  • 宁夏省建设厅网站网线制作实验心得体会
  • 开发手机网站教程wordpress可以做什么站
  • 网站建设实施计划包括网站建设在哪能看
  • app网站排名asp网站免费模板
  • 微网站开发平台免费济南教育平台网站建设
  • 做网站怎么做多少钱网站根目录文件名
  • 富库网站建设交互式网站设计怎么做
  • 做个网站多钱seo上海公司
  • 最好建设网站官方wordpress模板下载
  • 微信电影网站怎么做的品牌建设对企业的意义
  • pinterest设计网站查询网站的外链
  • 如何自己创造网站公司网站建设需求书
  • 大连哪家科技公司做网站好怎么看网站关键词排名
  • 公司网站建设方案模板厦门跨境电商前十
  • 如何自行建设网站推广一个产品有哪些方式