项目案例模板之登录注册的实现

案例演示

案例代码

设计表

pom.xml

 <dependencies>
  <dependency>
    <groupId>junit</groupId>
    <artifactId>junit</artifactId>
    <version>4.11</version>
    <scope>test</scope>
  </dependency>
  <dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>5.0.5</version>
  </dependency>
  <dependency>
    <groupId>javax.servlet</groupId>
    <artifactId>javax.servlet-api</artifactId>
    <version>3.1.0</version>
    <scope>provided</scope>
  </dependency>
  <dependency>
    <groupId>org.junit.jupiter</groupId>
    <artifactId>junit-jupiter-api</artifactId>
    <version>RELEASE</version>
    <scope>compile</scope>
  </dependency>
 </dependencies>

jdbc

JDBCUtils.java
 package jdbc;
 ​
 import org.junit.jupiter.api.Test;
 ​
 import java.sql.Connection;
 import java.sql.DriverManager;
 import java.sql.SQLException;
 ​
 public class JDBCUtils {
    public static Connection connection;
    private static String url="jdbc:mysql://localhost:3306/aaa?useUnicode=true&characterEncoding=utf-8";
    private static String username="root";
    private static String password="root";
 ​
    static{
        try {
            Class.forName("com.mysql.jdbc.Driver");
            connection = DriverManager.getConnection(url,username,password);
 ​
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
 ​
    public static Connection getConnection(){
        return connection;
    }
 ​
    @Test
    public void test(){
        Connection connection = JDBCUtils.getConnection();
        System.out.println(connection);
    }
 }

entity

User.java
 package entity;
 ​
 public class User {
    private int id;
    private String username;
    private String password;
 ​
    public User() {
    }
 ​
    public User(int id, String username, String password) {
        this.id = id;
        this.username = username;
        this.password = password;
    }
 ​
    @Override
    public String toString() {
        return "User{" +
                "id=" + id +
                ", username='" + username + '\'' +
                ", password='" + password + '\'' +
                '}';
    }
 ​
    public int getId() {
        return id;
    }
 ​
    public void setId(int id) {
        this.id = id;
    }
 ​
    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;
    }
 }

dao

UserDao.java
 package dao;
 ​
 import entity.User;
 import jdbc.JDBCUtils;
 ​
 import java.sql.Connection;
 import java.sql.PreparedStatement;
 import java.sql.ResultSet;
 import java.sql.SQLException;
 import java.util.ArrayList;
 import java.util.List;
 ​
 public class UserDao {
    private Connection connection = JDBCUtils.getConnection();
    private PreparedStatement ps;
 ​
    /*
    *添加用户
    * */
    public int add(User user) throws Exception{
        String sql = "insert into user(username,password) values(?,?)";
 ​
            ps=connection.prepareStatement(sql);
            ps.setObject(1,user.getUsername());
            ps.setObject(2,user.getPassword());
            int exe = ps.executeUpdate();
            return exe;
    }
    public int delete(int id) throws SQLException {
        String sql = "delete from user where id=?";
        ps = connection.prepareStatement(sql);
 ​
        /*
          * 删除用户
          * */
        ps.setObject(1,id);
        int exe = ps.executeUpdate();
        return exe;
    }
 ​
    /*
    * 修改用户
    * */
    public int update(User user) throws SQLException {
        String sql = "update user set username=? , password=? where id=?";
        ps = connection.prepareStatement(sql);
        ps.setObject(1,user.getUsername());
        ps.setObject(2,user.getPassword());
        ps.setObject(3,user.getId());
          return ps.executeUpdate();
 ​
    }
 ​
    /*
    * 查询所有用户
    * */
    public List<User> findAll() throws SQLException {
        String sql = "select * from user";
        ps=connection.prepareStatement(sql);
        ResultSet rs =ps.executeQuery();
        List<User> list = new ArrayList<User>();
        while(rs.next()){
            //以 Java 编程语言中 int 的形式获取此 ResultSet 对象的当前行中指定列的值。
            int id = rs.getInt("id");
            String username = rs.getString("username");
            String password = rs.getString("password");
            User u = new User(id,username,password);
            list.add(u);
 ​
        }
        return list;
    }
 ​
 /*
 * 通过id查询用户
 * */
    public User findById(int id) throws SQLException {
        String sql = "select * from user where id=?";
        ps=connection.prepareStatement(sql);
        ps.setInt(1,id);
        ResultSet rs = ps.executeQuery();
 ​
        User u = null;
        while (rs.next()){
            int uid = rs.getInt("id");
            String username = rs.getString("username");
            String password = rs.getString("password");
 ​
 ​
            u = new User(uid,username,password);
        }
 ​
        return u;
    }
 ​
 ​
    /*
    * 用户登录
    * */
    public User login(User user) throws SQLException {
        String sql = "select * from user where username=? and password=?";
        ps = connection.prepareStatement(sql);
        ps.setObject(1,user.getUsername());
        ps.setObject(2,user.getPassword());
 ​
        ResultSet rs = ps.executeQuery();
        User u = null;
 ​
        while (rs.next()){
            int uid = rs.getInt("id");
            String username = rs.getString("username");
            String password = rs.getString("password");
            u = new User(uid,username,password);
        }
 ​
        return u;
    }
 }

service

UserService.java
 package service;
 ​
 import dao.UserDao;
 import entity.User;
 ​
 import java.sql.SQLException;
 import java.util.List;
 ​
 public class UserService {
    private UserDao userDao = new UserDao();
 ​
    public int add(User user) throws Exception {
        return userDao.add(user);
    }
 ​
    public int delete(int id) throws SQLException {
        return userDao.delete(id);
    }
 ​
    public int update(User user) throws SQLException {
        return userDao.update(user);
    }
 ​
    public List<User> findAll() throws SQLException {
        return userDao.findAll();
 ​
    }
 ​
    public User findByID(int id) throws SQLException {
        return userDao.findById(id);
    }
 ​
    public User login(User user) throws SQLException {
        return userDao.login(user);
    }
 }

servlet

LoginServlet.java
 package servlet;
 ​
 import entity.User;
 import service.UserService;
 ​
 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 java.io.IOException;
 import java.sql.SQLException;
 ​
 @WebServlet("/login")
 public class LoginServlet extends HttpServlet {
 ​
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        doPost(req, resp);
    }
 ​
    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        req.setCharacterEncoding("utf-8");
        resp.setCharacterEncoding("utf-8");
 ​
        //接受请求参数
        String username = req.getParameter("username");
        String password = req.getParameter("password");
 ​
        User user = new User();
        user.setUsername(username);
        user.setPassword(password);
 ​
        //查询数据
        UserService us = new UserService();
        User u = null;
 ​
        try {
            u=us.login(user);
            //跳转
            if (u==null){
                req.setAttribute("mess","账号或密码错误");
                req.getRequestDispatcher("login.jsp").forward(req,resp);
            }else {
                req.getSession().setAttribute("user",u);
                resp.sendRedirect("main.jsp");
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }
 ​
 ​
 ​
 ​
    }
 }
RegServlet.java
 package servlet;
 ​
 import dao.UserDao;
 import entity.User;
 ​
 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 java.io.IOException;
 @WebServlet("/reg")
 public class RegServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        doPost(req, resp);
    }
 ​
    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        req.setCharacterEncoding("utf-8");
        resp.setCharacterEncoding("utf-8");
 ​
        //接受请求参数
        String username = req.getParameter("username");
        String password = req.getParameter("password");
 ​
        User u = new User();
        u.setUsername(username);
        u.setPassword(password);
 ​
        UserDao dao = new UserDao();
        int i = 0;
 ​
        try {
            i=dao.add(u);
        } catch (Exception e) {
            e.printStackTrace();
        }
 ​
 ​
        //跳转
        if(i>0){
            req.setAttribute("mess","注册成功");
            resp.sendRedirect("login.jsp");
        }else{
            req.setAttribute("mess","注册失败");
            req.getRequestDispatcher("regist.jsp").forward(req,resp);
        }
 ​
 ​
    }
 }

jsp

web.xml
 <!DOCTYPE web-app PUBLIC
  "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
  "http://java.sun.com/dtd/web-app_2_3.dtd" >
 ​
 <web-app>
  <display-name>Archetype Created Web Application</display-name>
 ​
  <welcome-file-list>
    <welcome-file>regist.jsp</welcome-file>
  </welcome-file-list>
 </web-app>
regist.jsp
 <%@ page contentType="text/html;charset=UTF-8" language="java" isELIgnored="false" %>
 <html>
 <head>
    <title>注册</title>
 </head>
 <body>
 <h1>用户注册</h1>
 <hr>
 <form action="reg" method="post">
    <p>
        用户名:<input type="text" name="username">
    </p>
    <p>
        密码:<input type="text" name="password">
    </p>
    <p>
        <input type="submit" value="注册">
    </p>
 ​
 </form>
 ​
 ${mess}
 ​
 </body>
 </html>
login.jsp
 <%@ page contentType="text/html;charset=UTF-8" language="java" isELIgnored="false" %>
 <html>
 <head>
    <title>登录</title>
 </head>
 <body>
 <h1>用户登录</h1>
 <hr>
 <form action="login" method="post">
    <p>
        用户名:<input type="text" name="username">
    </p>
    <p>
        密码:<input type="text" name="password">
    </p>
    <p>
        <input type="submit" value="登录">
    </p>
 ​
 </form>
 ​
 ${mess}
 ​
 </body>
 </html>
main.jsp
 <%--
  Created by IntelliJ IDEA.
  User: Lenovo
  Date: 2019/4/25
  Time: 9:11
  To change this template use File | Settings | File Templates.
 --%>
 ​
 <%@ page contentType="text/html;charset=UTF-8" language="java" isELIgnored="false" %>
 <html>
 <head>
    <title>主页</title>
 </head>
 <body>
 <h1>欢迎使用本系统</h1>
 当前用户:${sessionScope.user.username}
 </body>
 </html>

*****************************************************************************************************

我的博客园地址:https://www.cnblogs.com/zyx110/

登录注册案例(Servlet+JSP+Maven)的更多相关文章

  1. Java基础知识强化之集合框架笔记37:用户登录注册案例

    1. 登录注册案例分析图解: 2. 用户登录案例 详细分析 和 分包实现: (1)用户登录案例详细分析(面向对象思想) 按照如下的操作,可以让我们更符合面向对象思想: • 有哪些类呢?         ...

  2. vue新手入门之使用vue框架搭建用户登录注册案例,手动搭建webpack+Vue项目(附源码,图文详解,亲测有效)

    前言 本篇随笔主要写了手动搭建一个webpack+Vue项目,掌握相关loader的安装与使用,包括css-loader.style-loader.vue-loader.url-loader.sass ...

  3. Servlet jsp maven 依赖包

    servlet<dependency> <groupId>javax.servlet</groupId> <artifactId>javax.servl ...

  4. 以登录实现理解Servlet+jsp+JavaBean开发

    写在前面:菜鸟拙见,望请纠正 学过servlet的都知道,书本上一直说servlet一直作为控制器使用,它不实现view层,也不做具体的事务处理,那servlet到底是干什么的哪?怎么合理的用它呐?? ...

  5. Java Web实现登录验证码(Servlet+jsp)

    1.生成验证码图片(Servlet) import java.awt.Color; import java.awt.Font; import java.awt.Graphics2D; import j ...

  6. 会话跟踪技术 - Cookie 和 Session 快速上手 + 登陆注册案例

    目录 1. 会话跟踪技术概述 2. Cookie 2.1 Cookie的概念和工作流程 2.2 Cookie的基本使用 2.3 Cookie的原理分析 2.4 Cookie的使用细节 2.4.1 Co ...

  7. Java Web项目案例之---登录注册和增删改查(jsp+servlet)

    登录注册和增删改查(jsp+servlet) (一)功能介绍 1.用户输入正确的密码进行登录 2.新用户可以进行注册 3.登录后显示学生的信息表 4.可以添加学生 5.可以修改学生已有信息 6.可以删 ...

  8. javaweb学习总结(二十二)——基于Servlet+JSP+JavaBean开发模式的用户登录注册

    一.Servlet+JSP+JavaBean开发模式(MVC)介绍 Servlet+JSP+JavaBean模式(MVC)适合开发复杂的web应用,在这种模式下,servlet负责处理用户请求,jsp ...

  9. JavaWeb学习 (二十一)————基于Servlet+JSP+JavaBean开发模式的用户登录注册

    一.Servlet+JSP+JavaBean开发模式(MVC)介绍 Servlet+JSP+JavaBean模式(MVC)适合开发复杂的web应用,在这种模式下,servlet负责处理用户请求,jsp ...

随机推荐

  1. Nim 游戏

    你和你的朋友,两个人一起玩 Nim 游戏:桌子上有一堆石头,每次你们轮流拿掉 1 - 3 块石头. 拿掉最后一块石头的人就是获胜者.你作为先手. 你们是聪明人,每一步都是最优解. 编写一个函数,来判断 ...

  2. Orcl分页查询的语法示例

    Orcle分页查询SQL sql =  SELECT T.* FROM (SELECT X.*, ROWNUM AS RN FROM (SELECT * FROM +表名) X WHERE ROWNU ...

  3. Java描述设计模式(12):外观模式

    本文源码:GitHub·点这里 || GitEE·点这里 一.生活场景 1.场景描述 在移动互联网没有普及之前,去饭店吃饭的流程大致如下:选座位,排队,点菜,结账.后来移动互联网普及,通过手机APP就 ...

  4. 使用IntelliJ IDEA创建第一个Mawen项目

    咳咳...首先各位在学习SSM框架的时候,单个单个学完之后,老夫掐指一算(其实,我是个小鲜肉),各位必定会去整合SSM,这个时候,老夫又掐指一算,各位必定会碰到个mawen的东西,在这里,我可以告诉各 ...

  5. RabbitMQ的管控台的使用说明

    1.RabbitMQ的管控台确实是一个好东西,但是如果是新手,比如刚接触RabbitMQ的时候,看到RabbitMQ的管控台也是一脸懵逼的说,慢慢接触多了,才了解一些使用. 1).RabbitMQ的管 ...

  6. C#函数的递归

    using System; namespace ConsoleApp3 { class Program { static void Main(string[] args) { ); Console.W ...

  7. IDEA 2019.2版本下载安装与PJ教程

    场景 IDEA版本过低的话会导致某些IDEA插件没法安装,比如Lombok插件和EasyCode插件等. 实现 双击exe安装包 点击Next 选择安装路径,点击Next 设置桌面快捷方式,增加到右键 ...

  8. 如何在父级下访问v-slot的值——vuejs

    关于作用域插槽v-slot的用法可以先看看文档 https://cn.vuejs.org/v2/guide/components-slots.html#%E4%BD%9C%E7%94%A8%E5%9F ...

  9. Mybatis的逆向工程,自动生成代码(Mapper,xml,bean)

    步骤: 1. 新建一个Maven项目: 然后导入maven依赖: <dependencies> <dependency> <groupId>org.mybatis& ...

  10. 部署web01,web02,nfs,db01,backup,搭建wordpress,WeCenter,实现共享,热备,实时备份

    小结 部署web01,web02,nfs,db01,backup,搭建wordpress,WeCenter,实现共享,热备,实时备份 1)在web01和web02上安装nginx和php 2)创建ww ...