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

六、运行截图

在这里插入图片描述



相关文章
|
Java 数据安全/隐私保护
JavaBean组件<jsp:forward>动作<jsp:param>动作登录页面输入用户名和密码,然后进入检查页面判断是否符合要求,符合要求跳转到成功界面,不符合要求返回登录界面,显示错误信息。
该博客文章通过JavaBean组件和JSP动作元素`<jsp:forward>`与`<jsp:param>`的使用示例,演示了用户登录流程,包括登录信息的提交、验证以及根据验证结果进行的页面跳转。
JavaBean组件<jsp:forward>动作<jsp:param>动作登录页面输入用户名和密码,然后进入检查页面判断是否符合要求,符合要求跳转到成功界面,不符合要求返回登录界面,显示错误信息。
|
Java
排课系统【JSP+Servlet+JavaBean】(Java课设)
排课系统【JSP+Servlet+JavaBean】(Java课设)
278 5
|
前端开发 Java 数据库
玩转springboot之springboot注册servlet
在Spring Boot中注册Servlet非常灵活,可以通过 `@WebServlet`注解快速注册,也可以通过 `ServletRegistrationBean`进行细粒度控制。通过这两种方式,可以满足各种场景下的需求,确保应用能够高效处理HTTP请求。
1209 14
|
Java 数据安全/隐私保护
【JSP模式二】用户登录界面模块开发
【JSP模式二】用户登录界面模块开发
254 0
JSP中request对象的简单实用,实现简单的注册以及个人信息的展示
该文章通过实例演示了JSP中request对象的用法,包括接收客户端请求信息、设置和获取属性,以及如何使用request对象在电子简历页面中展示个人信息。
|
Java API
JSP 教程 之 JSP JavaBean 4
**JSP JavaBean教程摘要:** JavaBean是遵循JavaBean规范的特殊Java类,用于JSP中。`jsp:getProperty`读取属性(getter),`jsp:setProperty`设置属性(setter)。
112 0
|
Java API
JSP 教程 之 JSP JavaBean 3
**JSP JavaBean教程简述:** JavaBean是遵循JavaBean规范的特殊Java类,用于JSP中。`&lt;jsp:useBean&gt;`标签声明并实例化Bean,如`&lt;jsp:useBean id=&quot;date&quot; class=&quot;java.util.Date&quot; scope=&quot;page&quot;/&gt;`。`scope`决定Bean的作用域,`id`是变量名。示例显示日期:`&lt;%= date %&gt;`,输出如`Tue Jun 28 15:22:24 CST 2016`。
101 0
|
Java API
JSP 教程 之 JSP JavaBean 2
**JSP JavaBean 简介** JavaBean 是遵循特定规范的 Java 类,用于封装数据和业务逻辑。`StudentsBean.java` 示例展示了属性(firstName, lastName, age)及对应的 getter 和 setter 方法。编译得到 `StudentBean.class`,常放于 `/WebContent/WEB-INF/classes/包路径/` 下,以供JSP使用。
91 0
|
Java API
JSP 教程 之 JSP JavaBean 1
**JSP JavaBean 技术概览:** JavaBean遵循特定规范的Java类,具备默认无参构造器、实现Serializable接口以支持序列化。核心特性包括可读写的属性及对应的getter/setter方法。属性可通过getXXX()和setXXX()访问,如getMyName()和setMyName()对应属性myName。只读属性只有getter,只写属性只有setter。
103 0
|
SQL druid Java
javaweb案例实训之基于jsp和servlet的用户管理开发[增删改查及登录注销]
javaweb案例实训之基于jsp和servlet的用户管理开发[增删改查及登录注销]
156 0