Reader reader = new InputStreamReader(new FileInputStream("F:/WorkFolder/drools/drl/addpoint.drl"),"UTF-8");
System.setProperty("jxl.encoding", "UTF-8");
加上這兩個系統(tǒng)參數(shù),也是亂碼,經(jīng)過調(diào)試發(fā)現(xiàn),org.drools.rule.builder.dialect.java.JavaDialect類里面的addClassCompileTask方法有將字符超字節(jié)轉(zhuǎn)換的代碼,如下:
public void addClassCompileTask(final String className,
final BaseDescr descr,
final String text,
final MemoryResourceReader src,
final ErrorHandler handler) {
final String fileName = className.replace( '.',
'/' ) + ".java";
try {
if (src != null) {
src.add( fileName,
text.getBytes() );
} else {
this.src.add( fileName,
text.getBytes() );
}
} catch (final UnsupportedEncodingException e ) {
throw new RuntimeException("unable to encoding the rule!");
}
this.errorHandlers.put( fileName,
handler );
addClassName( fileName );
}
我們再來看一下String的getBytes方法的實現(xiàn),這個方法里面默認(rèn)取平臺的編碼的,至此,我們就知道病根了,所以比較簡單了,加上-Dfile.encoding=UTF8參數(shù)就可以了。注意,這個地方是UTF8,不是UTF-8,具體的解釋看官方文檔: http://docs.oracle.com/javase/6/docs/technotes/guides/intl/encoding.doc.html,最后這個也是在tomcat的啟動參數(shù)里面加上-Dfile.encoding=UTF8- 在tomcat的啟動
catalina.bat/
catalina.sh
參數(shù)里面加上-Dfile.encoding=UTF8
CATALINA_OPTS="-Xmx1024m -Xms1024m -XX:PermSize=256m -XX:MaxPermSize=512m -Xss128k -server -Xdebug -Xnoagent -Djav
a.compiler=NONE -Xrunjdwp:transport=dt_socket,server=y,suspend=n,address=8530 -Dfile.encoding=UTF8"
- 在maven跑junit測試的時候加上這個參數(shù)-Dfile.encoding=UTF-8
如果不加這個測試,在junit跑測試的時候還會使用操作系統(tǒng)的默認(rèn)字符集,會導(dǎo)致測試失敗:
<plugin> <artifactId>maven-surefire-plugin</artifactId>
<groupId>org.apache.maven.plugins</groupId>
<version>2.11</version>
<configuration>
<argLine>-Dfile.encoding=utf-8</argLine>
<parallel>methods</parallel>
<threadCount>10</threadCount>
<includes>
<include>**/*Test.java</include>
</includes>
<excludes>
<exclude>**/BaseControllerTest.java</exclude>
<exclude>**/BaseTest.java</exclude>
<exclude>**/TestUtils.java</exclude>
</excludes>
</configuration>
</plugin>
這里亂碼問題告一段落!