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。
即可运行成功!!!