日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

Spring如何基于aop實現(xiàn)操作日志功能

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

1. 在pom中添加所需依賴

創(chuàng)建一個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. 創(chuàng)建日志實體類

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. 創(chuàng)建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('---------------接口日志記錄---------------'); //創(chuàng)建一個日志對象 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); //調(diào)用service保存Operation實體類到數(shù)據(jù)庫 //可以在這設(shè)置id,因為是測試,這里就使用的是數(shù)據(jù)庫的自增id myLogMapper.insertLog(adminLog); }}

5. mapper層把日志數(shù)據(jù)存儲到mysql數(shù)據(jù)庫中

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. 測試

先直接登錄用戶,因為是測試,直接從數(shù)據(jù)庫中獲取后登錄,把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接口操作數(shù)據(jù)即可 @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實現(xiàn)操作日志功能

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

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實現(xiàn)操作日志功能

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

Spring如何基于aop實現(xiàn)操作日志功能

查看數(shù)據(jù)庫是否添加成功

Spring如何基于aop實現(xiàn)操作日志功能

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

標簽: Spring
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
精品一区二区三区中文字幕视频 | 欧美激情精品| 国产欧美午夜| 国产激情一区| 福利一区二区免费视频| 激情久久99| 丝袜美腿一区| 久久精品影视| 亚洲黄色影院| 综合激情五月婷婷| 国产精品一区二区免费福利视频| 国产精品一区二区av日韩在线| 免费一级欧美片在线观看网站| 精品久久免费| 激情欧美国产欧美| 蜜臀久久久久久久| 国产精品最新自拍| 国产91在线播放精品| 欧美日韩免费看片| 久久大逼视频| 国产欧美视频在线| 日韩在线不卡| 久久国产精品毛片| 亚洲精品第一| 久久亚州av| 激情综合网五月| 日韩亚洲精品在线观看| 久久麻豆视频| 亚洲一级特黄| 日韩国产一二三区| 国产一区二区精品久| 午夜久久福利| 久久国产乱子精品免费女| av资源新版天堂在线| 鲁大师影院一区二区三区| 国产精品欧美三级在线观看| 97精品一区| 免播放器亚洲| 久久激五月天综合精品| 免费看av不卡| 亚洲精品伊人| 国产白浆在线免费观看| 国产视频一区欧美| 国产精品久久乐| 亚洲精品va| 蜜桃久久久久| 久久性天堂网| 精品国产不卡一区二区| 日韩午夜黄色| 另类综合日韩欧美亚洲| 亚洲女同一区| 国产欧美日韩影院| 1024精品久久久久久久久| 日韩精品视频在线看| 国产精品毛片久久| 日本成人精品| 欧美中文一区二区| 国产欧美一区二区三区精品观看 | 国产极品模特精品一二| 欧美 日韩 国产一区二区在线视频| 日韩手机在线| 99免费精品| 国产精品99精品一区二区三区∴| 欧美精品一区二区三区精品| 久久不见久久见中文字幕免费| 黑丝一区二区三区| 国内一区二区三区| 色婷婷成人网| 亚洲精品97| 精品精品久久| 日韩一区二区三免费高清在线观看| 色网在线免费观看| 欧美精品中文字幕亚洲专区| 日韩一级网站| 精品亚洲成人| 欧美精品影院| 人人爽香蕉精品| 亚洲成a人片| 国产精品网站在线看| 国产亚洲午夜| 日韩不卡免费高清视频| 久久国内精品视频| 蜜臀av一区二区三区| 亚洲91久久| 福利一区二区免费视频| 国产精品白丝一区二区三区| 日韩中文字幕麻豆| 欧美va天堂| 成人三级高清视频在线看| 国产日韩视频| 婷婷成人av| 视频一区中文字幕国产| 蜜桃tv一区二区三区| 婷婷综合六月| 国产一区国产二区国产三区| 日本不卡视频一二三区| 水蜜桃久久夜色精品一区的特点| jizzjizz中国精品麻豆| 国产欧美日韩免费观看| 偷拍亚洲精品| 一二三区精品| 中日韩男男gay无套| 久久久人人人| 色一区二区三区四区| 美女国产精品久久久| 国产欧美另类| 日韩超碰人人爽人人做人人添| 视频一区欧美日韩| 亚洲在线成人| 亚洲在线成人| 国产精品毛片在线看| 日韩视频一区| 激情综合在线| 亚洲高清毛片| 亚洲播播91| 蜜桃精品在线| 国产66精品| 国产精品毛片一区二区在线看| 精品成人18| 国产成人免费视频网站视频社区| 嫩草伊人久久精品少妇av杨幂 | 国产精品亚洲二区| 日本久久二区| 欧美日韩91| 日韩视频一二区| 日韩专区视频网站| 欧美一区二区三区久久| 国产精品麻豆成人av电影艾秋 | 日韩中文字幕| 日韩av二区在线播放| 69堂免费精品视频在线播放| 欧美精品国产| 精品国产一区二| 日韩中文首页| 在线国产一区| 亚洲另类av| 日韩欧美中文字幕一区二区三区| 日本成人在线一区| 欧美激情视频一区二区三区在线播放| 久久wwww| 亚洲四虎影院| 亚洲一区激情| 日本精品一区二区三区在线观看视频| 日韩高清不卡一区二区| 国产精品成人自拍| 中文字幕在线官网| 日韩视频二区| 亚洲毛片在线免费| 国产精品视频一区二区三区 | 国产精品色在线网站| 国产不卡av一区二区| 久久久五月天| 综合激情在线| 久久中文在线| 激情五月综合| 日本不卡中文字幕| 精品一区视频| 欧美精选一区二区三区| 一区二区91| 麻豆精品国产91久久久久久| 欧美激情国产在线| 欧美午夜不卡| 日本天堂一区| 国产亚洲一区二区手机在线观看| 国产亚洲精品v| 国产日韩高清一区二区三区在线 | 日韩精品免费一区二区夜夜嗨 | 福利一区和二区| 在线成人直播| 国产探花在线精品一区二区| 日韩在线精品| 亚洲一二av| 91综合网人人| 免费成人性网站| 国产精品99视频| 视频在线观看91| 日韩综合一区| 亚洲精品四区| 欧美13videosex性极品| 婷婷精品在线观看| 日韩和的一区二在线| 日本aⅴ免费视频一区二区三区| 国产中文在线播放| 丝袜美腿亚洲一区二区图片| 国产一区二区三区探花| 亚洲一区免费| 国产一区二区三区探花| 爽好多水快深点欧美视频| 久久精品免费看| 亚洲一区激情| 91欧美国产| 青草国产精品| 欧美日韩视频| 国产精品久久久久蜜臀| 日韩一区二区三区精品| 久久香蕉国产| 精品72久久久久中文字幕| 亚洲精品国产精品粉嫩| 欧美三级精品| 国产伦精品一区二区三区千人斩 |