日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

Eclipse報錯:Setting property 'source' to 'o

系統 1959 0

最近把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.
    

對于這個問題,網上很多人給出的原因和解決方案如下:

寫道
出現SetPropertiesRule警告的原因是因為Tomcat在server.xml的Context節點中不支持source屬性:<Context docBase="…" path="/…" source="org.eclipse.jst.j2ee.server:…"/>
解決方法是在Servers視圖里雙擊創建的server,然后在其server的配置界面中選中"Publish module contexts to separate XML files"選項。

不過我按這種方式操作后發現還是會報這個問題,除了這種方式之外網上也沒有什么參考資料了,這個問題糾結了我幾天。仔細檢查工程結構后發現我的工程根目錄下生成了一個WebContent文件夾。具體截圖如下:

Eclipse報錯:Setting property 'source' to 'org.eclipse.jst.jee.server:test1' did no

一般來說正常的maven項目的web資源文件都是默認位于src/main/webapp下,WebContent只是普通的Dynamic Web project使用的默認Web文件目錄。而我這個工程竟然同時生成了這兩個目錄,而且兩個目錄下都有WEB-INF文件夾。這個是不是問題的根源呢?

?

為了排查,我又重新新建了一個maven web project,工程名為test2。新建完后發現并沒有生成WebContent文件夾。我們都知道,Eclipse中建Maven Web工程需要添加Project Facets。具體步驟如下圖所示:

1.右鍵--Properties

Eclipse報錯:Setting property 'source' to 'org.eclipse.jst.jee.server:test1' did no

2.選擇Project Facets,然后點擊右邊的Convert to faceted from...

Eclipse報錯:Setting property 'source' to 'org.eclipse.jst.jee.server:test1' did no

3.在彈出的窗口中選擇Dynamic Web Module

Eclipse報錯:Setting property 'source' to 'org.eclipse.jst.jee.server:test1' did no
4.如上圖所示在窗口下方還有一個Further configuration available...,點擊后彈窗如下,打開完后終于找到了原因所在,在這一步需要設置工程的content directory,如果不設置,目錄名稱默認就是WebContent。

Eclipse報錯:Setting property 'source' to 'org.eclipse.jst.jee.server:test1' did no
前一步我是沒有設置,所以才會生成默認的WebContent目錄。

?

添加完Facets后,把test2工程部署在tomcat啟動,發現之前的錯誤已經不存在了。

解決完問題后,心里還是有點不踏實,問題的根源到底是什么呢。逐一比對了兩個工程的文件內容后終于發現了區別所在。區別在于工程.settings文件夾下。.settings目錄下的文件附圖如下:

Eclipse報錯:Setting property 'source' to 'org.eclipse.jst.jee.server:test1' did no

上圖高亮的部分的兩個文件就是區別所在。

其中.jsdtscope中有一行定義:

      <classpathentry kind="src" path="WebContent"/>
    

?而test2工程的定義如下:

      <classpathentry kind="src" path="src/main/webapp"/>
    

另外org.eclipse.wst.common.component文件中定義了工程的wb-resource

      <wb-resource deploy-path="/" source-path="/WebContent" tag="defaultRootSource"/>
    

test2工程的定義如下:

      <wb-resource deploy-path="/" source-path="/src/main/webapp" tag="defaultRootSource"/>
    

?

綜上所述,推測tomcat在部署工程時會去查找.settings中定義的配置。如果配置有問題,則會報錯。上面的問題,只要把test1工程.settings目錄下對應的兩個文件的配置修改后重新部署就能正常啟動了。

Eclipse報錯:Setting property 'source' to 'org.eclipse.jst.jee.server:test1' did no


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 库伦旗| 永靖县| 德庆县| 十堰市| 边坝县| 商水县| 屏东县| 赤峰市| 壶关县| 庆城县| 韶关市| 罗源县| 德清县| 元氏县| 乐业县| 屯门区| 嘉兴市| 陕西省| 安溪县| 惠安县| 自治县| 翁牛特旗| 隆昌县| 咸丰县| 丹寨县| 昌吉市| 侯马市| 松溪县| 出国| 肃北| 司法| 益阳市| 苍溪县| 湖南省| 临猗县| 新宁县| 驻马店市| 东光县| 马关县| 建德市| 红桥区|