今天学了HttpCookie 之后,本来想试试自己的程度,写一个用cookie 记住用户名的简单页面。
form写在jsp中咯, 然后请求发送给servlet 咯,
servlet代码:
一、要获取POST过来的参数
String username = request.getParameter("username");
String isCheck = request.getParameter("remember");
二、创建Cookie
Cookie cookie = new Cookie("username",username);
三、判断是否选中(记住用户名)
if(isCheck != null && isCheck != ""){
这里要设置cookie 的生命周期为一周
cookie.setMaxAge(60*60*24*7);
}
else{
设置cookie的生命周期为关闭浏览器即消失
cookie.setMaxAge(0);
}
四、将cookie添加到响应
response.addCookie(cookie);
五、输出一个超链接用于转到jsp页面 这里要设置编码
response.setContentType("text/html;charset=utf-8");
response.getWriter().write("<a href='/Project/index.jsp' >返回</a>");
至此 servlet代码写完了(其实还有).
jsp代码:
用户名:<input type="text" value="${cookie.username.value}" />
<br />
<input type="checkbox" ${(cookie.username!=null)?"checked":""} />
<br />
<input type="submit" value="提交" />
以上代码写完了,运行输入 tom 提交之后,返回 , 没错,,,。可我输入中文之后 错误 500 了。
这就用到了之前学的Base64编码与解码了。
编码,修改servlet代码:
第二步的
Cookie cookie = new Cookie("username",username);
为
Cookie cookie = new Cookie("username",new BASE64Encoder().encode(username));
解码,修改jsp代码:
添加
<%
Cookie[] cookies = resquest.getCookies();
for(Cookie cookie:cookies){
if(cookie.getName().equals("username")){
byte[] bytes = new BASE64Decoder.decodeBuffer(cookie.getValue);
String username = new String(bytes);
}
}
%>
修改:
用户名:<input type="text" value="<%=username %>" />
<br />
<input type="checkbox" ${(cookie.username!=null)?"checked":""} />
<br />
<input type="submit" value="提交" />
****然后修改之后没有用呀,还tm 是一堆?????? ,怎么弄也是??????? , 然后百度, 也没有相关解决问题,
我通过抓包获取信息 ,发现Cookie 的username 键总是对应着 Pz8/Pz8/ , 我找了个Base64解码工具,将Pz8/解码 得出?
(PS:我是不是傻0.0) 我捣腾了2小时,才tm发现原来是忘了改request.setCharacterEncoding("UTF-8"); 这句。
错在了根上,我却找其他的地方的原因,我还以为是Base64不对-.-! 反正问题解决了,让我几年之内忘不了了,
不说了,都0点多了,1024程序员日,要不要这么2.。。。可是10次方啊!
~~~~安。
form写在jsp中咯, 然后请求发送给servlet 咯,
servlet代码:
一、要获取POST过来的参数
String username = request.getParameter("username");
String isCheck = request.getParameter("remember");
二、创建Cookie
Cookie cookie = new Cookie("username",username);
三、判断是否选中(记住用户名)
if(isCheck != null && isCheck != ""){
这里要设置cookie 的生命周期为一周
cookie.setMaxAge(60*60*24*7);
}
else{
设置cookie的生命周期为关闭浏览器即消失
cookie.setMaxAge(0);
}
四、将cookie添加到响应
response.addCookie(cookie);
五、输出一个超链接用于转到jsp页面 这里要设置编码
response.setContentType("text/html;charset=utf-8");
response.getWriter().write("<a href='/Project/index.jsp' >返回</a>");
至此 servlet代码写完了(其实还有).
jsp代码:
用户名:<input type="text" value="${cookie.username.value}" />
<br />
<input type="checkbox" ${(cookie.username!=null)?"checked":""} />
<br />
<input type="submit" value="提交" />
以上代码写完了,运行输入 tom 提交之后,返回 , 没错,,,。可我输入中文之后 错误 500 了。
这就用到了之前学的Base64编码与解码了。
编码,修改servlet代码:
第二步的
Cookie cookie = new Cookie("username",username);
为
Cookie cookie = new Cookie("username",new BASE64Encoder().encode(username));
解码,修改jsp代码:
添加
<%
Cookie[] cookies = resquest.getCookies();
for(Cookie cookie:cookies){
if(cookie.getName().equals("username")){
byte[] bytes = new BASE64Decoder.decodeBuffer(cookie.getValue);
String username = new String(bytes);
}
}
%>
修改:
用户名:<input type="text" value="<%=username %>" />
<br />
<input type="checkbox" ${(cookie.username!=null)?"checked":""} />
<br />
<input type="submit" value="提交" />
****然后修改之后没有用呀,还tm 是一堆?????? ,怎么弄也是??????? , 然后百度, 也没有相关解决问题,
我通过抓包获取信息 ,发现Cookie 的username 键总是对应着 Pz8/Pz8/ , 我找了个Base64解码工具,将Pz8/解码 得出?
(PS:我是不是傻0.0) 我捣腾了2小时,才tm发现原来是忘了改request.setCharacterEncoding("UTF-8"); 这句。
错在了根上,我却找其他的地方的原因,我还以为是Base64不对-.-! 反正问题解决了,让我几年之内忘不了了,
不说了,都0点多了,1024程序员日,要不要这么2.。。。可是10次方啊!
~~~~安。