HTML页面的超链接中文乱码如何处置呢
在实际应用中,我们有时候会遇到“HTML页面的超链接中文乱码如何处理呢?”这样的问题,我们该怎样来处理呢?下文给大家介绍了解决方法,希望这篇“HTML页面的超链接中文乱码如何处理呢?”文章能帮助大家解决问题。 Vm中一个超链接URL需要拼接中文作为Get请求的参数。如果直接拼接,传到后台Action的参数对象中后取出会是乱码,需要编码后再拼接到URL上。 解决方法是在Action中添加一个成员变量,保存编码后的中文参数。在vm页面渲染时取出这个变量值,再拼接超链接。 在这里碰到的问题是:调用java.net.URLEncoder的encode()方法时,如果没有显示指定字符集参数,那么URLEncoder会使用默认字符集。这个默认字符集在Eclipse里跑main()方法和在Tomcat里跑Web应用,得到的结果不一样,所以影响了编码的结果。 代码如下: /** * Translates a string into x-www-form-urlencoded * format. This method uses the platform'sdefault encoding * as the encoding scheme to obtain thebytes for unsafe characters. * * @param s String to betranslated. * @deprecated The resulting string mayvary depending on the platform's * default encoding. Instead, use theencode(String,String) * method to specify the encoding. * @return the translated String. */ @Deprecated public static String encode(String s) { String str = null; try { str = encode(s, dfltEncName); } catch(UnsupportedEncodingException e) { // The system should always have theplatform default } return str; 方法的注释中也说明了不建议使用的原因是,这个encode(String)方法依赖于平台字符集。 (编辑:银川站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |