创建learning-online-checkcode
工程,目录结构如下
learning-online-media ├── src/main/java │ ├── com.swx.checkcode │ │ ├── config │ │ ├── controller │ │ ├── model │ │ ├── service │ │ └── CheckCodeApplication.java │ └──resource └── pom.xml
|
在pom文件中添加如下依赖:
pom.xml<dependencies> <dependency> <groupId>com.swx</groupId> <artifactId>learning-online-base</artifactId> <version>0.0.1-SNAPSHOT</version> </dependency> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId> </dependency>
<dependency> <groupId>com.github.penggle</groupId> <artifactId>kaptcha</artifactId> <version>2.3.2</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter</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-data-redis</artifactId> </dependency> <dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-pool2</artifactId> <version>2.6.2</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-log4j2</artifactId> </dependency> </dependencies>
|
创建启动类,在com.swx.checkcode
包下创建启动类CheckCodeApplication
,内容如下:
CheckCodeApplication@SpringBootApplication public class CheckCodeApplication { public static void main(String[] args) { SpringApplication.run(CheckCodeApplication.class, args); } }
|
项目配置信息,在resources
下创建bootstrap.yml
bootstrap.ymlspring: application: name: checkcode cloud: nacos: discovery: server-addr: 124.221.23.47:8848 namespace: learning-online-dev group: learning-online-project config: server-addr: 124.221.23.47:8848 namespace: learning-online-dev group: learning-online-project file-extension: yaml refresh-enabled: true shared-configs: - data-id: logging-${spring.profiles.active}.yaml group: learning-online-common refresh: true - data-id: redis-${spring.profiles.active}.yaml group: learning-online-common refresh: true profiles: active: dev
|
日志配置,在resources
下创建log4j2-dev.xml
log4j2-dev.xml<?xml version="1.0" encoding="UTF-8"?> <Configuration monitorInterval="180" packages=""> <properties> <property name="logdir">logs</property> <property name="PATTERN">%date{YYYY-MM-dd HH:mm:ss,SSS} %level [%thread][%file:%line] - %msg%n%throwable</property> </properties> <Appenders> <Console name="Console" target="SYSTEM_OUT"> <PatternLayout pattern="${PATTERN}"/> </Console>
<RollingFile name="ErrorAppender" fileName="${logdir}/error.log" filePattern="${logdir}/$${date:yyyy-MM-dd}/error.%d{yyyy-MM-dd-HH}.log" append="true"> <PatternLayout pattern="${PATTERN}"/> <ThresholdFilter level="ERROR" onMatch="ACCEPT" onMismatch="DENY"/> <Policies> <TimeBasedTriggeringPolicy interval="1" modulate="true" /> </Policies> </RollingFile>
<RollingFile name="DebugAppender" fileName="${logdir}/info.log" filePattern="${logdir}/$${date:yyyy-MM-dd}/info.%d{yyyy-MM-dd-HH}.log" append="true"> <PatternLayout pattern="${PATTERN}"/> <ThresholdFilter level="DEBUG" onMatch="ACCEPT" onMismatch="DENY"/> <Policies> <TimeBasedTriggeringPolicy interval="1" modulate="true" /> </Policies> </RollingFile> <Async name="AsyncAppender" includeLocation="true"> <AppenderRef ref="ErrorAppender"/> <AppenderRef ref="DebugAppender"/> </Async> </Appenders> <Loggers>
<logger name="cn.itcast.wanxinp2p.consumer.mapper" level="DEBUG"> </logger>
<logger name="springfox" level="INFO"> </logger> <logger name="org.apache.http" level="INFO"> </logger> <logger name="com.netflix.discovery" level="INFO"> </logger> <logger name="RocketmqCommon" level="INFO" > </logger> <logger name="RocketmqRemoting" level="INFO" > </logger> <logger name="RocketmqClient" level="WARN"> </logger>
<logger name="org.dromara.hmily" level="WARN"> </logger>
<logger name="org.dromara.hmily.lottery" level="WARN"> </logger>
<logger name="org.dromara.hmily.bonuspoint" level="WARN"> </logger> <Root level="DEBUG" includeLocation="true"> <AppenderRef ref="AsyncAppender"/> <AppenderRef ref="Console"/> <AppenderRef ref="DebugAppender"/> </Root> </Loggers> </Configuration>
|