方式一
在Maven的pom.xml文件中增加如下代码:
<properties>
<argLine>-Dfile.encoding=UTF-8</argLine>
</properties>
方式二
引入 maven-surefire-plugin,并设置编码方式:
<build>
<plugins>
<!-- 解决maven test命令时console出现中文乱码乱码 -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<version>2.7.2</version>
<configuration>
<forkMode>once</forkMode>
<argLine>-Dfile.encoding=UTF-8</argLine>
</configuration>
</plugin>
</plugins>
</build>
-Dfile.encoding=utf-8到底是设置什么,有什么含义与作用?
程序运行源代码历经处理阶段
一份代码到运行得到正确输出,经过步骤:
Java源代码----Javac编译成class字节码文件----Java虚拟机JVM加载运行—操作系统----显示设备。
Java源码—字节码:调用jdk的javac命令执行编译,javac默认采用系统字符集。通常我们会设置文件编码UTF-8。使用命令编译也可以加上-encoding UTF-8;
System.getProperty(“file.encoding”) //可以获取当前系统使用的编码字符集
content.getBytes(System.getProperty(“file.encoding”)),“GBK”) 通过当前字符集转码
Java字节码—虚拟机—操作系统:虚拟机启动的时候以什么字符集编码来解析我们的class字节码文件呢?这时候我们就通常会设置 -Dfile.encoding=utf-8. Dfile=decode file. 这里也就解释了设置这个VM参数的意义了。
操作系统—显示设备:针对编码阶段出现的中文,在这一步骤就需要操作系统安装中文字体以支持中文。
maven-surefire-plugin简介
Maven本身并不是一个单元测试框架,Java世界中主流的单元测试框架为JUnit和TestNG。Maven所做的只是在构建执行到特定生命周期阶段的时候,通过插件来执行JUnit或者TestNG的测试用例。这一插件就是maven-surefire-plugin,可以称之为测试运行器(Test Runner),他能很好的兼容JUnit 3、JUnit 4以及TestNG。
我们知道,生命周期阶段需要绑定到某个插件的目标才能完成真正的工作,test阶段正是与maven-surefire-plugin的test目标相绑定了,这是一个内置的绑定。
在默认情况下,maven-surefire-plugin的test目标会自动执行测试源码路径(默认为src/test/java/)下所有符合一组命名模式的测试类。这组模式为:
**/Test*.java:任何子目录所有命名以Test开头的Java类。
**/*Test.java:任何子目录下所有命名以Test结尾的Java类。
**/*TestCase.java:任何子目录下所有命名以TestCase结尾的Java类。
只要将测试类按上述模式命名,Maven就能自动运行他们,用户也就不再需要定义测试集合(TestSuite)来聚合测试用例(TestCase)。关于模式需要注意的是,以Test结尾的测试类是不会得以自动执行的。
当然,如果有需要,可以自己定义要运行测试类的模式。此外,maven-surefire-plugin还支持更高级的TestNG测试集合xml文件。
当然,为了能够运行测试,Maven需要在项目中引入测试框架的依赖。