JSP+Servlet+JavaBean模式+实现登录注册

一、模式分析

在这里插入图片描述

二、架构设计

在这里插入图片描述

三、代码框架

在这里插入图片描述
在这里插入图片描述

四、数据库设置

在这里插入图片描述

五、核心代码

1.User.java

public class User {
	private String username;
	private String 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;
	}
	
}

2.UserDAO.java

public class UserDAO {
	public static final String DRIVER = "com.mysql.cj.jdbc.Driver";
	public static final String DBURL = "jdbc:mysql://localhost:3306/mydb?serverTimezone=UTC";//在这里将3306改为自己的数据库端口号
	public static final String DBUSER = "root";//在这里更改为自己数据库的用户名
	public static final String DBPASS = "123456";//在这里更改为自己数据库的密码
	private Connection conn = null;
	private PreparedStatement pStat = null;
	private ResultSet rs = null;

	public Connection getConnectionn() {
		try {
			Class.forName(DRIVER);
			return DriverManager.getConnection(DBURL, DBUSER, DBPASS);
		} catch (Exception e) {
			return null;
		}
	}

	public void close() {
		try {
			if (rs != null)
				rs.close();
			if (pStat != null)
				pStat.close();
			if (conn != null)
				conn.close();
		} catch (Exception e) {
			e.printStackTrace();
		}
	} // end close

	public boolean isUsernameExists(String username) {
		conn = getConnectionn();
		try {
			pStat = conn.prepareStatement("select * from users where username=?");
			pStat.setString(1, username);
			rs = pStat.executeQuery();
			if (rs.next())
				return true;
			else
				return false;
		} catch (Exception e) {
			return false;
		} finally {
			close();
		}
	} // end isUsernameExists

	public boolean addUser(User user) {
		conn = getConnectionn();
		try {
			pStat = conn.prepareStatement("insert into users values(null,?,?)");
			pStat.setString(1, user.getUsername());
			pStat.setString(2, user.getPassword());
			int cnt = pStat.executeUpdate();
			if (cnt > 0)
				return true;
			else
				return false;
		} catch (Exception e) {
			return false;
		} finally {
			close();
		}
	} // end add

	public boolean findUser(String username, String password) {
		conn = getConnectionn();
		try {
			pStat = conn.prepareStatement("select * from users where username=? and password=?");
			pStat.setString(1, username);
			pStat.setString(2, password);
			rs = pStat.executeQuery();
			if (rs.next())
				return true;
			else
				return false;
		} catch (Exception e) {
			return false;
		} finally {
			close();
		}
	} // end findUse
}//end class

3.LoginServlet.java

// TODO Auto-generated method stub
		String username = request.getParameter("username");
		String password = request.getParameter("password");
		UserDAO userdao = new UserDAO();
		boolean flag = userdao.findUser(username, password);
		if (flag) {
			request.getSession().setAttribute("username", username);
			response.sendRedirect("welcome.jsp");
		} else {
			request.getSession().setAttribute("err", "用户名或密码不正确!");
			response.sendRedirect("login.jsp");
		}

4.RegServlet.java

// TODO Auto-generated method stub
		String username = request.getParameter("username");
		String password = request.getParameter("password");
		User user = new User();
		user.setUsername(username);
		user.setPassword(password);
		UserDAO userdao = new UserDAO();
		if (userdao.isUsernameExists(username)) {
			request.getSession().setAttribute("err", "用户名已存在");
			response.sendRedirect("register.jsp");
		} else {
			boolean flag = userdao.addUser(user);
			if (flag) {
				request.getSession().setAttribute("username", username);
				response.sendRedirect("welcome.jsp");
			} else {
				request.getSession().setAttribute("err", "注册失败");
				response.sendRedirect("register.jsp");
			}
		}

5.login.jsp

<%
String errMsg=(String)session.getAttribute("err"); 
if( errMsg!=null ) { %>
<div style="color:red;"><%=errMsg %></div>
<% session.removeAttribute("err");
} %>
<form action="LoginServlet"> 
用户名<input type="text" name="username"><br/>
密码<input type="password" name="password"><br/>
<input type="submit" value="登录">
<input type="reset" value="重填">
</form>

6.register.jsp

<%
String errMsg=(String)session.getAttribute("err"); 
if( errMsg!=null ) { %>
<div style="color:red;"><%=errMsg %></div>
<% session.removeAttribute("err");
}%>
<form action="RegServlet">
用户名<input type="text" name="username"><br/>
密码<input type="password" name="password"><br/>
<input type="submit" value="注册">
<input type="reset" value="重填">
</form>

7.welcome.jsp

<%
String username=(String)session.getAttribute("username");
if(username!=null&&!username.isEmpty()) { %>
你已经登录,欢迎<%=session.getAttribute("username") %>
<% } 
else{
out.print("你还没有登录,3秒后自动跳往登录页面");
response.setHeader("refresh", "3;url=login.jsp");
} %>

六、运行截图

在这里插入图片描述

七、资源下载与学习

CSDN下载:JSP+Servlet+JavaBean模式实现登录注册

联系作者

如需要本资源下载也可以直接添加作者QQ,并可以获取资源预览、软件安装、工程导入、协助运行、算法解释、报告协助撰写等售后服务
欢迎交流

QQ:402501817(心源易码 佩奇)
QQ:2215991436(心源易码 派大星)

  • 19
    点赞
  • 188
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
基于servlet jsp javabean开发模式的用户登录注册系统是一种常见的Web应用程序开发模式。以下是一个简单的描述: 用户登录注册系统的主要组成部分包括前端页面、后端servletJavaBean对象和数据库。 首先,前端页面是用户与系统交互的界面,通常使用JSP技术创建登录页面包括用户名和密码输入框以及登录按钮,注册页面包括用户名、密码和确认密码输入框以及注册按钮。 当用户在登录页面输入用户名和密码并点击登录按钮时,前端页面会通过AJAX或表单提交的方式向后端servlet发送请求。后端servlet负责接收用户请求并处理登录逻辑。 后端servlet首先获取前端页面传递的用户名和密码,并将其封装到JavaBean对象中。JavaBean对象通过封装业务逻辑和数据传递,负责与数据库交互。 接着,后端servlet会调用JavaBean对象的方法,对用户输入的用户名和密码进行验证。验证方式可以是与数据库比对或其他自定义逻辑。如果验证成功,后端servlet将返回登录成功的信息给前端页面,并根据需要进行页面跳转或其他操作。 对于注册功能,当用户在注册页面输入用户名、密码和确认密码并点击注册按钮时,前端页面同样会向后端servlet发送请求。后端servlet获取用户输入的信息并将其封装到JavaBean对象中。 后端servlet调用JavaBean对象的方法,对用户输入的信息进行验证,如检查用户名是否已存在、密码是否符合要求等。如果验证通过,后端servlet将将用户信息存储到数据库中,并返回注册成功的信息给前端页面。 综上所述,基于servlet jsp javabean开发模式的用户登录注册系统涉及前端页面、后端servletJavaBean对象和数据库之间的交互。通过这种模式,可以实现用户的登录和注册功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

中杯可乐多加冰

请我喝杯可乐吧,我会多加冰!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值