java 讀取文件路徑空格、“+”和中文的處理

有時候在java代碼中讀取文件,如果文件所在路徑包含空格、”+“號或者是中文的時候,由于這些特殊的字符會被進行編碼轉譯,所以就會報沒有發(fā)現(xiàn)文件的錯誤,那么遇到這種錯誤,我們就要把編碼過后的路徑進行解碼,這樣才能正確的找到文件。主要的解決方法有一下三種方法:

解決方法

1、替換法

比如文件路徑如果存在空格,那么會被轉譯成“%20”,那么就可以利用字符串替換,把“%20”傳化成空格,這樣就能正確的找到文件了。這是這種如此暴力,低級的處理方法,一般有經驗的開發(fā)人員都不會采用吧?

2、使用URLDecoder.decode(str,enc)進行解碼

如果空格、中文被轉譯過后,可以使用URLDecoder.decode方法進行解碼,但是這種方法對于路徑中包含“+”號并不能進行正確解碼,因為URLDecoder.decode方法內部如果發(fā)現(xiàn)是加號,將會將其轉成空格:

3、萬能方法,使用toURI().getPath()

toURI()會跟自己的規(guī)則對字符串進行編碼,然后又能自動解碼,所以不用自己去關心這些事情,可以自行看下它的源碼。

演示:

web項目部署在一個tomcat中,路徑為:”D:\Program Files\java\apache-tomcat-6.0.26”

1、字符串包含空格:

從截圖中可以看到,路徑存在的空格已經被轉成“%20”,如果不對這包含空格的路徑進行解碼,那么直接讀取文件是獲取不到的;如果使用了以上第二、第三種方法,則能正確獲取到文件。

2、路徑中包含“+”

從上圖可以看到,如果路徑中包含“+”號,那么第二種方法就失效了,但是第三種方法還是有效。所以平時使用最好是使用第三種方法比較好。此外,以上介紹的方法,如果部署在linux下也是適用的。

原文鏈接:https://blog.csdn.net/LZJLZJLZJLZJLZJLZJ/article/details/63252978

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

友情鏈接更多精彩內容