SpringMVC之日志

一、导包

上一篇博客(整合ssm),lib里就有此包
在这里插入图片描述

二、log4j 配置文件

在这里插入图片描述

#log4j.rootLogger=debug, stdout
#
#log4j.appender.stdout=org.apache.log4j.ConsoleAppender
#log4j.appender.stdout.Target=System.err
#log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
#log4j.appender.stdout.layout.ConversionPattern=%d %l %m %n

log4j.rootLogger=debug,logfile

log4j.appender.logfile=org.apache.log4j.FileAppender
log4j.appender.logfile.File=C:\\Users\\LUO\\LOG\\mylog.txt
log4j.appender.logfile.layout=org.apache.log4j.PatternLayout
log4j.appender.logfile.layout.ConversionPattern=%p %d %F %M  %m%n

三、调用log4j中的记录日志方法

在这里插入图片描述

package com.java.exception;

import org.apache.log4j.Logger;
import org.springframework.web.bind.annotation.ControllerAdvice;
import org.springframework.web.bind.annotation.ExceptionHandler;

@ControllerAdvice
public class GlobalException {
	//一般会定义成静态,减少它加载的次数
	private static Logger logger = Logger.getLogger(GlobalException.class);
	
	@ExceptionHandler(Exception.class)
	public String myException(Exception e) {
		logger.debug(e.getMessage());
		return "error.jsp";
	}
}

四、增加扫描范围

在这里插入图片描述

在这里插入图片描述

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"

	xmlns:context="http://www.springframework.org/schema/context" xmlns:p="http://www.springframework.org/schema/p"
	xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xmlns:mvc="http://www.springframework.org/schema/mvc"
	xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.2.xsd
	http://www.springframework.org/schema/mvc 
	http://www.springframework.org/schema/mvc/spring-mvc-4.2.xsd 
	http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.2.xsd
	http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.2.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.2.xsd
	http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-4.2.xsd">
	
	<!-- 自動扫描Spring的注解 -->
	<!-- 
		特别要注意:base-package="com.java.controller"> 一定不能配置为com.java,这个这样配置了,事务将不起作用,
		因为配置为com.java,将在SpringMvc中扫描@service,这样Spring的容器中将会有service的实例,而applicationContext.xml的扫描
		就不会产生service的实例,可以事务的AOP将无法扩展功能。同时注意:controller中注入service实例只能用接口,不然就就会报错。
	-->
	<context:component-scan base-package="com.java.control,com.java.exception"></context:component-scan>
	
	<!-- 扫描springmvc中的注解 -->
	<!-- <mvc:annotation-driven></mvc:annotation-driven> -->
	
	<!-- 数据验证 -->
	<mvc:annotation-driven validator="validator"></mvc:annotation-driven>
	<bean id="validator" class="org.springframework.validation.beanvalidation.LocalValidatorFactoryBean">
       	<property name="providerClass" value="org.hibernate.validator.HibernateValidator" />
    </bean>
    
    <!-- 上传文件 -->
	<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
		<property name="defaultEncoding" value="utf-8"></property>
		
		<property name="maxUploadSize" value="1048576"></property>
	</bean>
	
	
	<!-- 
	<bean id="" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
		<property name="prefix" value="/pages/"></property>
		<property name="suffix" value=".jsp"></property>
	</bean>
	 -->
</beans>

自己写了个错误,然后运行看结果
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在SpringMVC中实现日志的AOP封装,可以使用Spring框架提供的AOP(面向切面编程)机制和Log4j或者其他日志框架。 首先需要在Spring的配置文件中开启AOP的支持,例如在xml配置文件中添加以下代码: ``` <aop:aspectj-autoproxy/> ``` 接着定义一个切面类,用于处理日志相关的操作。例如: ``` @Aspect public class LogAspect { private static final Logger LOGGER = Logger.getLogger(LogAspect.class); @Pointcut("execution(* com.example.controller.*.*(..))") public void controllerLog() {} @Around("controllerLog()") public Object logAround(ProceedingJoinPoint joinPoint) throws Throwable { String methodName = joinPoint.getSignature().getName(); String className = joinPoint.getTarget().getClass().getSimpleName(); LOGGER.info("Entering " + className + "." + methodName + "() with arguments: " + Arrays.toString(joinPoint.getArgs())); Object result = joinPoint.proceed(); LOGGER.info("Exiting " + className + "." + methodName + "() with result: " + result); return result; } } ``` 在上面的代码中,`@Aspect`注解表示这是一个切面类,`@Pointcut`注解定义了切入点,即对哪些方法进行日志记录,这里对所有Controller类中的所有方法进行切入。`@Around`注解表示在切入点前后执行的操作,这里分别记录方法的入参和返回值。 最后,在Spring的配置文件中将切面类注册到容器中,例如: ``` <bean id="logAspect" class="com.example.aspect.LogAspect"/> ``` 这样,每次调用Controller的方法时,就会自动记录日志了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值