成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

Spring如何基于aop實現操作日志功能

瀏覽:2日期:2023-08-03 09:32:55

1. 在pom中添加所需依賴

創建一個springboot工程,添加所需要的依賴,持久化用的是mybatis

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!--springboot aop依賴--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-aop</artifactId></dependency><!--mybatis--><dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId><version>2.1.3</version></dependency><!--mysql連接--><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.19</version><scope>runtime</scope></dependency><!--lombok--><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><optional>true</optional></dependency>

2. 創建日志實體類

import lombok.Data;import java.io.Serializable;@Datapublic class AdminLog implements Serializable { private static final long serialVersionUID = -291495801959706565L; private Integer id; //日志記錄id private Integer userId;//操作人id private String userName;//操作人name private String loginip;//登錄ip private int type; private String url; private String operation; private String createtime; private String remark;}

3. 自定義log注解

import java.lang.annotation.*;/** * 自定義日志注解 */@Target(ElementType.METHOD) //注解防止位置@Retention(RetentionPolicy.RUNTIME)//運行時可見@Documented //生成文檔public @interface MyLog { String operation() default ''; int type();}

4. 創建aop切面處理類

import cn.***.springaopdemo.anno.MyLog;import cn.***.springaopdemo.dao.MyLogMapper;import cn.***.springaopdemo.pojo.Admin;import cn.***.springaopdemo.pojo.AdminLog;import org.apache.logging.log4j.LogManager;import org.apache.logging.log4j.Logger;import org.aspectj.lang.JoinPoint;import org.aspectj.lang.annotation.Aspect;import org.aspectj.lang.annotation.Before;import org.aspectj.lang.annotation.Pointcut;import org.aspectj.lang.reflect.MethodSignature;import org.springframework.beans.factory.annotation.Autowired;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.lang.reflect.Method;/** * 切面處理類 */@Aspect@Componentpublic class SysLogAspect { /** * 使用log4j2把一些信息打印在控制臺上面 */ private static final Logger log = LogManager.getLogger(SysLogAspect.class); @Autowired private MyLogMapper myLogMapper; //定義切點 @Pointcut //在注解的位置切入代碼 @Pointcut('@annotation(cn.***.springaopdemo.anno.MyLog)') public void logPointCut() { } //切面 配置為前置通知 @Before('logPointCut()') public void saveOperation(JoinPoint joinPoint) { log.info('---------------接口日志記錄---------------'); //創建一個日志對象 AdminLog adminLog = new AdminLog(); //獲取切面織處入點的方法 MethodSignature signature = (MethodSignature) joinPoint.getSignature(); //獲取切入點所在的方法 Method method = signature.getMethod(); //獲取操作日志的屬性值 MyLog myLog = method.getAnnotation(MyLog.class); if (myLog != null) { //操作事件 String operation = myLog.operation(); adminLog.setOperation(operation); //日志類型 int type = myLog.type(); adminLog.setType(type); log.info('operation=' + operation + ',type=' + type); } //獲取url HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest(); String requestURL = request.getRequestURI().toString(); adminLog.setUrl(requestURL); //獲取客戶端ip String ip = request.getRemoteAddr(); adminLog.setLoginip(ip); //獲取操作人賬號、姓名(需要提前將用戶信息保存到Session) Admin admin = (Admin) request.getSession().getAttribute('admin'); if (admin != null) { Integer id = admin.getId(); String name = admin.getName(); adminLog.setUserId(id); adminLog.setUserName(name); } log.info('url=' + requestURL + ',ip=' + ip); //調用service保存Operation實體類到數據庫 //可以在這設置id,因為是測試,這里就使用的是數據庫的自增id myLogMapper.insertLog(adminLog); }}

5. mapper層把日志數據存儲到mysql數據庫中

mapper接口

import cn.***.springaopdemo.pojo.AdminLog;import java.util.List;public interface MyLogMapper { void insertLog(AdminLog adminLog);}

mapper.xml文件

<?xml version='1.0' encoding='UTF-8' ?><!DOCTYPE mapper PUBLIC '-//mybatis.org//DTD Mapper 3.0//EN' 'http://mybatis.org/dtd/mybatis-3-mapper.dtd'><mapper namespace='cn.***.springaopdemo.dao.MyLogMapper'> <insert parameterType='cn.***.springaopdemo.pojo.AdminLog'> INSERT INTO admin_log (user_id,user_name,loginip,type,url,operation,createtime,remark) VALUES (#{userId},#{userName},#{loginip},#{type},#{url},#{operation},now(),#{remark}) </insert></mapper>

6. 測試

先直接登錄用戶,因為是測試,直接從數據庫中獲取后登錄,把admin存儲到session中

import cn.***.springaopdemo.pojo.Admin;import cn.***.springaopdemo.service.IAdminService;import org.apache.logging.log4j.LogManager;import org.apache.logging.log4j.Logger;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RestController;import javax.servlet.http.HttpServletRequest;import java.util.List;@RestController@RequestMapping('/admin')public class AdminController { private static final Logger log = LogManager.getLogger(AdminController.class); //中間service層可以省略,直接通過mapper接口操作數據即可 @Autowired private IAdminService adminService; @RequestMapping('/login') public Admin login(HttpServletRequest request) { List<Admin> adminList = adminService.findAllAdmin(); Admin admin = adminList.get(0); request.getSession().setAttribute('admin',admin ); return admin; }}

在瀏覽器中輸入localhost:8080/admin/login,可以看到登錄的adminSpring如何基于aop實現操作日志功能

進行插入和查詢操作,插入數據直接通過后臺提供

import cn.***.springaopdemo.anno.MyLog;import cn.***.springaopdemo.pojo.Type;import cn.***.springaopdemo.service.ITypeService;import org.apache.logging.log4j.LogManager;import org.apache.logging.log4j.Logger;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RestController;import java.util.ArrayList;import java.util.List;@RestController@RequestMapping('/type')public class TypeController { private static final Logger log = LogManager.getLogger(TypeController.class); @Autowired private ITypeService typeService; @MyLog(operation = '增加書籍類型', type = 2) @RequestMapping('/add') public void insertType() { List<Type> typeList = new ArrayList<>(); Type type = new Type(); type.setName('自然科學'); typeList.add(type); typeService.addTypeList(typeList); log.info('添加書籍類型' + type.getName()); } @MyLog(operation = '查詢所有書籍類型', type = 1) @RequestMapping('/findAll') public List<Type> findAllType() { List<Type> typeList = typeService.findAllType(); log.info('查詢所有書籍類型'); return typeList; }}

在瀏覽器中輸入localhost:8080/type/add,后臺日志打印記錄

Spring如何基于aop實現操作日志功能

再輸入查詢請求localhost:8080/type/findAll,獲得查詢出的分類

Spring如何基于aop實現操作日志功能

查看數據庫是否添加成功

Spring如何基于aop實現操作日志功能

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Spring
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
欧美va亚洲va| 国产精品日韩精品欧美精品| 欧美1区3d| 欧美日韩国产一区| 亚洲欧美欧美一区二区三区| 91免费看片在线观看| 91麻豆精品国产91久久久资源速度 | 午夜精品成人在线视频| 亚洲一级黄色| 国产精品欧美一区喷水| 欧美一区三区二区在线观看| 精品国产一区二区三区av性色| 国产一区二区三区免费看| 日本精品免费观看高清观看| 伊人一区二区三区| 亚洲成色www久久网站| 国产精品伦一区二区三级视频| 粉嫩13p一区二区三区| 欧美美女直播网站| 奇米影视一区二区三区小说| 国产精品一区毛片| 亚洲午夜在线观看视频在线| 国产精品一页| 亚洲一区免费观看| 亚洲一区二区三区午夜| 一区二区三区中文免费| 亚洲理伦在线| 一区二区在线观看免费| 一区二区国产精品| 亚洲精品成人悠悠色影视| 亚洲乱码久久| 亚洲综合在线电影| 国产精品区二区三区日本| 亚洲国产视频一区二区| 鲁大师影院一区二区三区| 视频一区在线视频| 欧美网站大全在线观看| 国产在线精品一区在线观看麻豆| 欧美妇女性影城| gogo大胆日本视频一区| 亚洲国产精品激情在线观看| 亚洲电影av| 亚洲午夜精品久久久久久久久| 老鸭窝91久久精品色噜噜导演| 日韩高清国产一区在线| 91精品视频网| 欧美一区二区三区免费看| 国产精品少妇自拍| av成人毛片| 丝袜美腿亚洲色图| 欧美日韩精品久久久| 成人精品高清在线| 欧美激情一区在线| 99riav1国产精品视频| 午夜视频久久久久久| 欧美羞羞免费网站| 成人一区在线看| 国产欧美精品国产国产专区| 在线看无码的免费网站| 亚洲www啪成人一区二区麻豆| 在线亚洲高清视频| 国产成人av一区二区三区在线| 欧美成人一区二区三区片免费 | 免费在线成人av| 久久精品国产色蜜蜜麻豆| 日韩午夜激情电影| 欧美黄色大片网站| 亚洲一区二区三区视频在线播放| 欧洲精品一区二区三区在线观看| 国产成人精品综合在线观看| 国产日产欧美一区二区三区| 99日韩精品| 日韩成人午夜精品| 欧美一级片在线观看| 欧美全黄视频| 午夜一区二区三区视频| 欧美精品在线观看一区二区| 91论坛在线播放| 一区二区国产视频| 51精品秘密在线观看| 欧美精品一区二区三区在线看午夜| 亚洲已满18点击进入久久| 欧美裸体一区二区三区| 狠色狠色综合久久| 日本在线观看不卡视频| 精品国产伦一区二区三区观看方式 | 国产欧美一区二区精品久导航| 在线一区亚洲| 激情深爱一区二区| 国产日韩欧美激情| 亚洲一级在线| 久久精品国产色蜜蜜麻豆| 久久免费精品国产久精品久久久久| 国内精品久久久久久久影视麻豆| 五月天欧美精品| 精品国产成人系列| 亚洲免费在线精品一区| 黑人巨大精品欧美一区| 欧美成人一级视频| 国产伦精品一区二区| 久久精品国产99国产精品| 中文字幕不卡在线播放| 在线一区二区三区四区| 色综合天天综合狠狠| 亚洲成av人片在线观看无码| 2024国产精品| 久久久精品性| 91色.com| 日韩激情视频网站| 国产欧美va欧美不卡在线| 欧美色精品天天在线观看视频| 欧美精品aa| 裸体一区二区三区| 国产欧美精品一区| 久久久久久穴| 欧美日本一区二区视频在线观看| 亚洲成人免费观看| 日韩网站在线看片你懂的| 亚洲一区日韩| 国产成人小视频| 亚洲免费观看高清完整版在线观看 | 欧美日韩亚洲一区二区三区在线| 香港成人在线视频| 久久久久久**毛片大全| 久久精品官网| 亚洲欧美在线网| 美女一区二区视频| 国产精品美女久久久久久久| 色94色欧美sute亚洲线路二| 91碰在线视频| 五月婷婷综合在线| 久久久99精品免费观看不卡| 夜夜嗨网站十八久久 | 亚洲一区二区影院| 欧美精品一区二区三区高清aⅴ| 99pao成人国产永久免费视频| 国产91丝袜在线18| 亚洲一区二区三区四区不卡| 久久亚洲欧美国产精品乐播 | 不卡的av电影在线观看| 日韩精品五月天| 国产精品嫩草99a| 欧美一二三在线| 亚洲一区二区精品在线| 午夜电影亚洲| 国产精品亚洲人在线观看| 亚洲香肠在线观看| 久久人人爽爽爽人久久久| 色婷婷精品久久二区二区蜜臀av| 欧美精品福利| 国产另类ts人妖一区二区| 亚洲女与黑人做爰| 久久av最新网址| 欧美国产视频在线观看| 国产成人综合在线观看| 天天综合日日夜夜精品| **性色生活片久久毛片| 日韩久久久精品| 久久成人一区| 欧美激情精品久久久六区热门| 国产激情一区二区三区四区 | 亚洲精品中文在线| 2023国产精品自拍| 欧美日韩不卡在线| 性欧美长视频| 激情综合亚洲| 成人动漫视频在线| 国产剧情在线观看一区二区| 日韩中文字幕91| 亚洲一区二区三区爽爽爽爽爽| 国产精品久久久久久久久免费相片| 欧美三级资源在线| 国产精品有限公司| 亚洲天堂激情| 欧美在线日韩| kk眼镜猥琐国模调教系列一区二区| 久久精品国产色蜜蜜麻豆| 国产精品美女一区二区三区 | 欧美亚洲自偷自偷| 亚洲激情欧美| 欧美日韩国产精品一卡| 国产一区二区三区在线观看精品| 三级久久三级久久| 亚洲一区二区三区在线看| 国产精品少妇自拍| 久久这里只有精品6| 日韩一级精品视频在线观看| 欧美在线一区二区三区| 在线亚洲一区二区| 久久福利电影| 性色一区二区| 欧美亚洲免费| 校园激情久久| 免费日韩精品中文字幕视频在线| 亚洲高清成人| 亚洲国产精品一区二区第四页av| 欧美永久精品| av电影天堂一区二区在线观看| 国产成人午夜精品5599| 精品中文字幕一区二区小辣椒|