1、问题描述
正常的邮件附件名应该是带.xls后缀的如图
但是发送出来的邮件附件名被截断了,且没有后缀导致客户没法发开文件如图
在网上找了很多解决方案例如:
filenames=filenames.replace("\\r","").replace("\\n",""); //我本来就有的
SystemsetProperty("mail.mime.splitlongparameters", "false"); //我没有加上了,而且未知很靠前,放在启动类里面了
然并卵这些并没有解决我的问题,后来我转换了排查思路,从我自身项目入手,发现以上解决方案只是针对 mail.jar 1.4.4版本在linux服务器上的解决方案,而1.0版本是无论如何都不支持过长的附件名的,而1.4.5会Zion给优化这个缺陷
2、问题排查思路
2.1、使用同样的代码、数据库和一样的配置文件在DEV环境均不能复现,说明不是项目代码、数据库和配置文件的问题
2.2、由于UAT是linux环境,而DEV是Windows环境,怀疑是不同服务器的操作系统的差异的问题,但是将项目迁移到linux环境之后还是会出现附件名过长被截断的问题,排除是不同操作系统之间的差异问题
2.3、由此只能推断是引用的三方的jar包之间的差异导致的问题,通过对比UAT和DEV引用的jar包,发现DEV引用的mial的jar包版本是1.4.5的,而UAT引用使用的mail的j'a'r包版本是1.0的,将DEV上mail的j'a'r包换成1.0的之后第一次成功在dev复现附件名过长被截断的问题。由此定位到是mail的jar包的版本的问题
2.3、替换mail.jar由1.0到1.4.5成功修复
3、此次问题排查总结
问题排查的3大主线
1、项目代码,配置文件和数据库
2、不同服务器操作系统(如果有,没有则省略)
3、引用的jar包的版本差异
|