目标:完成用户注册和登录功能 要求: 1:)用户访问/hello(HelloServlet)的时候,判断用户的登录状态,如果已经登录,通过servlet中的重定向功能,跳转到hello.jsp页面,显示“用户名”欢迎您,如“张三欢迎您!”;如果用户未登录,请跳转到“login.jsp”让用户登录。 2)在login.jsp页面中允许用户输入账号密码(只有账号密码两个字段),点击登录后,将表单数据发送到/login(LoginServlet),在LoginServlet中判断用户输入的账号密码是否正确,如果正确跳转到hello.jsp页面;如果错误,跳转到login.jsp页面,并在页面中显示登录错误的原因,如“账号错误/密码错误”。 3)login.jsp登录页面包含“注册”链接,允许用户进行注册操作,当用户点击注册链接时,跳转到register.jsp页面。 3)register.jsp页面中,用户注册时只需要填写账号和密码两个字段,将注册信息提交到/register(RegisterServlet),如果用户输入的账号密码为空或者填写账号已经存在,跳转回register.jsp页面,并显示错误提示;如果账号密码不为空并且账号不存在,将用户的账号名和密码存入到list中,将账号名放入session存储,页面跳转到success.jsp页面,显示注册成功,3秒钟后自动跳转到登录页面。 4)请在程序编写过程中,创建UserBean,用于存储user信息。
时间: 2023-07-16 10:13:18 浏览: 582
好的,我来给你讲一下如何完成这个目标。
首先,我们需要创建一个UserBean类,用于存储用户信息:
```java
public class UserBean {
private String username;
private String password;
public UserBean(String username, String password) {
this.username = username;
this.password = password;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
}
```
接下来,我们需要创建一个数据库类,用于存储用户信息:
```java
public class UserDatabase {
private static List<UserBean> userList = new ArrayList<>();
public static boolean addUser(String username, String password) {
for (UserBean user : userList) {
if (user.getUsername().equals(username)) {
return false;
}
}
userList.add(new UserBean(username, password));
return true;
}
public static boolean checkUser(String username, String password) {
for (UserBean user : userList) {
if (user.getUsername().equals(username) && user.getPassword().equals(password)) {
return true;
}
}
return false;
}
}
```
在这个数据库类中,我们使用了一个静态的List来存储用户信息。addUser方法用于添加用户信息,如果用户名已经存在,则返回false;如果添加成功,则返回true。checkUser方法用于检查用户名和密码是否正确,如果正确则返回true,否则返回false。
现在,我们可以开始编写Servlet了。首先是HelloServlet:
```java
@WebServlet("/hello")
public class HelloServlet extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
HttpSession session = request.getSession();
String username = (String) session.getAttribute("username");
if (username != null) {
response.sendRedirect("hello.jsp");
} else {
response.sendRedirect("login.jsp");
}
}
}
```
在这个Servlet中,我们首先获取session中的用户名信息,如果用户名存在,则重定向到hello.jsp页面;否则,重定向到login.jsp页面。
接下来是LoginServlet:
```java
@WebServlet("/login")
public class LoginServlet extends HttpServlet {
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String username = request.getParameter("username");
String password = request.getParameter("password");
if (UserDatabase.checkUser(username, password)) {
HttpSession session = request.getSession();
session.setAttribute("username", username);
response.sendRedirect("hello.jsp");
} else {
request.setAttribute("error", "账号或密码错误");
request.getRequestDispatcher("login.jsp").forward(request, response);
}
}
}
```
在这个Servlet中,我们首先获取用户输入的用户名和密码,然后调用UserDatabase的checkUser方法检查用户名和密码是否正确。如果正确,则将用户名存入session中,并重定向到hello.jsp页面;否则,将错误信息存入request中,并转发到login.jsp页面。
最后是RegisterServlet:
```java
@WebServlet("/register")
public class RegisterServlet extends HttpServlet {
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String username = request.getParameter("username");
String password = request.getParameter("password");
if (username == null || username.equals("") || password == null || password.equals("")) {
request.setAttribute("error", "账号或密码不能为空");
request.getRequestDispatcher("register.jsp").forward(request, response);
} else if (!UserDatabase.addUser(username, password)) {
request.setAttribute("error", "账号已存在");
request.getRequestDispatcher("register.jsp").forward(request, response);
} else {
request.setAttribute("message", "注册成功,3秒钟后自动跳转到登录页面");
response.setHeader("refresh", "3;url=login.jsp");
HttpSession session = request.getSession();
session.setAttribute("username", username);
request.getRequestDispatcher("success.jsp").forward(request, response);
}
}
}
```
在这个Servlet中,我们首先获取用户输入的用户名和密码,然后调用UserDatabase的addUser方法添加用户信息。如果添加失败,则说明用户名已经存在,将错误信息存入request中,并转发到register.jsp页面。如果添加成功,则将用户名存入session中,并重定向到success.jsp页面,该页面将在3秒钟后自动跳转到登录页面。
现在,我们已经完成了用户注册和登录功能。接下来,我们需要编写login.jsp、register.jsp和hello.jsp页面。
首先是login.jsp:
```html
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Login</title>
</head>
<body>
<h1>Login</h1>
<% String error = (String) request.getAttribute("error"); %>
<% if (error != null) { %>
<p style="color: red;"><%= error %></p>
<% } %>
<form action="login" method="post">
<p>
<label>账号:</label>
<input type="text" name="username">
</p>
<p>
<label>密码:</label>
<input type="password" name="password">
</p>
<p>
<input type="submit" value="登录">
</p>
</form>
<p>还没有账号?<a href="register.jsp">注册</a></p>
</body>
</html>
```
在这个页面中,我们使用了JSP的EL表达式来获取request中的错误信息,并在页面上显示。同时,我们也添加了一个“注册”链接,用于跳转到register.jsp页面。
接下来是register.jsp:
```html
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Register</title>
</head>
<body>
<h1>Register</h1>
<% String error = (String) request.getAttribute("error"); %>
<% if (error != null) { %>
<p style="color: red;"><%= error %></p>
<% } %>
<form action="register" method="post">
<p>
<label>账号:</label>
<input type="text" name="username">
</p>
<p>
<label>密码:</label>
<input type="password" name="password">
</p>
<p>
<input type="submit" value="注册">
</p>
</form>
<p>已有账号?<a href="login.jsp">登录</a></p>
</body>
</html>
```
在这个页面中,我们同样使用了JSP的EL表达式来获取request中的错误信息,并在页面上显示。同时,我们也添加了一个“登录”链接,用于跳转到login.jsp页面。
最后是hello.jsp:
```html
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Hello</title>
</head>
<body>
<h1>Hello</h1>
<% String username = (String) session.getAttribute("username"); %>
<p><%= username %>欢迎您!</p>
</body>
</html>
```
在这个页面中,我们使用了JSP的EL表达式来获取session中的用户名信息,并在页面上显示。
现在,我们已经完成了用户注册和登录功能。将以上代码保存为相应的Java文件和JSP文件,并部署到Tomcat服务器上即可。
阅读全文