SpringBoot 学习笔记5

SpringBoot实践

整合SpringMVC

修改端口

查看SpringBoot的全局属性可知,端口通过以下方式配置:创建 SpringBoot 默认配置文件 —— application.yaml

server:
  port: 80

也可以使用 application.properties 默认配置文件来配置端口:

# 映射端口
server.port=80

重启服务后测试:

20200817172853

修改映射路径

修改配置文件:application.yaml

server:
  port: 80
  servlet:
    path: "*.abc"

修改映射路径以后,获取映射路径的方法,也要修改为对应的映射,如:

@GetMapping(value = "hello.abc")
@ResponseBody
public String hello() {
    return "Hello, SpringBoot!";
}

重启服务后测试:

20200817193401

修改日记级别

修改配置文件:application.yaml

server:
  port: 80
  servlet:
    path: "*.abc"
logging:
  level:
    pers.stringbug: debug
    org.springframework: debug

重启服务后测试:控制台这个时候输出的日记信息就会很详细

输出的部分日记信息

访问静态资源

现在,我们的项目是一个jar工程,那么就没有webapp,我们的静态资源该放哪里呢?

有一个叫做 ResourceProperties 的类,里面就定义了静态资源的默认查找路径:

默认的静态资源路径为:

  • classpath:/META-INF/resources/
  • classpath:/resources/
  • classpath:/static/
  • classpath:/public

只要静态资源放在这些目录中任何一个,SpringMVC都会帮我们处理。


我们习惯会把静态资源放在classpath:/static/目录下。我们创建目录,并且添加一些静态资源:

20200817200015

在 static 中放如下动态图片:

mysql从入门到放弃

重启项目后测试:

20200817200203

添加拦截器

如果我们想要保持 SpringBoot 的一些默认 MVC 特征,同时又想自定义一些 MVC 配置(包括:拦截器、格式化器、 视图控制器、消息转换器 等等)。这个时候,我们可以通过编写一个类,让这个类实现WebMvcConfigurer 接口,并且添加@Configuration注解,来实现自定义部分SpringMvc配置(不要添加@EnableWebMvc注解。)。

如果你想要自定义HandlerMappingHandlerAdapterExceptionResolver等组件,你可以创建一个WebMvcRegistrationsAdapter实例来提供以上组件。

如果你想要完全自定义SpringMVC,不保留SpringBoot提供的一切特征,你可以自己定义类并且添加@Configuration注解和@EnableWebMvc注解

注意:如果想要保留SpringBoot提供的一切特征,那么就不要添加@EnableWebMvc注解。


定义一个拦截器:

public class MyInterceptor implements HandlerInterceptor {

    private Logger logger = LoggerFactory.getLogger(MyInterceptor.class);

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, 
                             Object handler) {
        logger.debug("preHandle method is now running!");
        return true;
    }

    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response,
                           Object handler, ModelAndView modelAndView) {
        logger.debug("postHandle method is now running!");
    }

    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, 
                                Object handler, Exception ex) {
        logger.debug("afterCompletion method is now running!");
    }
}

定义配置类,注册拦截器:

@Configuration
public class MvcConfig implements WebMvcConfigurer {
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        // 添加一个拦截器,该拦截器拦截一切路径
        registry.addInterceptor(new MyInterceptor()).addPathPatterns("/**");
    }
}

applacation.yaml 配置如下:

server:
  port: 80
  servlet:
    path: /
logging:
  level:
     pers.stringbug: debug
     org.springframework: debug

重启项目后测试:

20200817205854

此外拦截器还可以这样写:

public class MyInterceptor implements HandlerInterceptor {
    private Logger logger = LoggerFactory.getLogger(MyInterceptor.class);
}

// 改成

@Slf4j
public class MyInterceptor implements HandlerInterceptor {
}

@Slf4j 可以帮我们为这个类创建 Logger 对象。


整合jdbc和事务

spring中的jdbc连接和事务是配置中的重要一环,在SpringBoot中该如何处理呢?

答案是不需要处理,我们只要找到SpringBoot提供的启动器即可:

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

当然,不要忘了数据库驱动,SpringBoot并不知道我们用的什么数据库,这里我们选择MySQL:

<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
  <version>5.1.6</version>
</dependency>

其中,需要在 application.yaml 中添加如下配置:

spring:
  datasource:
    driver-class-name: com.mysql.jdbc.Driver
    url: jdbc:mysql://127.0.0.1:3306/Test
    username: root
    password: 123456

至于事务,SpringBoot中通过注解来控制。就是我们熟知的@Transactional

@Service
public class UserService {

    @Autowired
    private UserMapper userMapper;

    public User queryById(Long id){
        return this.userMapper.selectByPrimaryKey(id);
    }

    @Transactional
    public void deleteById(Long id){
        this.userMapper.deleteByPrimaryKey(id);
    }

}

整合连接池

其实,在刚才引入jdbc启动器的时候,SpringBoot已经自动帮我们引入了一个连接池:

20200817221307

HikariCP应该是目前速度最快的连接池了,我们看看它与c3p0的对比:

20200817221352

使用 HikariCP,只需要指定连接池参数即可:application.yaml

spring:
  datasource:
    driver-class-name: com.mysql.jdbc.Driver
    url: jdbc:mysql://127.0.0.1:3306/Test
    username: root
    password: 123456
    hikari:
      idle-timeout: 60000
      maximum-pool-size: 30
      minimum-idle: 10

application.properties 文件中可以这样配置:

spring.datasource.url=jdbc:mysql://127.0.0.1:3306/Test
spring.datasource.username=root
spring.datasource.password=123456
spring.datasource.driverClassName=com.mysql.jdbc.Driver

spring.datasource.hikari.idle-timeout=60000
spring.datasource.hikari.maximum-pool-size=30
spring.datasource.hikari.minimum-idle=10

当然,如果你更喜欢Druid连接池,也可以使用Druid官方提供的启动器:

<!-- Druid连接池 -->
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid-spring-boot-starter</artifactId>
    <version>1.1.6</version>
</dependency>

而连接信息的配置与上面是类似的,只不过在连接池特有属性上,方式略有不同:

spring:
  datasource:
    driver-class-name: com.mysql.jdbc.Driver
    url: jdbc:mysql://127.0.0.1:3306/Test
    username: root
    password: 123456
    druid:
      initial-size: 1
      min-idle: 1
      max-active: 20
      test-on-borrow: true
      stat-view-servlet.allow: true

application.properties 文件中可以这样配置:

#初始化连接数
spring.datasource.druid.initial-size=1
#最小空闲连接
spring.datasource.druid.min-idle=1
#最大活动连接
spring.datasource.druid.max-active=20
#获取连接时测试是否可用
spring.datasource.druid.test-on-borrow=true
#监控页面启动
spring.datasource.druid.stat-view-servlet.allow=true

整合mybatis

mybatis

SpringBoot官方并没有提供Mybatis的启动器,不过Mybatis官网自己实现了:

<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>1.3.2</version>
</dependency>

配置,基本没有需要配置的:application.yaml

mybatis:
  configuration:
    map-underscore-to-camel-case: true
  mapper-locations: mappers/*.xml
  type-aliases-package: pers.stringbug.pojo

application.properties 文件中可以这样配置:

mybatis.configuration.map-underscore-to-camel-case=true
# mybatis 别名扫描
mybatis.type-aliases-package=com.heima.pojo
# mapper.xml文件位置,如果没有映射文件,请注释掉
mybatis.mapper-locations=classpath:mappers/*.xml

需要注意,这里没有配置mapper接口扫描包,因此我们需要给每一个Mapper接口添加@Mapper注解,才能被识别。

@Mapper
public interface UserMapper {
}

通用mapper

通用Mapper 的作者也为自己的插件编写了启动器,我们直接引入即可:

<!-- 通用mapper -->
<dependency>
    <groupId>tk.mybatis</groupId>
    <artifactId>mapper-spring-boot-starter</artifactId>
    <version>2.0.2</version>
</dependency>

注意:一但引入通用 Mapper 的启动器,会覆盖 Mybatis 官方启动器的功能。因此,需要移除对官方 Mybatis 启动器的依赖。


不需要做任何配置就可以使用了。如果还有其他需要,可以查看官网:https://github.com/abel533/Mapper/wiki

@Mapper
public interface UserMapper extends tk.mybatis.mapper.common.Mapper<User>{
}

另外,还需要在启动类上的 @MapperScan 注解修改为 通用Mapper 中自带的:

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import tk.mybatis.spring.annotation.MapperScan;

@SpringBootApplication
@MapperScan("pers.stringbug.mapper")
public class BootDemoApplication {
    public static void main(String[] args) {
        SpringApplication.run(BootDemoApplication.class, args);
    }
}

启动测试

将controller进行简单改造:

@RestController
public class HelloController {

    @Autowired
    private UserService userService;

    @GetMapping("/hello")
    public User hello() {
        User user = this.userService.queryById(8L);
        return user;
    }
}

我们启动项目,查看:

20200818003124

参考文献

  1. 黑马 Java
Good Good Write Bug, Day Day Up
原文地址:https://www.cnblogs.com/liyihua/p/14482520.html