URLEnprer应该是要走的路。你只需要记住只对单个查询字符串参数名称和/或值进行编码,而不对整个URL 进行编码,请确保对查询字符串参数分隔符
&和参数名称-值分隔符都不进行编码
=。
String q = "random word £500 bank $";String url = "http://example.com/query?q=" + URLEnprer.enpre(q, "UTF-8");
请注意,查询参数中的空格由+而不是表示
%20,这是合法有效的。在
%20通常被用于表示URI本身(URI查询字符串分隔符之前的部分的空间
?),而不是在查询字符串(之后的部分
?)。
另请注意,有两种
enpre()方法。一个不带
charset参数,另一个不带
charset参数。不带
charset参数的参数已弃用。从不使用它,并且始终指定
charset参数。在
javadoc中甚至明确建议使用UTF-8编码,通过的授权
RFC3986和
W3C。
所有其他字符都是不安全的,并且首先使用某种编码方案转换为一个或多个字节。然后,每个字节由3个字符的字符串“%xy”表示,其中xy是该字节的两位十六进制表示形式。建议使用的编码方案是UTF-8。但是,出于兼容性原因,如果未指定编码,则使用平台的默认编码。



