记录-SpringBoot-踩坑经历

31次阅读

共计 2220 个字符,预计需要花费 6 分钟才能阅读完成。

1、spring-boot-starter-web 作用

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

在使用 IDEA 每次自动创建项目的时候,都会自动加上以上依赖!但是你有没有仔细想过,为什么?

今天小司机带你开车,一探究竟。兄弟们,坐稳了,小心翻车!!

1.1、加或者不加 spring-boot-starter-web 有没有区别

答案是当然有了! SpringBoot 没有出现的时候,做过 web 的朋友都知道,搭建项目时候需要各种 xml 的配置,进行依赖关系的导入,还需要配置 web.xml 进行请求的拦截,在外部配置一个 tomcat 容器,每次启动项目的时候,使用 tomcat:run,启动完成后,才能访问项目的资源和本地测试等。但是当 SpringBoot 出现的时候,这一切都大大简化了。

因为 Spring Boot 支持容器的自动配置,它默认是 Tomcat 容器 (如下图红色所示),开发者可以可以进行修改。如果没有添加这个 web 依赖,在启动 SpringBoot 项目的时候,不会报错,但是启动不了项目!

我们可以这么理解,每次项目的启动都必须在容器中执行,所以 spring-boot-starter-web 这个依赖给我们默认已经配置了容器 (tomcat),我们不需要在外部配置 其他容器了。如果没有添加这个依赖,就会导致项目无法找到依赖的容器,无法找到容器,当然就不会启动了。

1.2、如何排除 spring-boot-starter-web 依赖中的 Tomcat,添加其他容器

 排除依赖容器 tomcat
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
    <exclusions>
        <exclusion>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-tomcat</artifactId>
        </exclusion>
    </exclusions>
</dependency>

加入 Jetty 容器
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-jetty</artifactId>
</dependency>

2、com.mysql.jdbc.Driver 和 com.mysql.cj.jdbc.Driver 的区别

com.mysql.jdbc.Driver 是 mysql-connector-java 5 中的。

com.mysql.cj.jdbc.Driver 是 mysql-connector-java 6 中的。

2.1、JDBC 连接 Mysql5 需用 com.mysql.jdbc.Driver

driverClassName=com.mysql.jdbc.Driver

url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8&useSSL=false

username=root

password=root

2.2、JDBC 连接 Mysql6 需用 com.mysql.cj.jdbc.Driver,同时需要指定时区 serverTimezone

driverClassName=com.mysql.cj.jdbc.Driver

url=jdbc:mysql://localhost:3306/test?serverTimezone=UTC&?useUnicode=true&characterEncoding=utf8&useSSL=false

username=root

password=root

2.3、设定时区时,serverTimezone=UTC 比中国时间早 8 个小时,若在中国,可设置 serverTimezone=Shanghai 或者 serverTimezone=Hongkong

driverClassName=com.mysql.cj.jdbc.Driver

url=jdbc:mysql://localhost:3306/test?serverTimezone=Shanghai&?useUnicode=true&characterEncoding=utf8&useSSL=false

username=root

password=root

2.4、总结:如果 mysql-connector-java 用的 6.0 以上的,如下:

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

但是 driver 用的还是 com.mysql.jdbc.Driver 就会报错,此时需要把 com.mysql.jdbc.Driver 改为 com.mysql.cj.jdbc.Driver。

即可运行成功!!!

正文完
 0