最近工做比較忙,事情也比較多。加班回到家都十點多了,洗個澡就想睡覺了。因此爲了避免斷更太多天,偷懶寫個小技巧合集吧。以後有時間都會進行文章更新的。原創不易,碼字不易,還但願你們多多支持!話很少說,開始今天的技巧合集吧~html
原來咱們在使用tomcat
開發時,設置網站圖片時,即icon圖標時,通常都是直接替換root
包下的favicon.ico
替換成本身的,或者在網頁的頭部設置link
的ref爲icon
而後設置其href
值。而在SpringBoot
中,替換圖片也是很簡單的,只須要將自定義圖片放置在靜態資源
目錄下便可,即默認有static
、public
、resources
、/META-INF/resources
或者自定義的靜態目錄下便可。java
目錄結構:nginx
CORS是一個W3C標準,全稱是"跨域資源共享"(Cross-origin resource sharing)。它容許瀏覽器向跨源(協議 + 域名 + 端口)服務器,發出XMLHttpRequest請求,從而克服了AJAX只能同源使用的限制。git
簡單來講,跨域問題是能夠經過nginx
來解決的,或者經過jsonp(只支持get請求)
來解決。而SpringBoot
中也提供了配置方法。 0.利用@CrossOrigin
註解,可放至在類上或者方法上。類上表明整個控制層全部的映射方法都支持跨域請求。github
@CrossOrigin(origins = "http://blog.lqdev.cn", maxAge = 3600) @RestController public class demoController{ @GetMapper("/") public String index(){ return "hello,CORS"; } }
1.配置全局CORS
配置。官網也有給出實例,具體以下:web
@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"); } }; } }
講解了這麼久,通常上咱們都是經過jar包的方式進行啓動的應用的。因此部署在獨立的
tomcat
時,須要如何解決呢?其實也簡單,只須要將項目打包方式修改成war
包,而後修改下啓動類配置便可。spring
0.修改pom打包方式爲war
,同時排除了內置的tomcat
。json
<packaging>war</packaging> <!-- 排除內置的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
方法。api
@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); //以後這裏設置業務邏輯 好比掛起一個線程 或者設置一個定時任務。保證不退出 //否則它就是一個啓動類,啓動後就中止了。 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中,啓動運行便可。跨域
其實這樣設置的話,在開發時直接運行啓動類也仍是能夠直接運行的,方便.
對一些定時任務服務項目,其自己只是提供一個定時調度功能,不須要其餘服務調用,只是去調度其餘服務。像這樣的服務,正常也就不須要設置端口了。這時候SpringBoot
也是支持的。只須要改下啓動方式:
new SpringApplicationBuilder().sources(ChapterApplication.class).web(false).run(args); //以後這裏設置業務邏輯 好比掛起一個線程 或者設置一個定時任務。保證不退出 //否則它就是一個啓動類,啓動後就中止了。
或者修改配置文件的屬性:
spring.main.web-environment=false
最後效果,是否是沒有看見端口了:
利用CommandLineRunner
或者ApplicationRunner
可實如今SpringApplication
的run()
完成前執行一些業務邏輯
0.修改啓動類,實現CommandLineRunner
接口,ApplicationRunner
相似,只是run
的入參不一樣而已。
@Override public void run(String... args) throws Exception { log.info("CommandLineRunner運行"); }
1.運行應用,注意查看控制檯輸出:
固然,直接申明一個bean
也是能夠的。
@Configuration @Slf4j public class CommandLineRunnerConfig { @Bean public CommandLineRunner runner(){ return new CommandLineRunner() { public void run(String... args){ log.info("CommandLineRunner運行2"); } }; } }
若多個時,可設置@Order
來肯定執行的順序。
經過org.springframework.boot.logging.LoggingSystem
提供的api便可。
loggingSystem.setLogLevel(null, LogLevel.DEBUG);
如,默認時是info
模式,未修改時,debug
模式是不會輸出的。
動態設置後
前面講了這麼多章節,由於功能都很單一,因此通常上都是直接重啓服務來進行更新操做。但當服務功能一多,啓動速度緩慢時,仍是配置個熱部署比較方便。在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
,提現逼格的時候到了~哈哈,如下是官網給的配置指南:
其實,替換很簡單,只須要在classpath
路徑下建立一個banner.txt
便可。具體的一些變量官網也有給出,具體以下:
如今咱們就定製一個本身的Banner
。
_ _ _ _ __ _ | | | | | | | |/ / | | | |__ ___ | | | | ___ ___ | ' / ___ _ __ __ _ | | | '_ \ / _ \ | | | | / _ \ / _ \ | < / _ \ | '_ \ / _` | | | | | | | | __/ | | | | | (_) | _ | (_) | | . \ | (_) | | | | | | (_| | |_| |_| |_| \___| |_| |_| \___/ ( ) \___/ |_|\_\ \___/ |_| |_| \__, | (_) |/ __/ | |___/ ${AnsiColor.BRIGHT_RED} Spring Boot Version: ${spring-boot.version}${spring-boot.formatted-version}
題外話:手輸字符畫是不太現實的,你們可經過一些網站進行快速生成。可自行搜索下,網上一搜一大把。
若以爲使用文字不夠酷炫,固然也能夠將圖片設置爲啓動的banner
。目前支持的圖片格式有gif
、png
、jpg
。使用也很簡單,只須要命名爲banner
便可。
如將頭像放入目錄中,最後的效果以下:
固然,若圖片是有色彩的,也是能夠的,對於太複雜的圖片顯示效果就不佳了,以下。
原圖:
banner效果圖:
是否是很酷炫~
一、https://docs.spring.io/spring-boot/docs/1.5.15.RELEASE/reference/htmlsingle
本章節主要是簡單的介紹了一些
SpringBoot
的一些小技巧,通常上也就一句話或者一個註釋、一句配置就解決問題的。寫這篇文章時,又去翻了翻官網的指南,很不錯,每次都去看都有新發現。以上有部分就是看了寫下的。確實,在看官網時,通常上是須要了解哪些知識點,就搜索直奔主題了,尚未哪次是從頭看的。有時間仍是耐心的看一看,就是全是英文看的有點頭疼,好在代碼是看的懂的,⊙﹏⊙‖∣
本來是想偷懶,發一點時間完成的。最後本着有圖有真相且負責的原則,爲了截圖展示效果,實際操做了一遍,發現時間沒有和寫一篇正文來的少,好尷尬。。既然說了,就簡單說下,接下來的章節會涉及的知識點吧。接下來仍是
web開發相關
,會介紹下websocket
相關知識點,這部分本人也不是很熟悉,估計寫的也是簡單入門的,也但願會來個聊天室的實踐,加深下影響。說了webSocket
,那就不能把Servlet3.0
提供的異步請求
機制遺漏了,會介紹下原生的方式及Spring
提供的方式實現,對一些異常處理,好比超時等設置也會進行說明下,既然都說的異步請求
了,順道也就講下異步調用
的相關知識點吧。至於Docker
系列,鑑於本人也是初學者,寫起來仍是比較慢的,有時間就更吧~
目前互聯網上不少大佬都有
SpringBoot
系列教程,若有雷同,請多多包涵了。本文是做者在電腦前一字一句敲的,每一步都是實踐的。若文中有所錯誤之處,還望提出,謝謝。
499452441
lqdevOps
我的博客:http://blog.lqdev.cn
完整實例:https://github.com/xie19900123/spring-boot-learning/tree/master/chapter
原文地址:http://blog.lqdev.cn/2018/08/11/springboot/springboot-tips/