原文出處: oKong
前言
最近工作比較忙,事情也比較多。加班回到家都十點多了,洗個澡就想睡覺了。所以為了不斷更太多天,偷懶寫個小技巧合集吧。之后有時間都會進(jìn)行文章更新的。原創(chuàng)不易,碼字不易,還希望大家多多支持!話不多說,開始今天的技巧合集吧~
設(shè)置網(wǎng)站圖標(biāo)
原來我們在使用tomcat開發(fā)時,設(shè)置網(wǎng)站圖片時,即icon圖標(biāo)時,一般都是直接替換root包下的favicon.ico替換成自己的,或者在網(wǎng)頁的頭部設(shè)置link的ref為icon然后設(shè)置其href值。而在SpringBoot中,替換圖片也是很簡單的,只需要將自定義圖片放置在靜態(tài)資源目錄下即可,即默認(rèn)有static、public、resources、/META-INF/resources或者自定義的靜態(tài)目錄下即可。
目錄結(jié)構(gòu):
允許跨域訪問
CORS是一個W3C標(biāo)準(zhǔn),全稱是”跨域資源共享”(Cross-origin resource sharing)。它允許瀏覽器向跨源(協(xié)議 + 域名 + 端口)服務(wù)器,發(fā)出XMLHttpRequest請求,從而克服了AJAX只能同源使用的限制。
簡單來說,跨域問題是可以通過nginx來解決的,或者通過jsonp(只支持get請求)來解決。而SpringBoot中也提供了配置方法。
0.利用@CrossOrigin注解,可放至在類上或者方法上。類上代表整個控制層所有的映射方法都支持跨域請求。
@CrossOrigin(origins = "http://blog.lqdev.cn", maxAge = 3600)
@RestController
public class demoController{
@GetMapper("/")
public String index(){
return "hello,CORS";
}
}
1.配置全局CORS配置。官網(wǎng)也有給出實例,具體如下:
@Configuration
public class MyConfiguration {
@Bean
public WebMvcConfigurer corsConfigurer() {
return new WebMvcConfigurerAdapter() {
@Override
public void addCorsMappings(CorsRegistry registry) { registry.addMapping("/api/**").allowedOrigins("https://blog.lqdev.cn");
}
};
}
}
獨立Tomcat運(yùn)行
講解了這么久,一般上我們都是通過jar包的方式進(jìn)行啟動的應(yīng)用的。所以部署在獨立的
tomcat時,需要如何解決呢?其實也簡單,只需要將項目打包方式修改為war包,然后修改下啟動類配置即可。
0.修改pom打包方式為war,同時排除了內(nèi)置的tomcat。
<packaging>war</packaging>
<!-- 排除內(nèi)置的tomcat -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
<scope>compile</scope>
</dependency>
<!-- 若直接有使用servlet對象時(這是廢話,⊙﹏⊙‖∣),需要將servlet引入,本例是沒有的~ -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<scope>provided</scope>
</dependency>
1.改造下啟動類,使其繼承SpringBootServletInitializer,同時覆蓋configure方法。
@SpringBootApplication
@Slf4j
public class ChapterApplication extends SpringBootServletInitializer{
public static void main(String[] args) {
SpringApplication.run(ChapterApplication.class, args);
// new SpringApplicationBuilder().sources(ChapterApplication.class).web(false).run(args);
//之后這里設(shè)置業(yè)務(wù)邏輯 比如掛起一個線程 或者設(shè)置一個定時任務(wù)。保證不退出
//不然它就是一個啟動類,啟動后就停止了。
log.info("jar,chapter啟動!");
}
@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {
log.info("外部tomcat,chapter啟動!");
return application.sources(ChapterApplication.class);
}
}
2.maven打包成war(mvn clean install),然后放入tomcat中,啟動運(yùn)行即可。
其實這樣設(shè)置的話,在開發(fā)時直接運(yùn)行啟動類也還是可以直接運(yùn)行的,方便.
啟動不設(shè)置端口
對一些定時任務(wù)服務(wù)項目,其本身只是提供一個定時調(diào)度功能,不需要其他服務(wù)調(diào)用,只是去調(diào)度其他服務(wù)。像這樣的服務(wù),正常也就不需要設(shè)置端口了。這時候SpringBoot也是支持的。只需要改下啟動方式:
new SpringApplicationBuilder().sources(ChapterApplication.class).web(false).run(args);
//之后這里設(shè)置業(yè)務(wù)邏輯 比如掛起一個線程 或者設(shè)置一個定時任務(wù)。保證不退出
//不然它就是一個啟動類,啟動后就停止了。
或者修改配置文件的屬性:
spring.main.web-environment=false
最后效果,是不是沒有看見端口了:
啟動完成前進(jìn)行業(yè)務(wù)邏輯
利用CommandLineRunner或者ApplicationRunner可實現(xiàn)在SpringApplication的run()完成前執(zhí)行一些業(yè)務(wù)邏輯
0.修改啟動類,實現(xiàn)CommandLineRunner接口,ApplicationRunner類似,只是run的入?yún)⒉煌选?/p>
@Override
public void run(String... args) throws Exception {
log.info("CommandLineRunner運(yùn)行");
}
1.運(yùn)行應(yīng)用,注意查看控制臺輸出:
當(dāng)然,直接申明一個bean也是可以的。
@Configuration
@Slf4j
public class CommandLineRunnerConfig {
@Bean
public CommandLineRunner runner(){
return new CommandLineRunner() {
public void run(String... args){
log.info("CommandLineRunner運(yùn)行2");
}
};
}
}
若多個時,可設(shè)置@Order來確定執(zhí)行的順序。
動態(tài)修改日志級別
通過org.springframework.boot.logging.LoggingSystem提供的api即可。
loggingSystem.setLogLevel(null, LogLevel.DEBUG);
如,默認(rèn)時是info模式,未修改時,debug模式是不會輸出的。
動態(tài)設(shè)置后
熱部署
前面講了這么多章節(jié),因為功能都很單一,所以一般上都是直接重啟服務(wù)來進(jìn)行更新操作。但當(dāng)服務(wù)功能一多,啟動速度緩慢時,還是配置個熱部署比較方便。在SpringBoot中,只需要加入一個spring-boot-devtools即可
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<optional>true</optional>
</dependency>
</dependencies>
題外話:這里的<optional>true</optional>是表示依賴不會傳遞,依賴了此項目的需要額外引入此包,若需要使用的話。
若不生效,可試著在打包工具spring-boot-maven-plugin下的configuration加入<fork>true</fork>看看,具體配置項如下:
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<fork>true</fork>
</configuration>
</plugin>
自定義啟動Banner
看煩了自帶的Banner,動手修改一個屬于自己的Banner,提現(xiàn)逼格的時候到了~哈哈,以下是官網(wǎng)給的配置指南:
文字形式
其實,替換很簡單,只需要在classpath路徑下創(chuàng)建一個banner.txt即可。具體的一些變量官網(wǎng)也有給出,具體如下:
現(xiàn)在我們就定制一個自己的Banner。
_ _ _ _ __ _
| | | | | | | |/ / | |
| |__ ___ | | | | ___ ___ | ' / ___ _ __ __ _ | |
| '_ \ / _ \ | | | | / _ \ / _ \ | < / _ \ | '_ \ / _` | | |
| | | | | __/ | | | | | (_) | _ | (_) | | . \ | (_) | | | | | | (_| | |_|
|_| |_| \___| |_| |_| \___/ ( ) \___/ |_|\_\ \___/ |_| |_| \__, | (_)
|/ __/ |
|___/
${AnsiColor.BRIGHT_RED}
Spring Boot Version: ${spring-boot.version}${spring-boot.formatted-version}
題外話:手輸字符畫是不太現(xiàn)實的,大家可通過一些網(wǎng)站進(jìn)行快速生成??勺孕兴阉飨?,網(wǎng)上一搜一大把。
圖片形式
若覺得使用文字不夠酷炫,當(dāng)然也可以將圖片設(shè)置為啟動的banner。目前支持的圖片格式有gif、png、jpg。使用也很簡單,只需要命名為banner即可。
如將頭像放入目錄中,最后的效果如下:
當(dāng)然,若圖片是有色彩的,也是可以的,對于太復(fù)雜的圖片顯示效果就不佳了,如下。
原圖:
原圖banner效果圖:
是不是很酷炫~
相關(guān)資料
1、https://docs.spring.io/spring-boot/docs/1.5.15.RELEASE/reference/htmlsingle
總結(jié)
本章節(jié)主要是簡單的介紹了一些SpringBoot的一些小技巧,一般上也就一句話或者一個注釋、一句配置就解決問題的。寫這篇文章時,又去翻了翻官網(wǎng)的指南,很不錯,每次都去看都有新發(fā)現(xiàn)。以上有部分就是看了寫下的。確實,在看官網(wǎng)時,一般上是需要了解哪些知識點,就搜索直奔主題了,還沒有哪次是從頭看的。有時間還是耐心的看一看,就是全是英文看的有點頭疼,好在代碼是看的懂的,⊙﹏⊙‖∣
一點吐槽
原本是想偷懶,發(fā)一點時間完成的。最后本著有圖有真相且負(fù)責(zé)的原則,為了截圖展現(xiàn)效果,實際操作了一遍,發(fā)現(xiàn)時間沒有和寫一篇正文來的少,好尷尬。。既然說了,就簡單說下,接下來的章節(jié)會涉及的知識點吧。接下來還是web開發(fā)相關(guān),會介紹下websocket相關(guān)知識點,這部分本人也不是很熟悉,估計寫的也是簡單入門的,也希望會來個聊天室的實踐,加深下影響。說了webSocket,那就不能把Servlet3.0提供的異步請求機(jī)制遺漏了,會介紹下原生的方式及Spring提供的方式實現(xiàn),對一些異常處理,比如超時等設(shè)置也會進(jìn)行說明下,既然都說的異步請求了,順道也就講下異步調(diào)用的相關(guān)知識點吧。至于Docker系列,鑒于本人也是初學(xué)者,寫起來還是比較慢的,有時間就更吧~
最后
目前互聯(lián)網(wǎng)上很多大佬都有SpringBoot系列教程,如有雷同,請多多包涵了。本文是作者在電腦前一字一句敲的,每一步都是實踐的。若文中有所錯誤之處,還望提出,謝謝













