一、问题描述
写了个Listener,并实现了ServletContextListener,重写contextInitialized()和contextDestroyed()方法来监听服务的启动和关闭,代码如下:
public class MyListener implements ServletContextListener {
@Override
public void contextInitialized(ServletContextEvent servletContextEvent) {
//servletContextEvent.
System.out.println("启动");
}
@Override
public void contextDestroyed(ServletContextEvent servletContextEvent) {
System.out.println("关闭");
}
}
启动服务时控制台却输出了乱码,如下:
![](https://i-blog.csdnimg.cn/blog_migrate/5c29e7267fb29c80f10fd5d5bc3d5d9a.png)
由于是maven项目,想着重新编译一下,没想到编译时就有问题,如下:
![](https://i-blog.csdnimg.cn/blog_migrate/e847e97754ffdc263c70a5cb7f281b7d.png)
二、原来如此
需要在maven的编译插件中声明正确的字符集,保证编译使用的字符集编码与保存代码文件时使用的字符集编码一致。
Windows中文系统默认的字符集是GBK,安装的软件一般会使用操作系统的默认字符集,比如用maven编译项目时,maven默认使用GBK字符集,而代码源文件采用UTF-8字符集,才会出现上图所示的问题,分析了问题出现的原因,下面就好解决了,一般代码源文件都采用UTF-8编码,所以就从“修改maven”着手,而“修改maven”体现在修改pom文件上,可以用如下两种办法修改pom文件来告诉maven用UTF-8编码编译项目。
方式一,在pom文件中添加:
<!--maven编译的时候默认使用的GBK编码, 通过project.build.sourceEncoding属性设置字符编码,通知maven使用UTF-8编译项目 -->
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
方式二,在plugins标签下为maven-compiler-plugin配置编码方式为UTF-8
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.3</version>
<configuration>
<source>1.7</source>
<target>1.7</target>
<!--maven编译的时候默认使用的GBK编码, 通过project.build.sourceEncoding属性设置字符编码,通知maven使用UTF-8编译项目 -->
<encoding>UTF-8</encoding>
</configuration>
</plugin>
以上两种方式任选其一即可。