javaWeb的session和cookie实现记住密码自动登录功能简单实例
2017-06-04 19:58
1246 查看
关键代码:
jsp:
<form action="${ pageContext.request.contextPath }/UserServlet" method="post">
${msg}
用户名<input type="text" id="username" name="username" />
密码<input type="password" id="password" name="password" />
记住密码<input type="checkbox" name="auto_login" value="true">
<input type="submit" value="提交">
</form>
servlet:
Map<String, String[]> map = request.getParameterMap();
User user=new User();
BeanUtils.populate(user, map);
UserService us=new UserService();
User uu = us.logu(user);
if(uu !=null){
String auto_login = request.getParameter("auto_login");
if("true".equals(auto_login)){
Cookie cookie=new Cookie("auto_login", uu.getUsername()+"#"+uu.getPassword());
cookie.setPath(this.getServletContext().getContextPath());
cookie.setMaxAge(60*60*24*7);
response.addCookie(cookie);
}
request.getSession().setAttribute("exitUser", uu);
response.sendRedirect(this.getServletContext().getContextPath()+"/demo04login/show.jsp");
}else{
request.setCharacterEncoding("utf-8");
request.getSession().setAttribute("msg", "登录失败");
request.getRequestDispatcher("/demo04login/login.jsp").forward(request, response);
}
Filter:
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
HttpServletRequest req=(HttpServletRequest) request;
HttpSession session = req.getSession();
Object exitUser = session.getAttribute("exitUser");
//判断session中用户是否存在
if(exitUser!=null){
chain.doFilter(request, response);
}else{
//判断cookie是否存在
Cookie[] cookies = req.getCookies();
Cookie findCookie = CookieUtils.findCookie(cookies, "auto_login");
if(findCookie==null){
chain.doFilter(request, response);
}else{
//查找数据库匹配账号密码
String auto_login = findCookie.getValue();
String[] split = auto_login.split("#");
User user=new User();
user.setUsername(split[0]);
user.setPassword(split[1]);
UserService us=new UserService();
try {
User uu = us.logu(user);
if(uu==null){
chain.doFilter(request, response);
}else{
session.setAttribute("exitUser", uu);
chain.doFilter(request, response);
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
jsp:
<form action="${ pageContext.request.contextPath }/UserServlet" method="post">
${msg}
用户名<input type="text" id="username" name="username" />
密码<input type="password" id="password" name="password" />
记住密码<input type="checkbox" name="auto_login" value="true">
<input type="submit" value="提交">
</form>
servlet:
Map<String, String[]> map = request.getParameterMap();
User user=new User();
BeanUtils.populate(user, map);
UserService us=new UserService();
User uu = us.logu(user);
if(uu !=null){
String auto_login = request.getParameter("auto_login");
if("true".equals(auto_login)){
Cookie cookie=new Cookie("auto_login", uu.getUsername()+"#"+uu.getPassword());
cookie.setPath(this.getServletContext().getContextPath());
cookie.setMaxAge(60*60*24*7);
response.addCookie(cookie);
}
request.getSession().setAttribute("exitUser", uu);
response.sendRedirect(this.getServletContext().getContextPath()+"/demo04login/show.jsp");
}else{
request.setCharacterEncoding("utf-8");
request.getSession().setAttribute("msg", "登录失败");
request.getRequestDispatcher("/demo04login/login.jsp").forward(request, response);
}
Filter:
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
HttpServletRequest req=(HttpServletRequest) request;
HttpSession session = req.getSession();
Object exitUser = session.getAttribute("exitUser");
//判断session中用户是否存在
if(exitUser!=null){
chain.doFilter(request, response);
}else{
//判断cookie是否存在
Cookie[] cookies = req.getCookies();
Cookie findCookie = CookieUtils.findCookie(cookies, "auto_login");
if(findCookie==null){
chain.doFilter(request, response);
}else{
//查找数据库匹配账号密码
String auto_login = findCookie.getValue();
String[] split = auto_login.split("#");
User user=new User();
user.setUsername(split[0]);
user.setPassword(split[1]);
UserService us=new UserService();
try {
User uu = us.logu(user);
if(uu==null){
chain.doFilter(request, response);
}else{
session.setAttribute("exitUser", uu);
chain.doFilter(request, response);
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
相关文章推荐
- JavaWeb学习记录总结(二十九)--Servlet\Session\Cookie\Filter实现自动登录和记住密码
- cookie、session及实现记住密码,自动登录
- 登录时简单的记住密码和自动登录功能实现
- cookie、session及实现记住密码,自动登录
- cookie、session及实现记住密码,自动登录
- cookie、session及实现记住密码,自动登录
- cookie、session及实现记住密码,自动登录
- [Java开发] cookie、session及实现记住密码,自动登录思路
- 登录时记住密码——Filter、Cookie和Session的简单应用
- Android——SharedPreferences实现登录界面的记住密码和自动登录功能
- (转)业务系统实现记住密码和自动登录功能
- 引用借以记录借鉴 实现记住密码和自动登录功能
- C#如何实现记住密码,自动登录功能?【转载】
- session、cookie与“记住我的登录状态”的功能的实现
- JQuery记住用户名密码实现下次自动登录功能
- session、cookie与“记住我的登录状态”的功能的实现
- 记住密码,自动登录功能实现
- session、cookie与“记住我的登录状态”的功能的实现
- Flex中如何实现类似像QQ登录框中那种“记住密码”、“自动登录”功能,还有如何实现文本框中记录最后一次输入的值?
- 自动登录,记住密码功能实现