在通过js传递参数的时候,用这样的链接
window.location.href=encodeURI("wqd_materialadd_sale.jsp?action=add&id="+id+"&order_id="+order_id+"&component="+component+"&remark="+remark);
实际表单中component的值可能是:100%毛
不加encodeURI时,传递过去的是乱码,加上就对了
一、正常JSP加密方法
<%@ page contentType="text/html;charset=gb2312" %>
<%@ page import="java.io.*" %>
<%@ page import="java.util.*" %>
<%@ page import="java.net.*" %>
<a href="test2.jsp?url=<%=java.net.URLEncoder.encode("编码的 是这里","GB2312")%>">点击这里</a>
二、正常JSP解密方法
<%@ page contentType="text/html;charset=gb2312" %>
<%@ page import="java.io.*" %>
<%@ page import="java.util.*" %>
<%@ page import="java.net.*" %>
<%
//request.setCharacterEncoding("GBK");
if(request.getParameter("url")!=null )
{
String str=request.getParameter("url");
str=java.net.URLDecoder.decode(str,"GB2312");
//str=new String(str.getBytes("ISO-8859-1"));
out.print(str);
}
%>
三、那么这么样在前台用JS_encode加密在后台用JSPdecode解密呢
第一次我这样加密
window.open(url+"?keyword="+encodeURI(document.getElementById("keyword").value));
在后台
String keyword= java.net.URLDecoder.decode(request.getParameter("keyword"),"UTF-8");
没成功
第二次我用JS两次encodeURI就成功解密啦
window.open(url+"?keyword="+encodeURI(encodeURI(document.getElementById("keyword").value)));
记住:要想用JS实现jsp的java.net.URLEncoder.encode必须这样做encodeURI(encodeURI(str));