SpringBoot搭建项目及单元测试、集成mybatis和log4j

SpringBoot是Spring框架对“约定大于配置(Convention over Configuration)”理念的最佳实践。SpringBoot应用本质上就是一个基于Spring框架的应用。其设计目的是用来简化新Spring应用的初始搭建以及开发过程。

maven构建项目

1、访问http://start.spring.io/按照下图中的步骤生成一个SpringBoot项目:

SpringBoot搭建项目及单元测试、集成mybatis和log4j

 

3、点击Generate Project下载项目压缩包

4、解压后,使用eclipse,Import -> Existing Maven Projects -> Next ->选择解压后的文件夹-> Finsh,OK done!

 

项目结构介绍

SpringBoot搭建项目及单元测试、集成mybatis和log4j

 

如上图所示,Spring Boot的基础结构共三个文件:

  1. src/main/java 程序开发以及主程序入口
  2. src/main/resources 配置文件
  3. src/test/java 测试程序

采用默认配置可以省去很多配置,当然也可以根据自己的喜欢来进行更改

最后,启动Application main方法,至此一个java项目搭建好了!

 

引入web模块

 

  1. pom.xml中添加支持web的模块:

 

<dependency>

        <groupId>org.springframework.boot</groupId>

        <artifactId>spring-boot-starter-web</artifactId>

 </dependency>

 

pom.xml文件中默认有两个模块:

  1. spring-boot-starter :核心模块,包括自动配置支持、日志和YAML;
  2. spring-boot-starter-test :测试模块,包括JUnit、Hamcrest、Mockito。

 

2、编写controller内容:

 

@RestController

public class HelloWorldController {

    @RequestMapping("/hello")

    public String index() {

        return "Hello World";

    }

}

@RestController 的意思就是controller里面的方法都以json格式输出,不用再写什么jackjson配置的了!

为添加启动类添加@ComponentScan("com.example") //注解扫包

 

3、启动主程序,打开浏览器访问http://localhost:8080/hello,就可以看到效果

SpringBoot中做单元测试

新建一个SpringBoot web项目时,一般都会自动引入此依赖,如果没有,请在pom.xml中手动引入

 

<dependency>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-test</artifactId>

<scope>test</scope>

</dependency>

 

src/test/java目录下的包内创建测试类

//这是JUnit的注解,通过这个注解让SpringJUnit4ClassRunner这个类提供Spring测试上下文。

@RunWith(SpringRunner.class)

@SpringBootTestclasses = DemoApplication.class

@WebAppConfiguration

 

public class DemoApplicationTests {

@Autowired

private IUserDao iud;

 

@Test

public void contextLoads() {

 

UserEntity uEntity = iud.getUserById(2);

Assert.assertEquals(uEntity.getName(), "李四");

} }

}

Junit常用注解:

  1. @Before:初始化方法
  2. @After:释放资源
  3. @Test:测试方法,在这里可以测试期望异常和超时时间
  4. @Ignore:忽略的测试方法
  5. @BeforeClass:针对所有测试,只执行一次,且必须为static void
  6. @AfterClass:针对所有测试,只执行一次,且必须为static void
  7. @RunWith:指定使用的单元测试执行类

 

执行顺序:

@BeforeClass ==> @Before ==> @Test ==> @After ==> @AfterClass 
过程:就是先加载模拟的环境,再进行测试。

 

集成Mybatis并连接数据库(MySQL)

 

添加依赖(pom.xml)

<dependency>

            <groupId>org.mybatis.spring.boot</groupId>

            <artifactId>mybatis-spring-boot-starter</artifactId>

            <version>1.2.0</version>

        </dependency>

 

<dependency>

            <groupId>mysql</groupId>

            <artifactId>mysql-connector-java</artifactId>

            <version>5.1.25</version>

      </dependency>

启动类DemoApplication .java

 

@SpringBootApplication

@EnableTransactionManagement //开启事务管理

@ComponentScan("com.example") //注解扫包

@MapperScan("com.example.mapper") //mapper扫包

public class DemoApplication {

 

public static void main(String[] args) {

SpringApplication.run(DemoApplication.class, args);

}

}

配置文件application.properties

 

#数据源的基本信息

spring.datasource.url = jdbc:mysql://localhost:3306/ssm?characterEncoding=utf-8

spring.datasource.username = root

spring.datasource.password = 123456

spring.datasource.driverClassName = com.mysql.jdbc.Driver

 

#mybatismapper文件的路径

mybatis.mapper-locations=classpath*:com/example/mapper/*.java

#起别名。可省略写mybatisxml中的resultType的全路径

mybatis.type-aliases-package=com.example.entity

 

#springMVC中的视图信息,响应前缀

spring.mvc.view.prefix=/

# 响应页面默认后缀

spring.mvc.view.suffix=.jsp

#DispatcherServlet中响应的url-pattern

server.sevlet-path=*.html

server.context-path=/

 

使用log4j日志

 

移除springboot集成的日志框架、添加log4j依赖

 

<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-log4j</artifactId>

   <version>1.3.8.RELEASE</version>

</dependency>

 

log4j.properties配置(文件置于src/main/resources目录下)

 

##########################系统日志配置################################

#### 配置日志记录器

log4j.rootLogger=ERROR, stdout, logfile

 

#### 配置日志输出源

log4j.appender.stdout=org.apache.log4j.ConsoleAppender

log4j.appender.logfile=org.apache.log4j.RollingFileAppender

log4j.appender.logfile.File=D://log//sys.log

log4j.appender.logfile.MaxFileSize=512KB

log4j.appender.logfile.MaxBackupIndex=5

 

#### 配置日志布局

log4j.appender.logfile.layout=org.apache.log4j.PatternLayout

log4j.appender.logfile.layout.ConversionPattern=%d %p [%c] %l  - %m%n

log4j.appender.stdout.layout=org.apache.log4j.PatternLayout

log4j.appender.stdout.layout.ConversionPattern=%d %p [%c] %l - %m%n

 

##########################自定义日志配置################################

#### 配置日志记录器(自定义)com.example为扫描的包(需要自己修改)

log4j.logger.com.example= DEBUG, test

 

#### 配置日志输出源(自定义)

log4j.additivity.test = false

log4j.appender.test=org.apache.log4j.FileAppender

log4j.appender.test.File=D://logs//my.log

 

#### 配置日志布局(自定义)

log4j.appender.test.layout=org.apache.log4j.PatternLayout

log4j.appender.test.layout.ConversionPattern=%d %p [%c] %l - %m%n

 

开发环境的调试

 

热启动在正常开发项目中已经很常见了吧,虽然平时开发web项目过程中,改动项目启重启总是报错;但springBoot对调试支持很好,修改之后可以实时生效,需要添加以下的配置:

 

<dependencies>

    <dependency>

        <groupId>org.springframework.boot</groupId>

        <artifactId>spring-boot-devtools</artifactId>

        <optional>true</optional>

    </dependency>

</dependencies>

 

<build>

    <plugins>

        <plugin>

            <groupId>org.springframework.boot</groupId>

            <artifactId>spring-boot-maven-plugin</artifactId>

            <configuration>

                <fork>true</fork>

            </configuration>

        </plugin>

</plugins>

</build>

 

该模块在完整的打包环境下运行的时候会被禁用。如果你使用java -jar启动应用或者用一个特定的classloader启动,它会认为这是一个“生产环境”。