手记

【九月打卡】第21天 Java主流框架实战-Spring Boot电商项目实战

课程名称:Java工程师2022版

课程章节:Spring Boot电商项目

课程内容

①Log4j2日志组件的配置和使用:log4j2 的使用 Apache Log4j2 是对Log4j 的升级版本,参考了logback 的一些优秀的设计,并且修复了一些问题,因此带来了一些重大的提升。

②拦截器在Spring Boot的配置和使用:拦截器是SpringMVC中的一种对象,能拦截器对Controller的请求,拦截器框架中有系统的拦截器,还可以自定义拦截器,实现对请求预先处理。

课程收获

Log4j2日志组件的配置和使用

       在配置log4j2日志组件之前,需要在pom.xml中将原有日志组件进行屏蔽。

<dependency>
    <
groupId>org.springframework.boot</groupId>
    <
artifactId>spring-boot-starter-web</artifactId>
    <
exclusions>
        <
exclusion>
            <
groupId>org.springframework.boot</groupId>
            <
artifactId>spring-boot-starter-logging</artifactId>
        </
exclusion>
    </
exclusions>
</
dependency>


       之后,引入依赖:

<dependency>
    <
groupId>org.springframework.boot</groupId>
    <
artifactId>spring-boot-starter-log4j2</artifactId>
</
dependency>


       在resources中创建log4j2.xml文件,添加如下内容:

<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="fatal">
  <
Properties>
    <
Property name="baseDir" value="D:\logs"/>
  </
Properties>

  <
Appenders>
    <
Console name="Console" target="SYSTEM_OUT">
     
<!--控制台只输出level及以上级别的信息(onMatch),其他的直接拒绝(onMismatch-->
     
<ThresholdFilter level="info" onMatch="ACCEPT"
       
onMismatch="DENY"/>
      <
PatternLayout
       
pattern="[%d{MM:dd HH:mm:ss.SSS}] [%level] [%logger{36}] - %msg%n"/>
    </
Console>

   
<!--debug级别日志文件输出-->
   
<RollingFile name="debug_appender" fileName="${baseDir}/debug.log"
     
filePattern="${baseDir}/debug_%i.log.%d{yyyy-MM-dd}">
     
<!-- 过滤器 -->
     
<Filters>
       
<!-- 限制日志级别在debug及以上在info以下 -->
       
<ThresholdFilter level="debug"/>
        <
ThresholdFilter level="info" onMatch="DENY" onMismatch="NEUTRAL"/>
      </
Filters>
     
<!-- 日志格式 -->
     
<PatternLayout pattern="[%d{HH:mm:ss:SSS}] [%p] - %l - %m%n"/>
     
<!-- 策略 -->
     
<Policies>
       
<!-- 每隔一天转存 -->
       
<TimeBasedTriggeringPolicy interval="1" modulate="true"/>
       
<!-- 文件大小 -->
       
<SizeBasedTriggeringPolicy size="100 MB"/>
      </
Policies>
    </
RollingFile>

   
<!-- info级别日志文件输出 -->
   
<RollingFile name="info_appender" fileName="${baseDir}/info.log"
     
filePattern="${baseDir}/info_%i.log.%d{yyyy-MM-dd}">
     
<!-- 过滤器 -->
     
<Filters>
       
<!-- 限制日志级别在info及以上在error以下 -->
       
<ThresholdFilter level="info"/>
        <
ThresholdFilter level="error" onMatch="DENY" onMismatch="NEUTRAL"/>
      </
Filters>
     
<!-- 日志格式 -->
     
<PatternLayout pattern="[%d{HH:mm:ss:SSS}] [%p] - %l - %m%n"/>
     
<!-- 策略 -->
     
<Policies>
       
<!-- 每隔一天转存 -->
       
<TimeBasedTriggeringPolicy interval="1" modulate="true"/>
       
<!-- 文件大小 -->
       
<SizeBasedTriggeringPolicy size="100 MB"/>
      </
Policies>
    </
RollingFile>

   
<!-- error级别日志文件输出 -->
   
<RollingFile name="error_appender" fileName="${baseDir}/error.log"
     
filePattern="${baseDir}/error_%i.log.%d{yyyy-MM-dd}">
     
<!-- 过滤器 -->
     
<Filters>
       
<!-- 限制日志级别在error及以上 -->
       
<ThresholdFilter level="error"/>
      </
Filters>
     
<!-- 日志格式 -->
     
<PatternLayout pattern="[%d{HH:mm:ss:SSS}] [%p] - %l - %m%n"/>
      <
Policies>
       
<!-- 每隔一天转存 -->
       
<TimeBasedTriggeringPolicy interval="1" modulate="true"/>
       
<!-- 文件大小 -->
       
<SizeBasedTriggeringPolicy size="100 MB"/>
      </
Policies>
    </
RollingFile>
  </
Appenders>
  <
Loggers>
    <
Root level="debug">
     
<!--过滤掉springmybatis的一些无用的DEBUG信息-->
      <!--<logger name="org.mybatis" level="debug" additivity="true">
          <AppenderRef ref="Console"/>
      </logger>-->
      <!--
监控系统信息-->
      <!--
若是additivity设为false,则 子Logger 只会在自己的appender里输出,而不会在 父Logger appender里输出。-->
      <!--<Logger name="org.springframework" level="debug" additivity="true">
          <AppenderRef ref="Console"/>
      </Logger>-->
     
<AppenderRef ref="Console"/>
      <
AppenderRef ref="debug_appender"/>
      <
AppenderRef ref="info_appender"/>
      <
AppenderRef ref="error_appender"/>
    </
Root>

  </
Loggers>
</
Configuration>


       配置完成后,可使用AOP环绕通知的方式进行使用

private final Logger log = LoggerFactory.getLogger(WebLogAspect.class);


 

拦截器在Spring Boot的配置和使用:

       可以在项目中使用拦截器对用户是否登录进行判断,具体方法如下:

1. 创建拦截器类实现HandlerInterceptor接口

public class UserLoginInterceptor implements HandlerInterceptor


 

2. 重写preHandle方法

@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) {
   
log.info("hahahahahhaha");
   
User user = (User) request.getSession().getAttribute(MallConst.CURRENT_USER);
   
if(user == null){
       
throw new UserException(ResponseEnum.USER_NEED_LOGIN);
    }
   
return true;
}


 

3. 对拦截器的应用范围进行配置(引用WebMvcController接口)

@Override
public void addInterceptors(InterceptorRegistry registry) {
    registry.addInterceptor(
new UserLoginInterceptor())
            .addPathPatterns(
"/**")
            .excludePathPatterns(
"/register","/login","/adminLogin");
}


 


0人推荐
随时随地看视频
慕课网APP