Maven编译项目下的.java文件时的编码问题

《编译.java文件时的编码问题》可知,在编译.java文件的时候,需要正确指定一个编码方案,该编码方案用于解码.java文件的字节流。
那么在使用Maven编译项目下所有的.java文件时,该如何指定正确的编码方案呢?
1)首先在Maven项目下执行"mvn help:effective-pom"命令。可以在得到的实际的POM文件中,发现默认情况下,用来编译Maven项目下的.java文件的工具是"maven-compiler-plugin"插件,其下有个"encoding"配置参数,该值就是用来指定编译.java文件过程中应该使用的编码方案的。该配置参数的值默认为"${project.build.sourceEncoding}",如果"${project.build.sourceEncoding}"没有配置,那么使用"platform encoding"
2)假如现在有个项目,使用Maven进行管理,项目下.java文件使用的编码方案是GBK,未设置"${project.build.sourceEncoding}",且"platform encoding=utf8",那么默认情况下,"maven-compiler-plugin"插件下的"encoding"配置参数的值被取为utf8,使用该"encoding"参数值去编译项目会得到错误的.class文件,在这种情况下,我们应该明确指定"encoding=gbk"。
即便项目使用UTF-8编码,"encoding"参数值默认也被取为utf8,使用该"encoding"参数值去编译项目能够得到正确的.class文件,但是"encoding"参数是非常重要的一个参数,我们最好能够明确定义它


综上所述,我们应该明确定义"encoding"参数值,详细的定义方式见《Maven中配置maven-compiler-plugin插件》


参考文献:
[1]http://maven.apache.org/plugins/maven-compiler-plugin/compile-mojo.html
发布了251 篇原创文章 · 获赞 86 · 访问量 87万+
展开阅读全文

Maven 项目UTF-8编码问题

11-19

我在我电脑上的G:\AdobeCQ路径下面有两个相同的项目: BMWPDF PDFGeneration ![图片说明](https://img-ask.csdn.net/upload/201511/19/1447909321_791529.png) 以前我在BMWPDF项目中的POM.xml文件里面加了以下的语句: ``` <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> <maven.compiler.encoding>UTF-8</maven.compiler.encoding> ``` 并且将这个项目Text file encoding 改为了UTF-8。做这个两个操作的目的是为了让这个项目能够支持在代码中写入中文字符。后来这样编译并没有什么问题,而且中文也能够顺利的输出到相对应的PDF中。 可是,昨天晚上大概11点半左右,我发现打开eclipse的时候出现了错误,提示“error shows in .metadata/.log”。项目打不开,我只好把.metadata文件删掉之后,重新打开eclipse,导入项目之后,用maven进行编译,出现以下的错误: [ERROR] Failed to execute goal org.apache.felix:maven-scr-plugin:1.7.4:scr (generate-scr-descriptor) on project bmwpdf-bundle: Execution generate-scr-descriptor of goal org.apache.felix:maven-scr-plugin:1.7.4:scr failed: syntax error @[861,2] in file:/G:/AdobeCQ/bmwpdf/bundle/src/main/java/com/bmw/pdf/generator/GeneratorProcess.java -> [Help 1] 看了具体的错误信息,我有点懵了。因为提示的错误文件中根本没有861行,最多859行。后来具体的去看错误信息,知道是因为这个文件存在中文引起的,但是我又不能讲中文去掉。于是,我只能想着碰运气,重新创建了一个项目PDFGeneration,代码一样,POM文件也是一样的。但是并没有改动项目配置中的Text file encoding,默认是GBK,这个时候,中文乱码,于是,我直接拷贝这些含有中文的文件内容到对应的新项目中。保存,编译,没有错误。运行包之后,只要是在代码中出现的中文字符,全部乱码。于是,我将Text file encoding改为UTF-8。编译之后同原来的项目一样,出现以下错误: [ERROR] Failed to execute goal org.apache.felix:maven-scr-plugin:1.7.4:scr (generate-scr-descriptor) on project bmwpdf-bundle: Execution generate-scr-descriptor of goal org.apache.felix:maven-scr-plugin:1.7.4:scr failed: syntax error @[861,2] in file:/G:/AdobeCQ/bmwpdf/bundle/src/main/java/com/bmw/pdf/generator/GeneratorProcess.java -> [Help 1] 于是我试着将POM文件中的以下内容去掉: ``` <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> <maven.compiler.encoding>UTF-8</maven.compiler.encoding> ``` 并将Text file encoding改为GBK。保存,编译,运行,中文正常出现。 以上总结一下就是项目编码的问题导致的,最后改为默认的编码解决了。具体问题是代码中出现了中文字符,如何让这些中文字符输出到PDF中不出现乱码,就出现了要将项目配置中的编译POM文件进行相应的编码改动措施,然并卵,后来又改回去了。只是奇怪的是第一个项目做了两个月左右,一直没出错,从昨天开始就奇怪的出现因为编码出现的问题。 说实话,这个项目的编码问题花了我不少的时间,但终究还是没有弄得太懂,有的时候只能是凭着感觉去具体的解决问题。哎,这种感觉真是不爽。花时间去弄懂这个问题吧,其他的事情又是一大堆;不花时间吧,以后可能又是同样的问题。这也许就是程序员的无奈。 问答

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 大白 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览