Eclipse報錯 Setting property 'source' to 'org eclipse jst jee
分享一下我老師大神的人工智慧教程!零基礎,通俗易懂!http://blog.csdn.net/jiangjunshow
也歡迎大家轉載本篇文章。分享知識,造福人民,實現我們中華民族偉大復興!
最近把Eclipse的maven外掛從m2eclipse更新到m2e後出了一些莫名其妙的的問題。今天又出了一個,就是Eclipse新建的Maven Web project在tomcat裡啟動後報錯,具體報錯資訊如下:
- 警告: [SetPropertiesRule]{Server/Service/Engine/Host/Context} Setting property 'source' to 'org.eclipse.jst.jee.server:test1' did not find a matching property.
對於這個問題,網上很多人給出的原因和解決方案如下:
解決方法是在Servers視圖裡雙擊建立的server,然後在其server的配置介面中選中"Publish module contexts to separate XML files"選項。
不過我按這種方式操作後發現還是會報這個問題,除了這種方式之外網上也沒有什麼參考資料了,這個問題糾結了我幾天。仔細檢查工程結構後發現我的工程根目錄下生成了一個WebContent資料夾。具體截圖如下:
一般來說正常的maven專案的web資原始檔都是預設位於src/main/webapp下,WebContent只是普通的Dynamic Web project使用的預設Web檔案目錄。而我這個工程竟然同時生成了這兩個目錄,而且兩個目錄下都有WEB-INF資料夾。這個是不是問題的根源呢?
為了排查,我又重新新建了一個maven web project,工程名為test2。新建完後發現並沒有生成WebContent資料夾。我們都知道,Eclipse中建Maven Web工程需要新增Project Facets。具體步驟如下圖所示:
1.右鍵--Properties
2.選擇Project Facets,然後點選右邊的Convert to faceted from...
3.在彈出的視窗中選擇Dynamic Web Module
4.如上圖所示在視窗下方還有一個Further configuration available...,點選後彈窗如下,開啟完後終於找到了原因所在,在這一步需要設定工程的content directory,如果不設定,目錄名稱預設就是WebContent。
前一步我是沒有設定,所以才會生成預設的WebContent目錄。
新增完Facets後,把test2工程部署在tomcat啟動,發現之前的錯誤已經不存在了。
解決完問題後,心裡還是有點不踏實,問題的根源到底是什麼呢。逐一比對了兩個工程的檔案內容後終於發現了區別所在。區別在於工程.settings資料夾下。.settings目錄下的檔案附圖如下:
上圖高亮的部分的兩個檔案就是區別所在。
其中.jsdtscope中有一行定義:
Xml程式碼- <classpathentry kind="src" path="WebContent"/>
而test2工程的定義如下:
Xml程式碼- <classpathentry kind="src" path="src/main/webapp"/>
另外org.eclipse.wst.common.component檔案中定義了工程的wb-resource
Xml程式碼- <wb-resource deploy-path="/" source-path="/WebContent" tag="defaultRootSource"/>
test2工程的定義如下:
Xml程式碼- <wb-resource deploy-path="/" source-path="/src/main/webapp" tag="defaultRootSource"/>
綜上所述,推測tomcat在部署工程時會去查詢.settings中定義的配置。如果配置有問題,則會報錯。上面的問題,只要把test1工程.settings目錄下對應的兩個檔案的配置修改後重新部署就能正常啟動了。