为了跟踪此问题,笔者翻阅了tomcat代码提交记录,其中2017年有一条提交记录

QQ图片20200420220305.png

代码中在默认的servlet中未指定编码的情况下,自动读取操作系统中的文件编码当作静态文件的编码

1.png

java 18以前中文的windows通常是gbk编码,linux通常是utf8编码。但是现在大部分程序默认都使用utf8编码,就是这处逻辑导致了新版本tomcat处理静态文件时会产生中文乱码,这种自作聪明的做法很显然不符合java一次编译到处运行的思想。

这个问题具体影响的版本为:8.5.17及以上,7.0.80及以上,9.0

解决方法有如下两种,建议采用*种方法

1. 给Tomcat指定文件编码可以在catalina.bat中修改下面这一行

set "JAVA_OPTS=%JAVA_OPTS% %JSSE_OPTS%"

改为

set "JAVA_OPTS=%JAVA_OPTS% %JSSE_OPTS% -Dfile.encoding=UTF-8"

2. 修改Tomcat conf/web.xml,给default servlet增加

        <init-param>
            <param-name>fileEncoding</param-name>
            <param-value>utf-8</param-value>
        </init-param>

在开发工具中处理静态文件乱码,修改tomcat脚本或设置是无效的,需要修改开发工具本身的设置:

1. Eclipse中默认设置一般就是utf8,如果也存在这样的问题可以按照下图修改

QQ图片20200420215750.png

2. 在Idea中,可以按照下图修改:

QQ图片20200420213615.png

需要注意的是静态文件会被浏览器缓存,可以使用浏览器开发人员工具禁用缓存,或者手动删除浏览器缓存

标签:tomcat,idea

匠人匠心科技是专业从事天津网站建设、天津网站制作、软件开发、移动建站、商城、微信端、app开发项目
软件事业部:天津市大学软件学院D-510(天津工业大学院内)
网站事业部: 天津市河北区新大路通广科技园3-225
咨询热线:138-2142-0129 136-2215-0903
天津网站建设_天津建站

扫码添加微信