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

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

@[TOC]

一、模式分析

在这里插入图片描述

二、架构设计

在这里插入图片描述

三、代码框架

在这里插入图片描述

在这里插入图片描述

四、数据库设置

在这里插入图片描述

五、核心代码

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");
} %>

六、运行截图

在这里插入图片描述



相关文章
|
6月前
|
Java 数据安全/隐私保护
JavaBean组件<jsp:forward>动作<jsp:param>动作登录页面输入用户名和密码,然后进入检查页面判断是否符合要求,符合要求跳转到成功界面,不符合要求返回登录界面,显示错误信息。
该博客文章通过JavaBean组件和JSP动作元素`<jsp:forward>`与`<jsp:param>`的使用示例,演示了用户登录流程,包括登录信息的提交、验证以及根据验证结果进行的页面跳转。
JavaBean组件<jsp:forward>动作<jsp:param>动作登录页面输入用户名和密码,然后进入检查页面判断是否符合要求,符合要求跳转到成功界面,不符合要求返回登录界面,显示错误信息。
|
2月前
|
前端开发 Java 数据库
玩转springboot之springboot注册servlet
在Spring Boot中注册Servlet非常灵活,可以通过 `@WebServlet`注解快速注册,也可以通过 `ServletRegistrationBean`进行细粒度控制。通过这两种方式,可以满足各种场景下的需求,确保应用能够高效处理HTTP请求。
78 14
|
4月前
|
Java 数据安全/隐私保护
【JSP模式二】用户登录界面模块开发
【JSP模式二】用户登录界面模块开发
47 0
|
6月前
|
缓存 安全 Java
Java服务器端技术:Servlet与JSP的集成与扩展
Java服务器端技术:Servlet与JSP的集成与扩展
60 3
|
6月前
|
存储 缓存 前端开发
Servlet与JSP在Java Web应用中的性能调优策略
Servlet与JSP在Java Web应用中的性能调优策略
56 1
|
6月前
|
存储 Java 关系型数据库
基于Servlet和JSP的Java Web应用开发指南
基于Servlet和JSP的Java Web应用开发指南
141 0
|
6月前
|
前端开发 安全 Java
在Java服务器端开发的浩瀚宇宙中,Servlet与JSP犹如两颗璀璨的明星,它们联袂登场,共同编织出动态网站的绚丽篇章。
在Java服务器端开发的浩瀚宇宙中,Servlet与JSP犹如两颗璀璨的明星,它们联袂登场,共同编织出动态网站的绚丽篇章。
39 0
|
6月前
|
Java
JSP中request对象的简单实用,实现简单的注册以及个人信息的展示
该文章通过实例演示了JSP中request对象的用法,包括接收客户端请求信息、设置和获取属性,以及如何使用request对象在电子简历页面中展示个人信息。
|
8月前
|
自然语言处理 前端开发 Java
Servlet与JSP:Java Web开发的基石技术详解
【6月更文挑战第23天】Java Web的Servlet与JSP是动态网页的核心。Servlet是服务器端的Java应用,处理HTTP请求并响应;JSP则是结合HTML与Java代码的页面,用于动态内容生成。Servlet通过生命周期方法如`init()`、`service()`和`destroy()`工作,而JSP在执行时编译成Servlet。两者在MVC架构中分工,Servlet处理逻辑,JSP展示数据。尽管有Spring MVC等框架,Servlet和JSP仍是理解Web开发基础的关键。
139 12
|
8月前
|
存储 Java 关系型数据库
基于Servlet和JSP的Java Web应用开发指南
【6月更文挑战第23天】构建Java Web应用,Servlet与JSP携手打造在线图书管理系统,涵盖需求分析、设计、编码到测试。通过实例展示了Servlet如何处理用户登录(如`LoginServlet`),JSP负责页面展示(如`login.jsp`和`bookList.jsp`)。应用基于MySQL数据库,包含用户和图书表。登录失败显示错误信息,成功后展示图书列表。部署到Tomcat服务器测试功能。此基础教程为深入Java Web开发奠定了基础。
157 10