0. 环境准备

项目创建:

IDEA 创建 Servlet 项目详细步骤:https://www.jianshu.com/p/386a79d16e05

导入 MySQL 驱动包:

Java MySQL 连接:https://eslsuwen.github.io/2019/06/02/Java-MySQL/

1. 创建测试数据

接下来我们在 MySQL 中创建 usersdb 数据库,并创建 user 数据表,表结构如下:

1234
CREATE TABLE `user` (  `name` char(20) NOT NULL DEFAULT '' COMMENT 'name',  `password` char(10) NOT NULL DEFAULT '' COMMENT 'password') ENGINE=InnoDB AUTO_INCREMENT=10 DEFAULT CHARSET=utf8;

插入一些数据:

12345
INSERT INTO `user`VALUES	( 'admin', 'admin' ),	( ' guest ', ' 123456 ' ),	( ' guest1 ', ' 123 ' );

2. 创建登录 jsp 文件

在 web 目录下创建 login.jsp :

1234567891011121314151617181920212223
<%@ page language="java" contentType="text/html; charset=UTF-8"         pageEncoding="UTF-8" %><!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html><head>    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">    <title>登录</title></head><body><div class="login" style="text-align:center;">    <fieldset>        <legend>用户登录</legend>        <br/>        <form action="login" method="post" name="login">            用户名:<input type="text" name="username"/> <br/> <br/> 密&nbsp;码:<input                type="password" name="password"/> <br/> <br/> <input                type="submit" value="登录"/>        </form>    </fieldset></div>

</body></html>

3. 创建登录 servlet 处理登录请求

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
package login;

import database.JdbcOp;

import javax.servlet.ServletException;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.io.IOException;import java.io.PrintWriter;import java.sql.ResultSet;

@WebServlet("/login")public class LoginServlet extends HttpServlet {    private static final long serialVersionUID = 1L;

    protected void doGet(HttpServletRequest request, HttpServletResponse response)            throws ServletException, IOException {        // 一般都会在doGet()方法中调用doPost()方法,或者在doPost()方法中调用doGet()方法        doPost(request, response);    }

    protected void doPost(HttpServletRequest request, HttpServletResponse response)            throws ServletException, IOException {        // 设置编码格式,可以防止乱码出现        response.setContentType("text/html; charset=utf-8");        response.setCharacterEncoding("utf-8");        request.setCharacterEncoding("utf-8");        // 获取用户提交过来的用户名和密码,是通过表单中input的name属性获取的        String username = request.getParameter("username");        String password = request.getParameter("password");        String isSignUp = request.getParameter("isSignUp");        PrintWriter out = response.getWriter();        System.out.println(username + ": " + password + " isSignUp: " + isSignUp);        // 获取输出流,用户显示信息,也可以用转发或者重定向        PrintWriter pw = response.getWriter();

        try {            JdbcOp jdbc = new JdbcOp();            jdbc.open("usersdb");            ResultSet rs = jdbc.executeQuery("select * from users");

            while (rs.next()) {                String nm = rs.getString("name");                String pd = rs.getString("password");                System.out.println("username: " + nm + " password: " + pd);

                if (nm.equals(username) && pd.equals(password)) {                    HttpSession session = request.getSession();                    //将数据存储到session中                    session.setAttribute("isLogin", "true");                    session.setAttribute("username", username);

                    out.print("<script language='javascript'>alert('You login successful  ! 你已成功登录!out.print');window.location.href='test.jsp';</script>");                    out.flush();                    out.close();                }            }            jdbc.close();        } catch (Exception e) {            e.printStackTrace();        }        pw.write("login fail");        out.print("<script language='javascript'>alert('please login first 登陆信息输入有误!');window.location.href='login.jsp';</script>");        out.flush();        out.close();    }

}

4. 运行项目

输入正确的账号密码:

账号密码验证失败:

JavaWeb MySQL 实现登录验证的更多相关文章

  1. 练习:python 操作Mysql 实现登录验证 用户权限管理

    python 操作Mysql 实现登录验证 用户权限管理

  2. 3月9日(用 DBHelper 工具连接 mysql 数据库 实现登录验证)

    一. 用DBHelper 与mysql 连接 实现最简单的登录验证. (1)新建 web project ----->选择src导入 DBHelper 工具包-------->选择web  ...

  3. Spring 笔记 -06- 从 MySQL 建库到 登录验证数据库信息(maven)

    Spring 笔记 -06- 从 MySQL 建库到 登录验证数据库信息(maven) 本篇和 Spring 没有什么关系,只是学习 Spring,必备一些知识,所以放在这里了. 本篇内容: (1)M ...

  4. Android开发之登录验证

    最近在做一个小项目,项目开发中需要实现一个登录验证功能,具体的要求就是,在Android端输入用户名和密码,在服务器端验证MySQL数据库中是否有此用户,实现之前当然首要的是,如何使Android端的 ...

  5. MySQL 1045登录失败

    当你登录MySQL数据库出现:Error 1045错误时(如下图),就表明你输入的用户名或密码错误被拒绝访问了,最简单的解决方法就是将MySQL数据库卸载然后重装,但这样的缺点就是就以前的数据库中的信 ...

  6. Linux登录验证机制、SSH Bruteforce Login学习

    相关学习资料 http://files.cnblogs.com/LittleHann/linux%E4%B8%AD%E7%94%A8%E6%88%B7%E7%99%BB%E5%BD%95%E8%AE% ...

  7. Filter登录验证过滤器(全局)

    通过Filter来定义一个登录验证过滤器,这是就不需要在每一个JSP页面添加判断用户合法性的代码了. 以下示例中包含了5个文件,一个是登录表单LoginForm.jsp,一个是登录判断页LoginCo ...

  8. linux下MySQL安装登录及操作

    linux下MySQL安装登录及操作 二.安装Mysql 1.下载MySQL的安装文件 安装MySQL需要下面两个文件: MySQL-server-4.0.16-0.i386.rpm MySQL-cl ...

  9. mysql配置的讲解 mysql的root密码重置 mysql的登录

    一,MySQL配置的讲解 port  默认mysql端口 socket  用于服务器端和客户端通信的套连接文字 skip-locking 取消文件系统的外部锁 key_buffer_size  索引缓 ...

随机推荐

  1. CentOS7安装CDH 第五章:CDH的安装和部署-CDH5.7.0

    相关文章链接 CentOS7安装CDH 第一章:CentOS7系统安装 CentOS7安装CDH 第二章:CentOS7各个软件安装和启动 CentOS7安装CDH 第三章:CDH中的问题和解决方法 ...

  2. wakelock查看

    Android的wakelock分为两层 待机异常https://wenku.baidu.com/view/6b765c8802020740be1e9bd8.html Linux层和应用层 查看Lin ...

  3. 个人推荐-几款好用的App

    前言 在使用智能手机的过程中比较喜欢尝试一些新奇好玩的app,同时也积攒下了不少个人认为很有帮助或很有特点的app,写这篇随笔当做一个记录吧. 便签-小周便签 一款功能十分强大的便签app,在编辑界面 ...

  4. 将字符串s='ab34aa243dd78eww89' 处理为 '**34**243**78***89',然后对数字求和,结果为'**7**9**15***17'

    s='ab34aa243dd78eww89'#s='ab34aa000dd78eww89' #方法1: result='' for i in s: if i.isalpha(): result+='* ...

  5. SVN(subversion )服务端和客户端的下载安装使用

    SVN(subversion)官方网站: http://subversion.apache.org/packages.html 一.服务端下载 1.百度搜关键字:subversion  进入subve ...

  6. python协程初步---一个迭代器的实现

    一般认为迭代器就是实现了两个方法__iter__和__next__ 先创建这样一个类 from collections import Iterable from collections import ...

  7. java第八次作业-继承

    一.题目 编写一个应用程序,创建一个矩形类,类中具有长.宽两个成员变量和求周长的方法.再创建一个矩形类的子类------正方形类,类中定义求面积的方法.重写求周长的方法.在主类中,输入一个正方形边长, ...

  8. 13、生命周期-InitializingBean和DisposableBean

    13.生命周期-InitializingBean和DisposableBean InitializingBean接口 package org.springframework.beans.factory ...

  9. django post请求 403错误解决方法

    --摘 第一次用Django做项目,遇到了很多问题. 今天遇到的问题是Django在处理post请求时多次出现403错误. 我先描述一下问题出现的环境:我用Django写了一个web服务端,姑且称它为 ...

  10. Appium自动化测试教程-自学网-app基础知识

    Instrumentation的缺点是不支持跨应用,比如我想要先调起通讯录,在操作其他的app,则不支持. 第一步,应该确定系统哪些模块适合自动化.哪些不适合做自动化,明确做自动化给我们带来的好处是什 ...