JavaWeb入门案例之用户注册

前言

之前把Java的基础知识系统的过了一遍,目前总算可以看懂Java代码了,接下来就是要学习Java开发框架(主要是springMVC)。

下面用一个用户注册的小案例,来总结一下之前学习的Java基础知识。

此案例涉及知识点

  • Java分层思想
  • JDBC连接数据库工具类封装
  • 数据库语句

创建数据库

使用数据库管理管理软件连接数据库,依次执行下面数据库语句。

create Database test_sql;
use test_sql;
CREATE TABLE t_user(u_id varchar(255) PRIMARY KEY NOT NULL,u_name varchar(255) NOT NULL, u_pwd varchar(255) NOT NULL);

项目说明

开发工具是IDEA2020.3.1,数据库是MySql8

jetbrains升级IDEA2020版之后,创建servlet项目跟之前大不一样了,如果不会使用新版的IDEA创建servlet项目,请移步《如何使用IDEA2020.2新建servlet工程》

简单说明一下项目的分层架构,项目下新建四个package。

  • util【存放项目工具类,目前此项目只放自定义封装的JDBCUtil类,用于连接数据库】
  • dao【存放数据库操作类】
  • entity【存放实体类,与数据库表一一对应】
  • servlet【存放servlet类,接收用户请求参数,并调用处理方法】

项目处理逻辑是这样的:servlet层接收到用户请求参数后,将请求参数数据组合成entity类。entity类就是在项目流转的数据。然后将组合好的entity数据传给dao层【怎么传?实例化dao层中相关类对象,调用dao层中的方法传参】。dao层中拿到数据,执行数据相关操作【获取数据库连接,执行相关数据库语句】。

新建用户实体类 – UserEntity

此类与数据库表对映

package cn.ixuela.entity;

import java.io.Serializable;

public class UserEntity implements Serializable {
  private String id;
  private String userName;
  private String userPwd;

  public String getId() {
    return id;
  }

  public void setId(String id) {
    this.id = id;
  }

  public String getUserName() {
    return userName;
  }

  public void setUserName(String userName) {
    this.userName = userName;
  }

  public String getUserPwd() {
    return userPwd;
  }

  public void setUserPwd(String userPwd) {
    this.userPwd = userPwd;
  }
}

新建DAO层

用于操作数据库,dao包下新建IUserDao接口类,并新建impl包。impl包下新建IUserDao接口的实现类IUserDaoImpl

package cn.ixuela.dao;

import cn.ixuela.entity.UserEntity;

import java.util.List;

public interface IUserDao {
  /**
   * 保存用户信息
   * @param userEntity
   */
  boolean saveUser(UserEntity userEntity) throws Exception;
}
package cn.ixuela.dao.impl;

import cn.ixuela.dao.IUserDao;
import cn.ixuela.entity.UserEntity;
import cn.ixuela.utils.DBUtil;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.List;

public class UserDaoImpl implements IUserDao {
  private Connection conn;
  // 传递sql语句
  private PreparedStatement ps;

  @Override
  public boolean saveUser(UserEntity userEntity) {
    try {
      conn = DBUtil.getConn();
      // 定义sql语句
      String Sql = "insert into t_user(u_id,u_name,u_pwd) values (?,?,?)";
      // 执行sql语句
      ps = conn.prepareStatement(Sql);
      ps.setString(1,userEntity.getId());
      ps.setString(2,userEntity.getUserName());
      ps.setString(3,userEntity.getUserPwd());
      // 返回结果集
      int i = ps.executeUpdate();
      if (i == 1) {
        return true;
      }else {
        return false;
      }
    } catch (Exception e) {
      e.printStackTrace();
    } finally {
      DBUtil.close(set,ps,conn);
    }
    return false;
  }
}

新建RegisterServlet类

用于接收用户提交的数据,并把数据转交给DAO层

package cn.ixuela.servlet;

import cn.ixuela.dao.IUserDao;
import cn.ixuela.dao.impl.UserDaoImpl;
import cn.ixuela.entity.UserEntity;

import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.util.HashMap;
import java.util.Map;
import java.util.UUID;

@WebServlet("/register")
public class RegisterServlet extends HttpServlet {
  /**
   * 获得一个UUID
   * @return String UUID
   */
  public static String getUUID(){
    String uuid = UUID.randomUUID().toString();
    //去掉“-”符号
    return uuid.replaceAll("-", "");
  }

  protected void doPost(HttpServletRequest request, HttpServletResponse response)  {
    UserEntity userEntity = new UserEntity();
    IUserDao userDao = new UserDaoImpl();
    String username = request.getParameter("userName");
    String userPwd = request.getParameter("userPwd");
    userEntity.setId(RegisterServlet.getUUID());
    userEntity.setUserName(username);
    userEntity.setUserPwd(userPwd);
    Map<String,Object> map = new HashMap<>();
    try {
      boolean flag = userDao.saveUser(userEntity);
      if (flag) {
        map.put("success", "true");
        map.put("msg", "注册成功!");
      } else {
        map.put("success", "false");
        map.put("msg", "注册失败!");
      }
      response.getWriter().write(map.toString());
      response.getWriter().flush();
      response.getWriter().close();
    } catch (Exception e) {
      e.printStackTrace();
    }
  }
}

项目总结

项目虽然简单,但是却是能说明JavaWeb的基础。此项目属于自己真正从零开始独立完成的。抛弃JSP,可以搭配独立的前端工程或使用postman调试。

原创文章,作者:ZERO,如若转载,请注明出处:https://www.edu24.cn/course/java/javaweb-register.html

(1)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
ZEROZERO
上一篇 2020年12月30日
下一篇 2021年1月20日

相关推荐

  • STS插件mybatis-generator安装及使用

    断断续续学习Java也有好长时间了,没有师傅带,没有项目练手,学习超级慢,也很烦。视频、书籍翻看了一大推,还是没有目标。 相信滴水成海,外加条条大路通罗马,只要坚持,自己终能达成目…

    2019年12月27日
    2.4K
  • Java自学之抽象类与接口

    面向对象程序设计中,类继承的主要作用的扩充已有类的功能。子类可以根据自己的需要选择是否要覆写父类中的方法,所以一个设计完善的父类是无法对子类做出任何强制性的覆写约定。为了解决这样的…

    2020年12月7日
    1.3K
  • JAVA学习之多线程知识点整理

    1、什么是进程?什么是线程? 进程是一个应用程序。线程是一个进程中的执行场景或者执行单元。一个进程可以启动多个线程。进程之间内存独立不共享。同一个进程中的线程之间,堆内存和方法区内…

    2020年6月19日
    1.4K
  • MyBatis之MyBatis-Generator标签配置及意义

    DTD 标签 <generatorConfiguration/>: 根标签,所有的配置都必须在该标签内配置;没有属性 <properties/>: 主要引用外部的pro…

    2019年12月27日
    1.9K
  • Java自学之异常的捕获与处理

    在程序开发中,程序的编译与运行是两个不同的阶段,编译主要针对的是语法检测,而在程序运行时却有可能出现各种各样的错误导致程序中断执行,那么这些错误在Java中统一称为异常。 异常处理…

    2020年12月11日
    1.5K
  • Java自学之I/O编程

    I/O(Input/Output,输入/输出)可以实现数据的读取与写入操作,Java针对I/O操作的实现提供了java.io工具包,此包的核心组成由File类、InputStrea…

    2020年12月21日
    1.3K
  • spring boot练习篇之用户登录系统【接口篇】

    写在前面 抛弃JSP,只做纯粹的前后端分离项目。 作为一个资深前端工作者,想要转JavaWeb开发,无论是书籍,还是网上视频、资料,竟然没有一篇能清楚明白地讲解怎样搭建一个前后端分…

    2021年5月25日
    1.7K
  • JAVA学习路线之夯实基础

    第一章 开发环境 JDK(Java SE Development Kit),Java标准版开发包,提供编译、运行Java程序所需的各种工具和资源,包括Java编译器、Java运行环…

    2020年1月14日
    1.7K
  • Java自学之反射机制

    重用性是面向对象设计的核心原则。为了进一步提升代码的重用性,Java提供了反射机制。反射技术首先考虑的是“反”与“正”的操作,所谓的“正”操作,是指当开发者使用一个类的时候,一定要…

    2020年12月24日
    1.3K
  • Java自学之泛型

    在Java语言中,为了方便接收参数类型的统一,提供了核心类Object,利用此类对象可以接收所有类型的数据(包括基本数据类型和引用数据类型)。但是由于其所描述的数据范围过大,所以在…

    2020年12月8日
    1.4K