国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

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

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

1. 在pom中添加所需依賴(lài)

創(chuàng)建一個(gè)springboot工程,添加所需要的依賴(lài),持久化用的是mybatis

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!--springboot aop依賴(lài)--><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)建日志實(shí)體類(lèi)

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)//運(yùn)行時(shí)可見(jiàn)@Documented //生成文檔public @interface MyLog { String operation() default ''; int type();}

4. 創(chuàng)建aop切面處理類(lèi)

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;/** * 切面處理類(lèi) */@Aspect@Componentpublic class SysLogAspect { /** * 使用log4j2把一些信息打印在控制臺(tái)上面 */ private static final Logger log = LogManager.getLogger(SysLogAspect.class); @Autowired private MyLogMapper myLogMapper; //定義切點(diǎn) @Pointcut //在注解的位置切入代碼 @Pointcut('@annotation(cn.***.springaopdemo.anno.MyLog)') public void logPointCut() { } //切面 配置為前置通知 @Before('logPointCut()') public void saveOperation(JoinPoint joinPoint) { log.info('---------------接口日志記錄---------------'); //創(chuàng)建一個(gè)日志對(duì)象 AdminLog adminLog = new AdminLog(); //獲取切面織處入點(diǎn)的方法 MethodSignature signature = (MethodSignature) joinPoint.getSignature(); //獲取切入點(diǎn)所在的方法 Method method = signature.getMethod(); //獲取操作日志的屬性值 MyLog myLog = method.getAnnotation(MyLog.class); if (myLog != null) { //操作事件 String operation = myLog.operation(); adminLog.setOperation(operation); //日志類(lèi)型 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); //獲取客戶(hù)端ip String ip = request.getRemoteAddr(); adminLog.setLoginip(ip); //獲取操作人賬號(hào)、姓名(需要提前將用戶(hù)信息保存到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í)體類(lèi)到數(shù)據(jù)庫(kù) //可以在這設(shè)置id,因?yàn)槭菧y(cè)試,這里就使用的是數(shù)據(jù)庫(kù)的自增id myLogMapper.insertLog(adminLog); }}

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

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. 測(cè)試

先直接登錄用戶(hù),因?yàn)槭菧y(cè)試,直接從數(shù)據(jù)庫(kù)中獲取后登錄,把a(bǔ)dmin存儲(chǔ)到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層可以省略,直接通過(guò)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實(shí)現(xiàn)操作日志功能

進(jìn)行插入和查詢(xún)操作,插入數(shù)據(jù)直接通過(guò)后臺(tái)提供

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 = '增加書(shū)籍類(lèi)型', type = 2) @RequestMapping('/add') public void insertType() { List<Type> typeList = new ArrayList<>(); Type type = new Type(); type.setName('自然科學(xué)'); typeList.add(type); typeService.addTypeList(typeList); log.info('添加書(shū)籍類(lèi)型' + type.getName()); } @MyLog(operation = '查詢(xún)所有書(shū)籍類(lèi)型', type = 1) @RequestMapping('/findAll') public List<Type> findAllType() { List<Type> typeList = typeService.findAllType(); log.info('查詢(xún)所有書(shū)籍類(lèi)型'); return typeList; }}

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

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

再輸入查詢(xún)請(qǐng)求localhost:8080/type/findAll,獲得查詢(xún)出的分類(lèi)

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

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

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

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 一区二区三区在线 | 日本 | 国产免费自拍 | 韩国一级做a爰片性色毛片 韩国一区在线 | 香港三澳门三日本三级 | 91国语精品自产拍在线观看一 | 天堂视频免费看 | 全部免费a级毛片 | 午夜视频网站 | 在线观看日本视频免费 | 国产人妖xxxx做受视频 | 国产成人亚洲精品无广告 | 日韩在线国产精品 | 日本一区二区高清免费不卡 | 97国产精品| www.操操| 中文精品久久久久国产不卡 | 一区二区三区国产美女在线播放 | 精品真实国产乱文在线 | 欧美高清日韩 | 欧美在线bdsm调教一区 | 亚洲网址在线观看 | 国产精品久久精品 | 成人18免费软件 | 久草视频免费播放 | 特黄特黄一级高清免费大片 | 国产精品一区亚洲一区天堂 | 高清一区二区 | 一个人看的日本免费视频 | 国产片网站 | 亚洲区精品久久一区二区三区 | 日本亲子乱子伦视频 | 色色视频免费网 | 911国产自产精选 | 俺来也俺来也天天夜夜视频 | 青青热久久国产久精品秒播 | 日本美女视频韩国视频网站免费 | 国产精品99久久久久久宅男 | 夜色视频一区二区三区 | 免费在线观看一级毛片 | 91porny九色国产首页在线 | 波多野结衣中文视频 |