JavaWeb简单案例——用户登录校验JDBC版

简单介绍:

这个和我们之前做的用户登录校验是一样的,只不过是数据源从之前的数据库模拟类变成了真正的数据库而已

运行效果:

代码示例:

登陆界面:

<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%--
  Created by IntelliJ IDEA.
  User: Administrator
  Date: 2022/11/23
  Time: 22:42
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>登陆界面</title>
</head>
<body>
<form action="<c:url value="/JDBCUse"/>">
    <table>
        <tr>
            <td>用户名:</td>
            <td>
                <input type="text" name="username">
            </td>
        </tr>
        <tr>
            <td>密码:</td> <td><input type="password" name="password"></td>
        </tr>
        <tr><td colspan="2"><button type="submit">提交</button></td></tr>
    </table>
</form>
</body>
</html>

显示界面:

<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%--
  Created by IntelliJ IDEA.
  User: Administrator
  Date: 2022/11/23
  Time: 23:44
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>展示界面</title>
    <style>
        .false{
            color: red;
        }
        .true{
            color: #4cae4c;
        }
    </style>
</head>
<body>
<c:choose>
    <c:when test="${sessionScope.userNameTrue}">
        <h1 class="true">欢迎你:${sessionScope.username}</h1>
        <c:remove var="username" scope="session"/>
        <c:remove var="userNameTrue" scope="session"/>
    </c:when>
    <c:when test="${sessionScope.passwdWorn}">
        <h1 class="false">有这个人但是密码不对</h1>
        <c:remove var="passwdWorn" scope="session"/>
    </c:when>
    <c:otherwise>
        <h1 class="false">就没有这个人!</h1>
    </c:otherwise>
</c:choose>
<a href="http://localhost:80/JDBCLogin/Login.jsp">返回首页</a>
</body>
</html>

数据库连接类:

package Semester_3.JDBCLogin;

import java.sql.Connection;
import java.sql.DriverManager;

public class JDBC {
    public static Connection conn() throws Exception{
        Class.forName("com.mysql.cj.jdbc.Driver");
        String url = "jdbc:mysql:///jdbc_demo?serverTimezone=Asia/Shanghai";
        String username = "root";
        String passwd = "123456";
        return DriverManager.getConnection(url, username, passwd);
    }
}

逻辑判断类:

package Semester_3.JDBCLogin;

import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

@WebServlet(name = "JDBCUse" , value = "/JDBCUse")
public class JDBCUse extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) {
        String username = req.getParameter("username");
        String passwd = req.getParameter("password");
        HttpSession session = req.getSession();
        try {
            String SQL = "select * from user";
            Statement stat = JDBC.conn().createStatement();
            ResultSet set = stat.executeQuery(SQL);
            while (set.next()){
                if(set.getString("username").equals(username)){
                    if(set.getString("password").equals(passwd)){
                        System.out.println("有且对");
                        session.setAttribute("userNameTrue","true");
                        session.setAttribute("username",username);
                        resp.sendRedirect("http://localhost/JDBCLogin/show.jsp");
                        return;
                    }else {
                        System.out.println("有这个人但是密码不对");
                        session.setAttribute("passwdWorn","true");
                        resp.sendRedirect("http://localhost/JDBCLogin/show.jsp");
                        return;
                    }
                }
            }
            resp.sendRedirect("http://localhost/JDBCLogin/show.jsp");
        } catch (Exception e) {
            throw new RuntimeException(e);
        }
    }

    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) {
        this.doGet(req, resp);
    }

    public static void main(String[] args) throws Exception {
        Statement statement = JDBC.conn().createStatement();
        String SQL = "select * from user";
        ResultSet set = statement.executeQuery(SQL);
        while (set.next()){
            String username = set.getString("username");
            System.out.println(username);
            System.out.println(username.equals("张三"));
        }
    }
}

思路解析:

界面的显示和数据库的连接都非常简单,我们只说判断的过程。

上面的判断的代码逻辑不是很好,我的基本思路是判断数据库中的username这一列有没有和传进来的用户名相同的,如果有就进入第二层判断,判断密码对不对,如果都对就在session域中设置一个参数,如果中间有发生错误的地方就在对应的session域中传入一个标记,然后重定向到显示的界面。但是在判断没有用户的时候发生了问题,至少我是不知道怎么创建一个判断用户不存在的时候的分支,如果使用else,就会把前几个的判断都走完,会传入很多没有用的数据。

还有一种方法就是将结果存入一个String数组,在数组中进行判断就会容易很多,但是当数据库的数据量非常大的时候,这个做法就不是很明智了。

  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值