JSP设计一个用户登录页面,用户可以输入用户名和密码,让用户选择“是否保存登录状态”,如果账号和密码相符,则登录成功,进入欢迎页面,否则不跳转并显示“登录错误”的信息。在登录时,如果保存了登录状态,下次登录时若访问登录页面则进入欢迎页面,如果用户没有经过登录就访问欢迎页面,则跳转到登录页面
时间: 2023-09-28 14:11:58 浏览: 432
首先,我们需要创建一个 JSP 页面来实现用户登录的功能。以下是一个简单的示例:
```jsp
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>用户登录</title>
</head>
<body>
<h1>用户登录</h1>
<form action="login.jsp" method="post">
用户名:<input type="text" name="username"><br>
密码:<input type="password" name="password"><br>
是否保存登录状态:<input type="checkbox" name="remember" value="1"><br>
<input type="submit" value="登录">
</form>
</body>
</html>
```
在该页面中,我们使用了一个表单来获取用户输入的用户名和密码,并添加了一个复选框来让用户选择是否保存登录状态。表单的提交地址为 `login.jsp`。
接下来,我们需要创建 `login.jsp` 页面来处理用户提交的表单数据,并根据用户输入的信息来判断登录是否成功。以下是一个实现该功能的示例:
```jsp
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%
// 获取用户提交的表单数据
String username = request.getParameter("username");
String password = request.getParameter("password");
String remember = request.getParameter("remember");
// 判断用户名和密码是否正确
if (username != null && password != null && username.equals("admin") && password.equals("123456")) {
// 登录成功
session.setAttribute("username", username);
if (remember != null && remember.equals("1")) {
// 如果用户选择了保存登录状态,则设置一个 Cookie,以便下次自动登录
Cookie cookie = new Cookie("username", username);
cookie.setMaxAge(60 * 60 * 24 * 7);
response.addCookie(cookie);
}
response.sendRedirect("welcome.jsp");
} else {
// 登录失败
out.println("登录错误!");
}
%>
```
在该页面中,我们首先使用 `request.getParameter()` 方法获取用户提交的表单数据,然后判断用户名和密码是否正确。如果登录成功,则将用户名存储到会话中,并根据用户是否选择了保存登录状态来设置一个 Cookie,以便下次自动登录。最后,使用 `response.sendRedirect()` 方法将用户重定向到欢迎页面。如果登录失败,则向页面输出一个错误信息。
最后,我们需要创建一个欢迎页面(例如 `welcome.jsp`),并在该页面中检查用户是否已经登录。如果用户没有登录,则将其重定向到登录页面。以下是一个实现该功能的示例:
```jsp
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%
// 检查用户是否已经登录
String username = (String) session.getAttribute("username");
if (username == null) {
// 如果用户没有登录,则重定向到登录页面
response.sendRedirect("login.jsp");
} else {
// 用户已经登录,显示欢迎信息
out.println("欢迎您," + username + "!");
}
%>
```
在该页面中,我们首先使用 `session.getAttribute()` 方法获取存储在会话中的用户名。如果用户名为 `null`,则说明用户没有登录,此时使用 `response.sendRedirect()` 方法将其重定向到登录页面。否则,说明用户已经登录,此时向页面输出一个欢迎信息。