前言:正所謂,天下武功,唯快不破,在當(dāng)今生活節(jié)奏越來(lái)越快的時(shí)代,我們也要講求效率,也要追求一個(gè)快字(不過(guò)有些方面還是不能快的,不要當(dāng)快男哦)。springboot就是能簡(jiǎn)化配置、敏捷開(kāi)發(fā)的東西。做同一個(gè)項(xiàng)目,用spring你可能還在寫(xiě)xml,用springboot的話你可能已經(jīng)做完在約妹子了! 一、springboot簡(jiǎn)介:springboot,說(shuō)到底還是spring家族的,只不過(guò)用spring時(shí)我們要寫(xiě)大量的xml配置各種東西,而springboot不用寫(xiě)這些,直接寫(xiě)在application.properties或application.yml中即可,相當(dāng)于那些復(fù)雜的配置springboot底層為我們配置好了,直接聲明一下就可以。 二、springboot常用知識(shí)點(diǎn):1、springboot對(duì)靜態(tài)資源的處理: springboot項(xiàng)目中靜態(tài)資源的根目錄是: src/main/resources/static 靜態(tài)資源如html頁(yè)面、圖片、js、css等都放在此文件夾或該文件夾的子文件夾下。比如在static下有water.jpg圖片,在沒(méi)有配置視圖解析器和訪問(wèn)根路徑的情況下,? 在瀏覽器直接輸入: http://localhost:8080/water.jpg 即可訪問(wèn)該圖片。? 一般而言,會(huì)在static下建立pages文件夾用于存放頁(yè)面,js文件夾存放js代碼,css文件夾存放css。 2、全局異常捕獲: 當(dāng)你訪問(wèn)頁(yè)面出錯(cuò)時(shí),默認(rèn)是404或500以及以一大串英文,自己寫(xiě)了全局異常捕獲類就可以在出錯(cuò)時(shí)顯示自己寫(xiě)的內(nèi)容。 只需要編寫(xiě)一個(gè)類加上注解即可,如下: @ControllerAdvice
public class GlobalExceptionHandler{
@ExceptionHandler(RuntimeException.class)
@ResponseBody
public Map<String,Object> resultError(){
Map<String,Object> modelMap = new HashMap<String,Object>();
modelMap.put("errCode",500);
modelMap.put("errMsg","錯(cuò)誤!");
return modelMap;
}
}
這實(shí)際上是用了spring的異常通知。 3、配置多環(huán)境: 在實(shí)際開(kāi)發(fā)過(guò)程中,一般可能有以下4個(gè)環(huán)境: test ------------------ 本地開(kāi)發(fā)環(huán)境
sit ------------------ 測(cè)試環(huán)境
pre ------------------ 預(yù)生產(chǎn)環(huán)境
pid ------------------ 生產(chǎn)環(huán)境
那么如何為不同的生產(chǎn)環(huán)境配置不同的配置文件呢?首先得有如下5個(gè).properties 配置 文件: application.properties ------------------ 總配置文件
application-test.properties ------------------ 本地
application-sit.properties ------------------ 測(cè)試
application-pre.properties ------------------ 預(yù)生產(chǎn)
application-pid.properties ------------------ 生產(chǎn)
每個(gè)環(huán)境下的配置寫(xiě)到對(duì)應(yīng)的配置文件中,然后在總配置文件application.properties中通過(guò) spring.profiles.active= 讀取不同的配置文件, =test 時(shí)讀取 application-test.properties , =sit 時(shí)讀取 application-sit.properties 。 4、整合jdbcTemplate: 雖然jdbcTemplate用得不多了,也介紹一下如何整合。 添加依賴: <!-- 要用jdbcTemplate,除了數(shù)據(jù)庫(kù)依賴,添加這一個(gè)即可 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
<version>2.0.2.RELEASE</version>
</dependency>
注入使用: 在需要使用的地方直接注入使用即可,如下: public class test{
@AutoWired
private JdbcTemplate jdbcTemplate;
public void insertUser(String name,int age){
jdbcTemplate.update("insert into tb_user values(null,?,?)",name,age);
}
}
5、整合jpa: 添加依賴: <!-- 除了數(shù)據(jù)庫(kù)依賴,添加這一個(gè)即可 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
<version>2.0.2.RELEASE</version>
</dependency>
加注解: 在啟動(dòng)類上添加兩個(gè)注解: @EntityScan("實(shí)體類所在的包") , @EnableJpaRepositories("dao層所在包名") ,如下圖: @EnableJpaRepositories("com.zhu.dao")
@EntityScan("com.zhu.entity")
@SpringBootApplication
public class App{
public static void main(String[] args){
SpringApplication.run(App.class,args);
}
}
完成這兩步就可以使用jpa了。 6、整合mybatis: 添加依賴: <dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>1.3.2</version>
</dependency>
加注解: 啟動(dòng)類上加 @MapperScan("dao層所在包名") ,若需要事務(wù)支持,加上 @EnableTransactionManagement ,如下: @EnableTransactionManagement
@MapperScan("com.zhu.dao")
@SpringBootApplication
public class App{
public static void main(String[] args){
SpringApplication.run(App.class,args);
}
}
若mybatis基于注解形式,這樣就行了,可以直接使用了,若mybatis基于xml形式,那就要在application.properties中配置如下內(nèi)容: #掃描dao層接口對(duì)應(yīng)的xml文件
mybatis.mapper-locations=classpath:mapper/*.xml
#掃描mybatis的配置文件
mybatis.config-location=classpath:mybatis-config.xml
#起別名(可選),寫(xiě)了這個(gè)在resultType中就不用寫(xiě)實(shí)體類包名,直接寫(xiě)類名即可
mybatis.type-aliases-package=com.zhu.entity
7、整合多數(shù)據(jù)源: 整合多數(shù)據(jù)源一般才用分包管理的辦法,比如test1包使用數(shù)據(jù)源1,test2包使用數(shù)據(jù)源2。具體做法如下: 首先來(lái)看項(xiàng)目的目錄結(jié)構(gòu): 
配置: ####整合多數(shù)據(jù)源#####
######數(shù)據(jù)源1:springboot1########
spring.datasource.springboot1.driverClassName = com.mysql.jdbc.Driver
spring.datasource.springboot1.url = jdbc:mysql:///springboot1
spring.datasource.springboot1.username = #
spring.datasource.springboot1.password = #
######數(shù)據(jù)源2:springboot2########
spring.datasource.springboot2.driverClassName = com.mysql.jdbc.Driver
spring.datasource.springboot2.url = jdbc:mysql:///springboot2
spring.datasource.springboot2.username = #
spring.datasource.springboot2.password = #
數(shù)據(jù)源1是連接的springboot1數(shù)據(jù)庫(kù),數(shù)據(jù)源2是連接springboot2數(shù)據(jù)庫(kù)。以 spring.datasource.springboot1. 和 spring.datasource.springboot2. 來(lái)區(qū)分?jǐn)?shù)據(jù)源1和數(shù)據(jù)2。但是這屬于自定義的標(biāo)簽,springboot不會(huì)自動(dòng)加載這兩個(gè) 數(shù)據(jù)源,因此要?jiǎng)?chuàng)建兩個(gè)配置類去加載這兩個(gè)數(shù)據(jù)源: 加載數(shù)據(jù)源: /**
* 配置數(shù)據(jù)源1(springboot1)的類
* @author zhu
*
*/
@Configuration
//表示只要是在test01包下的,都訪問(wèn)springboot1數(shù)據(jù)源
@MapperScan(basePackages = "com.zhu.test01",sqlSessionFactoryRef = "springboot1SqlSessionFactory")
public class DataSource1Config {
//創(chuàng)建datasource
@Bean(name = "springboot1DataSource")
@ConfigurationProperties(prefix = "spring.datasource.springboot1")
@Primary
public DataSource testDataSource() {
return DataSourceBuilder.create().build();
}
//創(chuàng)建SqlSessionFactory并注入datasource
@Bean(name = "springboot1SqlSessionFactory")
@Primary
public SqlSessionFactory testSqlSessionFactory(@Qualifier("springboot1DataSource") DataSource dataSource)
throws Exception{
SqlSessionFactoryBean bean = new SqlSessionFactoryBean();
bean.setDataSource(dataSource);
return bean.getObject();
}
//創(chuàng)建事物管理并注入dataSource
@Bean(name = "springboot1TransactionManager")
@Primary
public DataSourceTransactionManager testTransactionManager(@Qualifier("springboot1DataSource") DataSource dataSource) {
return new DataSourceTransactionManager(dataSource);
}
//創(chuàng)建事物管理并注入sqlSessionFactory
@Bean(name = "springboot1SqlSessionTemplate")
@Primary
public SqlSessionTemplate testSqlSessionTemplate(@Qualifier("springboot1SqlSessionFactory")
SqlSessionFactory sqlSessionFactory) throws Exception {
return new SqlSessionTemplate(sqlSessionFactory);
}
}
/**
* 配置數(shù)據(jù)源2(springboot2)的類
* @author zhu
*
*/
@Configuration
//表示只要是在test02包下的,都訪問(wèn)springboot2數(shù)據(jù)源
@MapperScan(basePackages = "com.zhu.test02",sqlSessionFactoryRef = "springboot2SqlSessionFactory")
public class DataSource2Config {
//創(chuàng)建datasource
@Bean(name = "springboot2DataSource")
@ConfigurationProperties(prefix = "spring.datasource.springboot2")
public DataSource testDataSource() {
return DataSourceBuilder.create().build();
}
//創(chuàng)建SqlSessionFactory并注入datasource
@Bean(name = "springboot2SqlSessionFactory")
public SqlSessionFactory testSqlSessionFactory(@Qualifier("springboot2DataSource") DataSource dataSource)
throws Exception{
SqlSessionFactoryBean bean = new SqlSessionFactoryBean();
bean.setDataSource(dataSource);
return bean.getObject();
}
//創(chuàng)建事物管理并注入dataSource
@Bean(name = "springboot2TransactionManager")
public DataSourceTransactionManager testTransactionManager(@Qualifier("springboot2DataSource") DataSource dataSource) {
return new DataSourceTransactionManager(dataSource);
}
//創(chuàng)建事物管理并注入sqlSessionFactory
@Bean(name = "springboot2SqlSessionTemplate")
public SqlSessionTemplate testSqlSessionTemplate(@Qualifier("springboot2SqlSessionFactory")
SqlSessionFactory sqlSessionFactory) throws Exception {
return new SqlSessionTemplate(sqlSessionFactory);
}
}
這樣就完成了這兩個(gè)數(shù)據(jù)源的加載,由于有 @MapperScan 指定包, prefix= ... 指定加載哪個(gè)數(shù)據(jù)源,所以就能實(shí)現(xiàn)test01包下的就使用springboot1這個(gè)數(shù)據(jù)庫(kù),test02包下的就使用springtboot2數(shù)據(jù)庫(kù)。至此就完成了多數(shù)據(jù)源的整合。注意其中一個(gè)數(shù)據(jù)源的加載時(shí)要加上 @Primary 注解,否則會(huì)報(bào)錯(cuò)。 總結(jié):以上就是springboot常用的一些功能,通過(guò)整合上面那些技術(shù)肯定已經(jīng)感受到了它的便捷,更多spring boot的用法,本公眾號(hào)將持續(xù)更新。
|