解決JavaMail附件名字過長導(dǎo)致的亂碼問題
問題背景:
公司有個業(yè)務(wù)場景是審核客戶機構(gòu)通過后,給客戶發(fā)送一封郵件,并將機構(gòu)相關(guān)材料以附件形式一塊發(fā)送,有些附件名正常,有些就亂了,如下圖:


后來發(fā)現(xiàn)是附近名稱過長導(dǎo)致的!
問題原因:java mail中設(shè)置附件名稱會采用 base64格式進行編碼,如果附件名稱過長會被進行切割,將剩下字符抹去,所以導(dǎo)致不知道這是什么格式的文件。
注:雖然將文件格式被改變了,但是若強制轉(zhuǎn)換成原格式(右鍵->另存為->xxx.pdf) 仍然可以進行打開,文件內(nèi)容也并非改變(這是測試后的結(jié)果)
解決方案:
由于是spring boot 項目,只需要在main方法中加入以下 代碼即可(大概意思就是,取消切割,默認是true)
System.setProperty("mail.mime.splitlongparameters", "false");

補充知識:LinkedList的增刪一定比ArrayList快嗎?
1.背景
眾所周知,arrayList底層是通過數(shù)組實現(xiàn),當(dāng)其超過容量時,會進行1.5的擴容,將原數(shù)組數(shù)據(jù)遷移至新數(shù)組中。
而LinkedList底層為雙向鏈表,其增加操作直接在尾部新增一個node節(jié)點即可。
那么,在插入相同的數(shù)據(jù)情況下(集合默認長度都是0),到底誰更快呢?
2.案例
public static void main(String[] args) {
List<String> array = new ArrayList<>();
List<String> linked = new LinkedList<>();
long start = System.currentTimeMillis();
int index = 10000000;
for (int i = 0; i < index; i++) {
array.add("" + i);
}
long end = System.currentTimeMillis();
System.out.println("ArrayList用時:" + (end - start) / 1000 + "s");
start = System.currentTimeMillis();
for (int i = 0; i < index; i++) {
linked.add("" + i);
}
end = System.currentTimeMillis();
System.out.println("LinkedList用時:" + (end - start) / 1000 + "s");
}
3.結(jié)果

4.分析
此處我是這么理解的,arrayList是通過下標直接去放入數(shù)據(jù),而linked需要創(chuàng)建一個Node然后 將數(shù)據(jù)放入,再與前節(jié)點建立鏈接。
然后不需要擴容的情況下,明顯arrayList快,那么擴容呢?其實我們測試用的是尾部插入。
也就是arrayList擴容后直接將前面的數(shù)據(jù)放入對應(yīng)下標,之后的在繼續(xù)按照下標插入就行,也就是有序在尾部插入。
如果數(shù)據(jù)量大通過尾部插入的話(不指定下標,默認就是在尾部插入),linked的插入需要建立對應(yīng)的對象,綁定關(guān)系,
而array則直接放置,其擴容也是按照原來順序放入新數(shù)組,速度比較鏈表 要更快。
我還專門做了一個按照頭部插入的方式,發(fā)現(xiàn)這時明顯鏈表高于數(shù)組的速度。
5.總結(jié)(個人觀點)
數(shù)組比之鏈表:
在需要擴容的前提下
插入效率隨著下標的遞增,其性能逐漸由鏈表偏向數(shù)組。
下標靠中間(鏈表的查詢慘不忍睹),所以其中間效率也是極低的
而數(shù)組插入的下標靠前,會涉及其下標之后元素移位操作,所以index越靠前插入,效率越低
6.插入性能

以上這篇解決JavaMail附件名字過長導(dǎo)致的亂碼問題就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
深入理解Java8新特性之接口中的默認方法和靜態(tài)方法
從Java8開始,程序允許在接口中包含帶有具體實現(xiàn)的方法,使用default修飾,這類方法就是默認方法。默認方法在接口中可以添加多個,并且Java8提供了很多對應(yīng)的接口默認方法,接下來讓我們一起來看看吧2021-11-11
Java中Spring技巧之?dāng)U展點的應(yīng)用
這篇文章主要介紹了Java中Spring技巧之?dāng)U展點的應(yīng)用,下文Spring容器的啟動流程圖展開其內(nèi)容的相關(guān)資料,具有一定的參考價值,需要的小伙伴可以參考一下2022-04-04
使用Spring Cloud Feign遠程調(diào)用的方法示例
這篇文章主要介紹了使用Spring Cloud Feign遠程調(diào)用的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-09-09
SpringMVC @GetMapping注解路徑?jīng)_突問題解決
MD5對密碼進行加密存儲是常見的一種加密方式,本文主要介紹了Java雙重MD5加密實現(xiàn)安全登錄,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07
Java 數(shù)組內(nèi)置函數(shù)toArray詳解
這篇文章主要介紹了Java 數(shù)組內(nèi)置函數(shù)toArray詳解,文本詳細的講解了toArray底層的代碼和文檔,需要的朋友可以參考下2021-06-06
一文搞懂spring boot本地事務(wù)@Transactional參數(shù)
這篇文章主要介紹了spring boot本地事務(wù)@Transactional參數(shù)詳解,本文通過示例代碼圖文相結(jié)合給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-10-10
解決IDEA?2022?Translation?翻譯文檔失敗:?未知錯誤的問題
這篇文章主要介紹了IDEA?2022?Translation?翻譯文檔失敗:?未知錯誤,本文較詳細的給大家介紹了IDEA?2022?Translation未知錯誤翻譯文檔失敗的解決方法,需要的朋友可以參考下2022-04-04
SpringBoot2.x設(shè)置Session失效時間及失效跳轉(zhuǎn)方式
這篇文章主要介紹了SpringBoot2.x設(shè)置Session失效時間及失效跳轉(zhuǎn)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03

