Spring MVC集成Log4j
2023-09-14 09:02:02 时间
以下示例显示如何使用Spring Web MVC框架集成LOG4J。首先使用Eclipse IDE,并按照以下步骤使用Spring Web Framework开发基于动态表单的Web应用程序:
- 创建一个名称为 IntegrateLog4j 的动态WEB项目。
- 在
com.yiibai.springmvc
包下创建一个Java类:HelloController
。- 从maven存储库页面下载Log4库: log4j 。 把它放在
CLASSPATH
中。- 在
src
文件夹下创建一个log4j.properties
文件。- 最后一步是创建所有源和配置文件的内容并运行应用程序,详细如下所述。
完整的项目文件目录结构如下所示 -
HelloController.java 的代码如下所示 -
package com.yiibai.springmvc; import org.apache.log4j.Logger; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.ui.ModelMap; @Controller @RequestMapping("/hello") public class HelloController{ private static final Logger LOGGER = Logger.getLogger(HelloController.class); @RequestMapping(method = RequestMethod.GET) public String printHello(ModelMap model) { LOGGER.info("printHello started."); //logs debug message if(LOGGER.isDebugEnabled()){ LOGGER.debug("Inside: printHello"); } //logs exception LOGGER.error("Logging a sample exception", new Exception("Testing")); model.addAttribute("message", "Hello Spring MVC Framework!"); LOGGER.info("printHello ended."); return "hello"; } }
log4j.properties 的代码如下所示 -
# Root logger option log4j.rootLogger=DEBUG, stdout, file # Redirect log messages to console log4j.appender.stdout=org.apache.log4j.ConsoleAppender log4j.appender.stdout.Target=System.out log4j.appender.stdout.layout=org.apache.log4j.PatternLayout log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n # Redirect log messages to a log file log4j.appender.file=org.apache.log4j.RollingFileAppender #outputs to Tomcat home log4j.appender.file.File=${catalina.home}/logs/myapp.log log4j.appender.file.MaxFileSize=5MB log4j.appender.file.MaxBackupIndex=10 log4j.appender.file.layout=org.apache.log4j.PatternLayout log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n
IntegrateLog4j-servlet.xml 配置如下所示 -
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:context="http://www.springframework.org/schema/context" 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-3.0.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd"> <context:component-scan base-package="com.yiibai.springmvc" /> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/WEB-INF/jsp/" /> <property name="suffix" value=".jsp" /> </bean> </beans>
hello.jsp 文件中的配置如下所示 -
<%@ page contentType="text/html; charset=UTF-8" %> <html> <head> <title>Hello World</title> </head> <body> <h2>${message}</h2> </body> </html>
在上面的代码中,已经在tomcat控制台中配置了
log4j
,用它来记录日志详细信息,并且在 tomcat 目录下将日志文件保存为:myapp.log
。完成创建源和配置文件后,发布应用程序到Tomcat服务器。
现在启动Tomcat服务器,当访问URL => http://localhost:8080/IntegrateLog4j/hello , 如果Spring Web应用程序没有问题,应该看到以下结果:
原文出自【易百教程】,商业转载请联系作者获得授权,非商业转载请保留原文链接:https://www.yiibai.com/spring_mvc/springmvc_log4j.html
相关文章
- Spring集成MyBatis 事务管理
- [Spring]~@SpringBootTest(单元测试)
- Spring集成MyBatis
- Mybatis与Spring集成:SqlSessionTemplate[通俗易懂]
- spring与quartz的整合[通俗易懂]
- SSM-Spring整合Mybatis[通俗易懂]
- 理论:第二章:Spring的AOP和IOC是什么?使用场景有哪些?Spring事务与数据库事务,传播行为,数据库隔离级别
- 如何找到spring的官方文档[通俗易懂]
- SpringBoot运行源码分析:Spring应用上下文准备
- Spring Boot集成websocket
- 关于Spring的两三事:万物之始—BeanDefinition
- Spring监听器-spring源码详解(五)
- spring boot支持https请求(建议收藏)
- 【Spring源码】- 10 Spring AOP核心API
- 玩转Spring Cloud Alibaba
- Spring Boot 3.0 抢先了解:aot.factories 是个啥?
- Spring 那么多子项目,谁才是真正的一哥?
- Spring Cloud Config 与其他组件集成(二)
- 集成Spring Cloud Sleuth和Zipkin
- 解析Spring Cloud Sleuth的跟踪数据
- Spring Cloud Stream应用程序开发-集成Spring Boot应用程序
- Spring Cloud Security配置JWT和OAuth2的集成实现授权管理(三)
- Spring Security 的核心组件UserDetailsService(一)
- Spring Cloud LoadBalancer 的核心组件Reactor-based LoadBalancer
- Spring Boot 集成 JUnit5,更优雅单元测试!
- Spring集成Log4J
- spring MVC-fastjson中文乱码详解编程语言
- 使用spring aspect控制自定义注解详解编程语言
- spring集成 JedisCluster 连接 redis3.0 集群详解编程语言
- Spring IoC容器:BeanFactory和ApplicationContext
- Spring整合Redis简单实现高效缓存(spring集成redis)
- Spring Boot 2 快速教程:WebFlux 集成 Thymeleaf(五)
- Spring Boot 2.x :通过 spring-boot-starter-hbase 集成 HBase