有不知道怎麼安裝的嗎?File-->settings打開設置面板,找到plugins,輸入想要安裝的插件回車便可html
目前,IDEA支持設置背景圖片。這對於廣大程序員來講無疑是個好功能。整日對着枯燥的代碼實在是會讓人疲乏。要是能夠設置一張美女圖片的話。。。
設置方法:
Ctrl+Shift+A(或者help -> find action)調用彈窗後輸入Set Background Image
java
在裏面設定要設置爲Image的圖片,透明度調到15左右,保存便可。nginx
效果如圖:
git
平常開發中,可能常常會遇到jar包衝突等問題,就須要經過查看maven依賴樹來查看依賴狀況。這種方式不是很高效,這裏推薦一個插件,安裝以後,直接打開pom文件,便可查看依賴數,還能自動分析是否存在jar包衝突。
一旦安裝了Maven Helper插件,只要打開pom文件,就能夠打開該pom文件的Dependency Analyzer視圖(在文件打開以後,文件下面會多出這樣一個tab)。
程序員
進入Dependency Analyzer視圖以後有三個查看選項分別是:web
FindBugs不少人都並不陌生,Eclipse中有插件能夠幫助查找代碼中隱藏的bug,IDEA中也有這款插件。spring
使用方法很簡單,就是能夠對多種級別的內容進行finbugs
分析完以後會有一個視圖進行提示,詳細的說明是哪一種問題。
json
檢測JAVA代碼中存在不規範得位置而後給予提示,阿里巴巴規約插件包含三個子菜單:編碼規約掃描、關閉試試檢測功能。
安裝好此插件便可自動在不規範位置給與提示
api
Java開發中,常常有把json格式的內容轉成Object的需求,好比項目開始時,合做方給你提供了一個json格式request/response,這時候你就須要將其定義成一個Java類,GsonFormat這款插件能夠實現該功能。
跨域
在Java中,咱們常常會定義不少JavaBean,這些Bean須要有getter、setter、toString、equals和hashCode等方法。
一般狀況下,咱們可使用IDEA的快捷鍵生成這些代碼,可是自動生成的代碼後,若是bean中的屬性一旦有修改,須要從新生成,給代碼維護增長了必定的負擔。
有一款很好的插件,能夠幫助開發者節省這部分工做。那就是Lombok。
只要在IDEA中安裝了該插件,只須要在JavaBean中添加一行註解代碼,插件就會自動幫咱們生成getter、setter、toString、equals和hashCode等方法。
固然,這些方法不止在IDE中的代碼調用中須要用到,在真正線上部署的時候也須要有,因此,還須要使用maven引入一個lombok的包。
@Data class Wechat { private String id; private String desc; }
咱們在Wechat類上面添加了@Data註解,插件就自動幫咱們添加了getter/setter和toString方法。
字符串平常開發中常常用到的,可是不一樣的字符串類型在不一樣的地方可能有一些不一樣的規則,好比類名要用駝峯形式、常量須要所有大寫等,有時候還須要進行編碼解碼等。這裏推薦一款強大的字符串轉換工具——String Manipulation。
它強大到什麼程度,看下他的功能列表你就知道了:
安裝好插件後,選中須要處理的內容後,按快捷鍵Alt+m,便可彈出工具功能列表。
很好很強大的一款字符串處理工具。
目前ORM框架中,Mybatis很是受歡迎。可是,同時給不少開發帶來困擾的就是Mybatis須要不少xml的配置文件,有的時候很難去進行修改。
這裏推薦一款神器,可讓你像編輯java代碼同樣編輯mybatis的文件。
Intellij Idea Mybatis插件主要功能:
提供Mapper接口與配置文件中對應SQL的導航
編輯XML文件時自動補全
根據Mapper接口, 使用快捷鍵生成xml文件及SQL標籤
ResultMap中的property支持自動補全,支持級聯(屬性A.屬性B.屬性C)
快捷鍵生成@Param註解
XML中編輯SQL時, 括號自動補全
XML中編輯SQL時, 支持參數自動補全(基於@Param註解識別參數)
自動檢查Mapper XML文件中ID衝突
自動檢查Mapper XML文件中錯誤的屬性值
支持Find Usage
支持重構從命名
支持別名
自動生成ResultMap屬性
(圖源:https://www.oschina.net/p/intellij-mybatis-plugin)
可是這款插件是收費的,可是不影響他確實是一個很實用,能夠很大程度上提高開發效率的插件。讀者能夠考慮使用Free Mybatis plugin(這款插件我沒用過,具體是否好用有待考證)。
對於不少剛剛開始使用IDEA的開發者來講,最苦惱的就是不知道快捷鍵操做是什麼。
使用IDEA,若是全部操做都使用鼠標,那麼說明你還不是一個合格的程序員。
這裏推薦一款能夠進行快捷鍵提示的插件Key promoter X。
Key Promoter X 是一個提示插件,當你在IDEA裏面使用鼠標的時候,若是這個鼠標操做是可以用快捷鍵替代的,那麼Key Promoter X會彈出一個提示框,告知你這個鼠標操做能夠用什麼快捷鍵替代。
當我使用鼠標查看一個方法都被哪些類使用的時候,就會提示:
記住這個快捷鍵之後,就可使用快捷鍵代替鼠標啦。
最後,介紹一款程序員很好的在妹子面前裝X的插件——activate-power-mode 。
安裝了這款插件以後,你寫代碼的時候,就會附加一些狂拽炫酷屌炸天的效果:
git提交時過濾掉不須要提交的文件,很方便,有些本地文件是不須要提交到Git上的。
將不是駝峯格式的名稱,快速轉成駝峯格式,安裝好後,選中要修改的名稱,按快捷鍵shift+alt+u。
在編輯區的右側顯示的代碼地圖。
這是一款主題插件,可讓你的ide的圖標變漂亮,配色搭配的很到位,還能夠切換不一樣的顏色,甚至能夠自定義顏色。默認的配色就很漂亮了,若是須要修改配色,能夠在工具欄中Tools->Material Theme而後修改配色等。
這是一款能夠設置idea背景圖片的插件,不但能夠設置固體的圖片,還能夠設置一段時間後隨機變化背景圖片,以及設置圖片的透明度等等。
彩虹顏色的括號 看着很舒服 敲代碼效率變高
原來咱們在使用tomcat
開發時,設置網站圖片時,即icon圖標時,通常都是直接替換root
包下的favicon.ico
替換成本身的,或者在網頁的頭部設置link
的ref爲icon
而後設置其href
值。而在SpringBoot
中,替換圖片也是很簡單的,只須要將自定義圖片放置在靜態資源
目錄下便可,即默認有static
、public
、resources
、/META-INF/resources
或者自定義的靜態目錄下便可。
目錄結構:
CORS是一個W3C標準,全稱是」跨域資源共享」(Cross-origin resource sharing)。它容許瀏覽器向跨源(協議 + 域名 + 端口)服務器,發出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
配置。官網也有給出實例,具體以下:
@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
包,而後修改下啓動類配置便可。
0.修改pom打包方式爲war
,同時排除了內置的tomcat
。
<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
方法。
@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效果圖: