Spring 은 어떻게 op 기반 으로 조작 로그 기능 을 실현 합 니까?
springboot 프로젝트 를 만 들 고 필요 한 의존 도 를 추가 합 니 다.지속 적 으로 my batis 를 사용 합 니 다.
<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;
@Data
public 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.사용자 정의 로그 주석
import java.lang.annotation.*;
/**
*
*/
@Target(ElementType.METHOD) //
@Retention(RetentionPolicy.RUNTIME)//
@Documented //
public @interface MyLog {
String operation() default "";
int type();
}
4.op 절단면 처리 클래스 만 들 기
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
@Component
public 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 층 은 로그 데 이 터 를 my sql 데이터베이스 에 저장 합 니 다.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 id="insertLog" 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 을 입력 하면 로그 인 한 admin 을 볼 수 있 습 니 다.삽입 과 조회 작업 을 하고 데 이 터 를 삽입 하면 배경 을 통 해 직접 제공 합 니 다.
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,배경 로그 인쇄 기록 을 입력 하 십시오.검색 요청 localhost:8080/type/findAll 을 입력 하여 검색 한 분 류 를 얻 습 니 다.
데이터베이스 추가 성공 여부 보기
이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
thymeleaf로 HTML 페이지를 동적으로 만듭니다 (spring + gradle)지난번에는 에서 화면에 HTML을 표시했습니다. 이번에는 화면을 동적으로 움직여보고 싶기 때문에 입력한 문자를 화면에 표시시키고 싶습니다. 초보자의 비망록이므로 이상한 점 등 있으면 지적 받을 수 있으면 기쁩니다! ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.