javaweb之Session完成用户登录

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>首页</title>
</head>

<body>
	<!-- ${user.username}取出session域中的user对象,显示它的username -->
	欢迎您:${user.username}
	<a href="/day07/login.jsp">登录</a>
	<a href="/day07/servlet/LogoutServlet">注销</a>
	<br />
	<br />
	<br />
</body>
</html>
package test.login;

import java.io.IOException;
import java.io.PrintWriter;
import java.util.ArrayList;
import java.util.List;

import javax.servlet.ServletException;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

//用户登陆servlet
public class LoginServlet extends HttpServlet {

	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		String username = request.getParameter("username");
		String password = request.getParameter("password");
		List<User> list = DB.getAll();
		for (User user : list) {
			// 如果用户登录成功
			if (user.getUsername().equals(username)
					&& user.getPassword().equals(password)) {
				HttpSession session = request.getSession();
				// 手动设置session的有效期为30分钟
				String sessionId = session.getId();
				Cookie cookie = new Cookie("JSESSIONID", sessionId);
				cookie.setMaxAge(60 * 30);
				cookie.setPath(request.getContextPath());
				response.addCookie(cookie);
				// 登录成功后要存入用户的登录状态,key是用户对象的String形式value就是用户对象(model)!!别的页面应该能用到
				session.setAttribute("user", user);
				// 重定向到首页,URL重写方式
				String url = response.encodeRedirectURL(request
						.getContextPath() + "/index.jsp");
				response.sendRedirect(url);
				return;
			}
		}

		response.setCharacterEncoding("UTF-8");
		response.setHeader("Content-type", "text/html;charset=UTF-8");
		PrintWriter out = response.getWriter();
		out.print("用户名或密码错误");
	}

	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		doGet(request, response);
	}

}

// 模拟存储用户的数据库
class DB {
	private static List<User> list = new ArrayList<User>();
	static {
		list.add(new User("aaa", "123"));
		list.add(new User("bbb", "123"));
		list.add(new User("ccc", "123"));
	}

	public static List<User> getAll() {
		return list;
	}
}

package test.login;

import java.io.IOException;
import java.io.PrintWriter;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

//注销servlet
public class LogoutServlet extends HttpServlet {

	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		response.setCharacterEncoding("UTF-8");
		response.setHeader("Content-type", "text/html;charset=UTF-8");
		PrintWriter out = response.getWriter();
		HttpSession session = request.getSession(false);
		if (session == null) {
			// 没登录,重定向到首页
			String url = response.encodeRedirectURL(request.getContextPath()
					+ "/index.jsp");
			response.sendRedirect(url);
			return;
		}
		// 从session中移除登录状态
		session.removeAttribute("user");
		// 重定向到首页,URL重写方式
		String url = response.encodeRedirectURL(request.getContextPath()
				+ "/index.jsp");
		response.sendRedirect(url);
	}

	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		doGet(request, response);
	}

}

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>用户登录</title>
</head>

<body>
	<form action="/day07/servlet/LoginServlet" method="post">
		用户名:<input type="text" name="username" /><br> 
		密码:<input type="password" name="password" /><br> 
		<input type="submit" value="登录" />
	</form>
</body>
</html>


  • 5
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
YOLO高分设计资源源码,详情请查看资源内容中使用说明 YOLO高分设计资源源码,详情请查看资源内容中使用说明 YOLO高分设计资源源码,详情请查看资源内容中使用说明 YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明
要实现用户注册登录页面,需要以下步骤: 1. 创建一个Java Web项目,例如使用Eclipse或IntelliJ IDEA等IDE工具,创建一个Dynamic Web Project。 2. 创建用户注册和登录的JSP页面,包括表单元素和提交按钮。 3. 创建一个Servlet来处理用户提交的表单数据,并将其存储到数据库中。可以使用JDBC或ORM框架如Hibernate等。 4. 创建一个Session来记录用户是否已经登录。如果用户已经登录,将其重定向到主页。 5. 创建一个验证码生成器,可以使用Java的awt包来生成图片验证码。当用户注册或登录时,要求用户输入正确的验证码。 6. 将生成的验证码图片显示在注册或登录页面上,以确保用户输入正确的验证码。 7. 创建一个过滤器,以确保只有通过身份验证的用户才能访问受保护的页面。 需要注意以下几个点: 1. 在处理用户输入时,要确保正确性和安全性。可以使用正则表达式或其他验证方法来验证用户输入。 2. 在处理密码时,要对其进行哈希处理,以确保密码不会被泄露。 3. 在处理验证码时,要确保用户输入的验证码与生成的验证码相匹配。可以使用Session来存储生成的验证码,并将其与用户输入进行比较。 4. 在创建过滤器时,要确保只有通过身份验证的用户才能访问受保护的页面。可以使用基于角色的访问控制(Role-Based Access Control)来实现此目的。 以上是实现用户注册登录页面的大致步骤,具体实现过程中需要根据具体情况进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值