解决办法是:应该使用-encoding参数指明编码方式:javac -encoding UTF-8 XX.java



获取系统默认编码:


System.out.println("Default Charset=" + Charset.defaultCharset());  
System.out.println("file.encoding=" + System.getProperty("file.encoding"));  
System.out.println("Default Charset in Use=" + FileTools.getDefaultCharSet());     
public static String getDefaultCharSet() {  
 OutputStreamWriter writer = new OutputStreamWriter(new ByteArrayOutputStream());  
 String enc = writer.getEncoding();  
 try
 {
    writer.close();
 } catch (IOException e)
 {
    e.printStackTrace();
  }
  return enc;  
 }


使用的时候最好是统一的格式,比如java文件保存格式也同样为 UTF-8 格式的

在命令行的中使用时先设置一个java变量

set JAVA_TOOL_OPTIONS=-Dfile.encoding=utf-8 -Duser.language=en -Duser.country=US

通过命令行对JAVA文件进行编译


javac -d ../ *.java


这样生成出来的.CLASS文件格式也同样为 UTF-8 编码的

同样在执行java或者jar包前,要设置一个临时的或者永久的变量

set JAVA_TOOL_OPTIONS=-Dfile.encoding=utf-8 -Duser.language=en -Duser.country=US




encodeURIComponent编码后java后台的解码


解决方法一:

JavaScript:
window.self.location="searchbytext.action?searchtext="+encodeURIComponent(encodeURIComponent(seartext));
java:
searchtext=java.net.URLDecoder.decode(searchtext,"UTF-8");
为什么要两次编码的原因:后台java代码给searchtext赋值的时候,本身已经使用了一次解码,不过解码的结果依然不对。所以我们可以在页面上进行两次编码操作,这样后台自动的那次就可以抵消掉一次,然后在使用searchtext=java.net.URLDecoder.decode(searchtext,"UTF-8");进行一次解码就好了。

解决方法二:
另外还有一种方法是JavaScript进行一次编码,后台java处理时换种想法就好了:
java代码:
String s = new String(request.getParameter("name").getBytes("ISO8859-1"), "UTF-8");


 


        js解码函数 escape,encodeURI,encodeURIComponent比较

js对文字进行编码涉及3个函数:escape,encodeURI,encodeURIComponent,相应3个解码函数:unescape,decodeURI,decodeURIComponent 1、   传递参数时需要使用encodeURIComponent,这样组合的url才不会被#等特殊字符截断。                            例如: 2、   进行url跳转时可以整体使用encodeURI 例如:Location.href=encodeURI("http://cang.baidu.com/do/s?word=百度&ct=21"); 3、   js使用数据时可以使用escape 例如:搜藏中history纪录。 4、   escape对0-255以外的unicode值进行编码时输出%u****格式,其它情况下escape,encodeURI,encodeURIComponent编码结果相同。 最多使用的应为encodeURIComponent,它是将中文、韩文等特殊字符转换成utf-8格式的url编码,所以如果给后台传递参数需要使用encodeURIComponent时需要后台解码对utf-8支持(form中的编码方式和当前页面编码方式相同) escape不编码字符有69个:*,+,-,.,/,@,_,0-9,a-z,A-Z encodeURI不编码字符有82个:!,#,$,&,',(,),*,+,,,-,.,/,:,;,=,?,@,_,~,0-9,a-z,A-Z encodeURIComponent不编码字符有71个:!, ',(,),*,-,.,_,~,0-9,a-z,A-Z