Example: “蘋果君华”几个字。
一开始使用的是php urlencode,然后java urldecode,“蘋”字亂碼。
后改用PHP base64_encode,再使用java decode(使用的org.apache.commons.codec.binary.Base64包),”蘋”字OK了,但“君华”倆字亂碼了。
search說是java使用的是非標準的base64解碼,so…求破。
回复内容:
Example: “蘋果君华”几个字。
一开始使用的是php urlencode,然后java urldecode,“蘋”字亂碼。
后改用PHP base64_encode,再使用java decode(使用的org.apache.commons.codec.binary.Base64包),”蘋”字OK了,但“君华”倆字亂碼了。
search說是java使用的是非標準的base64解碼,so…求破。
会乱码的原因是你的编码不一致导致的
php中的urlencode的编码是和系统编码一致的(比如windows默认gb2312,ubuntu默认utf-8)
所以首先需要确定你的系统编码,之后根据得到的系统编码在调用java的decode方法的时候,将这个编码传入(考虑到你的例子中有繁体字,所以,建议你使用utf-8编码),以下是我使用utf-8编码的例子(php环境是ubuntun下)
<code class="lang-php"><?php echo urlencode("蘋果君华");?></code>
output: %E8%98%8B%E6%9E%9C%E5%1本文来#源gaodai$ma#com搞$代*码*网
搞代gaodaima码
90%9B%E5%8D%8E
<code class="lang-java"> String ret = java.net.URLDecoder.decode("%E8%98%8B%E6%9E%9C%E5%90%9B%E5%8D%8E", "utf-8"); System.out.println(ret);</code>
output: 蘋果君华