使用Cookie时出现点小问题:在eclipse中不能识别Cookie,提示信息为:Cookie Cannot be resolved to a type,怎么办呢:
1. 加载Cookie包
(1) 首先,尝试加载Cookie包语句:<%@ page import="javax.servlet.http.Cookie" %>问题并未解决,Cookie处仍然提示Cookie Cannot be resolved to a type,而且在Cookie包语句上提示:The import java.servlet cannot be resolved,这其实是软件包javax.servlet不存在,从tomcat中导入就可以了。
(2) 其次,右键项目-->Build Path-->Configure Build Path...,打开Properties for "项目名";
(3) 选择Libraries选项卡,选择Add Library...,打开Add Library对话框;
(4) 选择Server Runtime,单击Next按钮,再选择服务器(如Apache Tomcat v7.0),单击Finish按钮完成,并单击OK退出Properties for "项目名"对话框。
这时,才能够顺利编辑成功。
顺便,把常用的cookie读写方法总结一下:
2. 写Cookie与读Cookie
(1) 写Cookie:
<%
Cookie myCook = new Cookie("cookieName", "cookieContent");
myCook.setMaxAge(60*60*24*365); // 有效期一年
response.addCookie(myCook);
%>
(2) 读Cookie:
<%
Cookie cook = request.getCookies();
if(cook!=null)
{
for(int i=0; i<cook.length; i++)
{
if(cook[i].getName().equals("cookieName")) // getName方法得到cookie名称cookieName
{
String value = cook[i].getValue(); // getValue方法得到cookie的值cookieContent
}
}
}
%>
但是,还有一个小问题,当cookie里存的是中文的话就会出现问题,修改代码如下:
3. Cookie中存有中文时的读写
(1) 写Cookie
<%@page import="java.net.URLEncoder"%>
<%
Cookie myCook = new Cookie("cookieName", URLEncoder.encode("cookieContent","GB18030"));//对cookie对象进行编码
myCook.setMaxAge(60*60*24*365); // 有效期一年
response.addCookie(myCook);
%>
(2) 读Cookie
<%@page import="java.net.URLDecoder"%>
<%
Cookie cook = request.getCookies();
if(cook!=null)
{
for(int i=0; i<cook.length; i++)
{
if(cook[i].getName().equals("cookieName")) // getName方法得到cookie名称cookieName
{
String value = URLDecoder.decode(cook[i].getValue(),"GB18030"); // getValue方法得到cookie的值cookieContent,并且经过解码
}
}
}
%>
Cookie实现记忆用户名和密码功能的实现
1、登录页面
<body>
<h1>用户登录</h1>
<hr>
<%
request.setCharacterEncoding("utf-8");
String username="";
String password = "";
Cookie[] cookies = request.getCookies();
if(cookies!=null&&cookies.length>0)
{
for(Cookie c:cookies)
{
if(c.getName().equals("username"))
{
username = URLDecoder.decode(c.getValue(),"utf-8");
}
if(c.getName().equals("password"))
{
password = URLDecoder.decode(c.getValue(),"utf-8");
}
}
}
%>
<form name="loginForm" action="dologin.jsp" method="post">
<table>
<tr>
<td>用户名:</td>
<td><input type="text" name="username" value="<%=username %>"/></td>
</tr>
<tr>
<td>密码:</td>
<td><input type="password" name="password" value="<%=password %>" /></td>
</tr>
<tr>
<td colspan="2"><input type="checkbox" name="isUseCookie" checked="checked"/>十天内记住我的登录状态</td>
</tr>
<tr>
<td colspan="2" align="center"><input type="submit" value="登录"/><input type="reset" value="取消"/></td>
</tr>
</table>
</form>
</body>
2、登录处理页面
<%
request.setCharacterEncoding("utf-8");
//首先判断用户是否选择了记住登录状态
String[] isUseCookies = request.getParameterValues("isUseCookie");
if(isUseCookies!=null&&isUseCookies.length>0)
{
//把用户名和密码保存在Cookie对象里面
String username = URLEncoder.encode(request.getParameter("username"),"utf-8");
//使用URLEncoder解决无法在Cookie当中保存中文字符串问题
String password = URLEncoder.encode(request.getParameter("password"),"utf-8");
Cookie usernameCookie = new Cookie("username",username);
Cookie passwordCookie = new Cookie("password",password);
usernameCookie.setMaxAge(864000);
passwordCookie.setMaxAge(864000);//设置最大生存期限为10天
response.addCookie(usernameCookie);
response.addCookie(passwordCookie);
}
else
{
Cookie[] cookies = request.getCookies();
if(cookies!=null&&cookies.length>0)
{
for(Cookie c:cookies)
{
if(c.getName().equals("username")||c.getName().equals("password"))
{
c.setMaxAge(0); //设置Cookie失效
response.addCookie(c); //重新保存。
}
}
}
}
%>
3、获取Cookie对象页面
<%
request.setCharacterEncoding("utf-8");
String username="";
String password = "";
Cookie[] cookies = request.getCookies();
if(cookies!=null&&cookies.length>0)
{
for(Cookie c:cookies)
{
if(c.getName().equals("username"))
{
username = URLDecoder.decode(c.getValue(),"utf-8");
}
if(c.getName().equals("password"))
{
password = URLDecoder.decode(c.getValue(),"utf-8");
}
}
}
%>