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

六、运行截图

在这里插入图片描述



相关文章
|
2月前
|
Java 容器
【学习笔记】Jsp与Servlet技术
【学习笔记】Jsp与Servlet技术
84 0
|
2月前
|
Java 数据安全/隐私保护
【JSP模式二】用户登录界面模块开发
【JSP模式二】用户登录界面模块开发
34 0
|
4月前
|
SQL Java 数据库
jsp中使用Servlet查询SQLSERVER数据库中的表的信息,并且打印在屏幕上
该博客文章介绍了在JSP应用中使用Servlet查询SQL Server数据库的表信息,并通过JavaBean封装图书信息,将查询结果展示在Web页面上的方法。
jsp中使用Servlet查询SQLSERVER数据库中的表的信息,并且打印在屏幕上
|
4月前
|
缓存 安全 Java
Java服务器端技术:Servlet与JSP的集成与扩展
Java服务器端技术:Servlet与JSP的集成与扩展
44 3
|
4月前
|
存储 缓存 前端开发
Servlet与JSP在Java Web应用中的性能调优策略
Servlet与JSP在Java Web应用中的性能调优策略
44 1
|
4月前
|
供应链 前端开发 Java
JSP+servlet+mybatis+layui服装库存管理系统(大三上学期课程设计)
这篇文章通过一个服装库存管理系统的实例,展示了在Spring Boot项目中使用Ajax、JSON、layui、MVC架构和iframe等技术,涵盖了注册登录、权限管理、用户管理、库存管理等功能,并提供了系统运行环境和技术要求的详细说明。
JSP+servlet+mybatis+layui服装库存管理系统(大三上学期课程设计)
|
4月前
|
存储 Java 关系型数据库
基于Servlet和JSP的Java Web应用开发指南
基于Servlet和JSP的Java Web应用开发指南
85 0
|
4月前
|
前端开发 安全 Java
在Java服务器端开发的浩瀚宇宙中,Servlet与JSP犹如两颗璀璨的明星,它们联袂登场,共同编织出动态网站的绚丽篇章。
在Java服务器端开发的浩瀚宇宙中,Servlet与JSP犹如两颗璀璨的明星,它们联袂登场,共同编织出动态网站的绚丽篇章。
32 0
|
6月前
|
自然语言处理 前端开发 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开发基础的关键。
116 12
|
6月前
|
存储 Java 关系型数据库
基于Servlet和JSP的Java Web应用开发指南
【6月更文挑战第23天】构建Java Web应用,Servlet与JSP携手打造在线图书管理系统,涵盖需求分析、设计、编码到测试。通过实例展示了Servlet如何处理用户登录(如`LoginServlet`),JSP负责页面展示(如`login.jsp`和`bookList.jsp`)。应用基于MySQL数据库,包含用户和图书表。登录失败显示错误信息,成功后展示图书列表。部署到Tomcat服务器测试功能。此基础教程为深入Java Web开发奠定了基础。
138 10