JavaWeb实现用户登录与注册功能(服务器)

本文实例为大家分享了JavaWeb实现用户登录与注册功能的具体代码,供大家参考,具体内容如下

用到的知识

客户端:HTML CSS JS (JQuery)

服务器:JAVA基础  JSP   Servlet  JDBC  Tomcat

数据库:MySQL

用到的Jar包 druid数据库连接池  dbutils JDBC数据库操作工具  MySQL jar包

总体结构:

客户端数据库部分网址

思路:

服务器部分采用JavaEE三层架构

(1)、表现层:通俗讲就是展现给用户的界面,即用户在使用一个系统的时候他的所见所得。
(2)、业务逻辑层:针对具体问题的操作,也可以说是对数据层的操作,对数据业务逻辑处理。
(3)、数据访问层:该层所做事务直接操作数据库,针对数据的增添、删除、修改、查找等。

先创建基本的文件夹架构,三层的文件夹依次为web ,servlet ,DAO。 此外还有其他相关文件夹工具类utils,JAVABean类pojo,测试类test 。依次实现从DAO层到Servce层再到Web层。

文件夹架构

资源文件 jdbc.properties

username=root
password=123456
url=jdbc:mysql://localhost:3306/book
driverClassName=com.mysql.jdbc.Driver
initialSize=5
maxActive=10

一、DAO层

0.写好JAVABean User类

package com.book.pojo;

public class User {
    private Integer id;
    private String username;
    private String password;
    private String email;

    public User() {
    }

    public User(Integer id, String username, String password, String email) {
        this.id = id;
        this.username = username;
        this.password = password;
        this.email = email;
    }

    public Integer getId() {
        return id;
    }

    public void setId(Integer 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;
    }

    public String getEmail() {
        return email;
    }

    public void setEmail(String email) {
        this.email = email;
    }

    @Override
    public String toString() {
        return "User{" +
                "id=" + id +
                ", username='" + username + '\'' +
                ", password='" + password + '\'' +
                ", email='" + email + '\'' +
                '}';
    }

}

1.先实现数据连接

JDBCUtils

package com.book.utils;

import com.alibaba.druid.pool.DruidDataSource;
import com.alibaba.druid.pool.DruidDataSourceFactory;

import java.io.File;
import java.io.FileInputStream;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.Properties;

public class JDBCUtils {

    private static DruidDataSource druidDataSource;

    //数据库连接池初始化
    static {
        try {

            InputStream resourceAsStream = JDBCUtils.class.getClassLoader().getResourceAsStream("jdbc.properties");//类加载器默认是从classPath路径加载资源
            Properties properties = new Properties();
            properties.load(resourceAsStream);
            //创建数据库连接池
            druidDataSource = (DruidDataSource) DruidDataSourceFactory.createDataSource(properties);
        } catch (Exception e) {
            System.out.println("数据库连接池初始化异常");
        }
    }

    //获取数据库连接池中的连接
    public static Connection getConnection() {

        Connection connection= null;
        try {
            connection = druidDataSource.getConnection();
        } catch (SQLException throwables) {
            throwables.printStackTrace();
        }
        return connection;

    }

    public static void close(Connection connection) {
        try {
            connection.close();
        } catch (SQLException throwables) {
            throwables.printStackTrace();
        }
    }

    public static void main(String[] args) {
        JDBCUtils jdbcUtils=new JDBCUtils();
        System.out.println(jdbcUtils.getConnection());
    }
}

2.测试连接是否成功

3.编写BaseDAO 实现对数据库的基本通用操作

package com.book.DAO;
import com.book.utils.JDBCUtils;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanHandler;
import org.apache.commons.dbutils.handlers.BeanListHandler;
import org.apache.commons.dbutils.handlers.ScalarHandler;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
public abstract class BaseDAO {
    private QueryRunner queryRunner=new QueryRunner();
    //数据库通用操作,使用dbutils来操作
    //用来执行updata,delete,insert
    public int updata(String sql,Object...objects){
        Connection connection= JDBCUtils.getConnection();
        try {
            return queryRunner.update(connection,sql,objects);//返回影响的行数
        } catch (SQLException throwables) {
            throwables.printStackTrace();
        }
        return -1;
    }
    //用来执行查询操作
    public <T>T queryForOne(Class<T>clazz,String sql,Object...objects){
        Connection connection=JDBCUtils.getConnection();
        try {
            return queryRunner.query(connection,sql,new BeanHandler<T>(clazz),objects);
        } catch (Exception throwables) {
            throwables.printStackTrace();
        }
        return null;
    }
    //查询多个结果
    public <T>List<T> queryForList(Class<T>clazz,String sql,Object...objects){
        Connection connection=JDBCUtils.getConnection();
        List<T>list=new ArrayList<>();
        try {
            list=queryRunner.query(connection,sql,new BeanListHandler<T>(clazz),objects);
        } catch (SQLException throwables) {
            throwables.printStackTrace();
        }
        return list;
    }
    //查询单个数
    public Object queryForSingleValue(String sql,Object...objects){
        Connection connection= JDBCUtils.getConnection();
        try {
            return queryRunner.query(connection,sql,new ScalarHandler(),objects);
        } catch (SQLException throwables) {
            throwables.printStackTrace();
        }
        return null;
    }
}

4.编写UserDAO接口确定需要的操作

package com.book.DAO;

import com.book.pojo.User;
public interface UserDAO {
    // 注册时判断是否该用户名已经被注册  根据用户名查询用户信息 如果返回null说明没有该用户
    public User queryUserByUsername(String username);

    //注册成功   保存用户信息
    public int saveUser(User user);

    //登录操作 根据用户名和密码查询用户 查不到返回null
    public User queryUserByUsernameAndPassword(String username,String password);
}

5.UserDAOImpl实现UserDAO接口

package com.book.DAO;
import com.book.pojo.User;
//所犯错误:继承的子类会有父类的全部方法,不要在子类中声明父类对象,调用父类方法
public class UserDAOimpl extends BaseDAO implements UserDAO{

    @Override
    public User queryUserByUsername(String username) {
        String sql="select * from users where username=?";
        User user =queryForOne(User.class,sql,username);
        return user;
    }
    //所犯错误:输入的邮箱不能重复
    @Override
    public int saveUser(User user) {
        String sql="INSERT INTO `users`(`username`,`password`,`email`) VALUES(?,?,?)";
        int n;
        n = updata(sql,user.getUsername(),user.getPassword(),user.getEmail());
        return n;
    }
    @Override
    public User queryUserByUsernameAndPassword(String username, String password) {
        String sql="select * from users where username=? and password=?";
        User user=queryForOne(User.class,sql,username,password);
        return user;
    }
}

二、Servlet层

1.UserServce接口确定业务需要的方法,用来与Web层进行交互

package com.book.servlet;
import com.book.pojo.User;
//业务层一个业务一个方法
public interface UserServce {
    //注册业务 注册成功将用户保存到数据库中
    public void registUser(User user);
    //登录业务
    public User login(User user);
    //检查用户名是否可用 返回true表示用户名已存在
    public boolean existUsername(String username);
}

2.UserServceImpl类实现UserServce接口

package com.book.servlet;
import com.book.DAO.UserDAO;
import com.book.DAO.UserDAOimpl;
import com.book.pojo.User;

public class UserServceImpl implements UserServce {

    private UserDAO userDAO=new UserDAOimpl();
    @Override
    public void registUser(User user) {
        userDAO.saveUser(user);
    }

    @Override
    public User login(User user) {
       return userDAO.queryUserByUsernameAndPassword(user.getUsername(),user.getPassword());
    }

    @Override
    public boolean existUsername(String username) {
        //用户名不存在
         if(userDAO.queryUserByUsername(username)==null){
             return false;
         }else {
             return true;
         }
    }
}

三、Web层

1.注册操作

package com.book.web;
import com.book.pojo.User;
import com.book.servlet.UserServce;
import com.book.servlet.UserServceImpl;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

public class RegistServlet extends HttpServlet {
    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        UserServce userServce=new UserServceImpl();
       //获取请求参数
        String username=req.getParameter("username");
        String password=req.getParameter("password");
        String email=req.getParameter("email");
        String code=req.getParameter("code");
        //判断验证码是否正确 忽略大小写
        if("6n6np".equalsIgnoreCase(code)){
            //判断是否存在用户名
            if(!userServce.existUsername(username)){
                //不存在则将注册信息写入数据库
                User user=new User(null,username,password,email);
                userServce.registUser(user);
                //请求转发到注册成功页面
                req.getRequestDispatcher("/pages/user/regist_success.jsp").forward(req,resp);
            }else{
                System.out.println("用户名已存在");
                //跳转到注册页面
                req.getRequestDispatcher("/pages/user/regist.jsp").forward(req,resp);
            }
        }else {
            System.out.println("验证码错误");
            //跳转到注册页面
            req.getRequestDispatcher("/pages/user/login.jsp").forward(req,resp);
        }
    }
}

2.登录操作

package com.book.web;

import com.book.pojo.User;
import com.book.servlet.UserServce;
import com.book.servlet.UserServceImpl;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

public class LoginServlet extends HttpServlet {
    private UserServce userServce=new UserServceImpl();
    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //获取请求参数
        String username=req.getParameter("username");
        String password=req.getParameter("password");
        User user=new User(null,username,password,null);
        //判断用户的账号密码是否正确
        if(userServce.login(user)!=null){
            //登录成功跳转到登录成功页面
            System.out.println("登录成功");
            req.getRequestDispatcher("/pages/user/login_success.jsp").forward(req,resp);
        }else{
            //账号或密码不正确
            System.out.println("账号或密码不正确");
            req.getRequestDispatcher("/pages/user/login.jsp").forward(req,resp);
        }
    }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • JavaWeb实现用户登录与注册功能

    本文实例为大家分享了JavaWeb实现用户登录与注册的具体代码,供大家参考,具体内容如下 所用知识 客户端:HTML CSS JS (JQuery) 服务器:JAVA基础  JSP   Servlet  JDBC  Tomcat 数据库:MySQL 用到的Jar包 druid数据库连接池  dbutils JDBC数据库操作工具  MySQL jar包 实现效果基本为注册用户,注册成功将数据写入数据库,登录过程查看数据库中是的用户名,密码是否匹配,匹配跳转到登录成功页面,失败返回登录页面. 思路

  • JavaWeb简单用户登录注册实例代码(有验证码)

    需求 编写login登录界面(用户名,密码,验证码,登陆按钮,注册按钮) 设计关系数据库(编号,用户名,密码) 编写注册功能,将数据存储在数据库中.(姓名不能重复,设为主键,重复会注册失败) 编写登录功能 .首先获取验证码,先判断验证码是否正确,不正确则显示验证码错误.验证码正确后再获取用户名和密码,进行数据库的搜索比对,若正确则重定向到成功的界面,并且将用户名显示. jar包 技术选型 Servlet + JSP + Mysql + JDBCTemplate + Druid + BeanUti

  • JavaWeb实战之用Servlet+JDBC实现用户登录与注册

    一.前言 使用到的技术栈: (1)JDBC (2)Servlet (3)MySQL 二.准备工作 (1)书城用户数据库与表创建 (2)编写用户类对象JavaBean (3)编写JdbcUtils对数据库进行交互(使用德鲁伊数据库连接池) (4)编写web层 最终编写好的第二阶段登陆注册文件结构为 dao中定义了基础的操作数据库代码,具体功能有 1.Insert.update.delete(修改) 2.查询一个对象(返回一个对象) 3.查询一个数组对象(数组返回多个对象) 4.返回某一个特定值对象

  • JavaWeb实现用户登录注册功能实例代码(基于Servlet+JSP+JavaBean模式)

    下面通过通过图文并茂的方式给大家介绍JavaWeb实现用户登录注册功能实例代码,一起看看吧. 一.Servlet+JSP+JavaBean开发模式(MVC)介绍 Servlet+JSP+JavaBean模式(MVC)适合开发复杂的web应用,在这种模式下,servlet负责处理用户请求,jsp负责数据显示,javabean负责封装数据. Servlet+JSP+JavaBean模式程序各个模块之间层次清晰,web开发推荐采用此种模式. 这里以一个最常用的用户登录注册程序来讲解Servlet+JS

  • JavaWeb实现用户登录与注册功能(服务器)

    本文实例为大家分享了JavaWeb实现用户登录与注册功能的具体代码,供大家参考,具体内容如下 用到的知识 客户端:HTML CSS JS (JQuery) 服务器:JAVA基础  JSP   Servlet  JDBC  Tomcat 数据库:MySQL 用到的Jar包 druid数据库连接池  dbutils JDBC数据库操作工具  MySQL jar包 总体结构: 客户端数据库部分网址 思路: 服务器部分采用JavaEE三层架构 (1).表现层:通俗讲就是展现给用户的界面,即用户在使用一个

  • JavaWeb实现用户登录与注册功能(服务器)

    本文实例为大家分享了JavaWeb实现用户登录与注册功能的具体代码,供大家参考,具体内容如下 用到的知识 客户端:HTML CSS JS (JQuery) 服务器:JAVA基础  JSP   Servlet  JDBC  Tomcat 数据库:MySQL 用到的Jar包 druid数据库连接池  dbutils JDBC数据库操作工具  MySQL jar包 总体结构: 客户端数据库部分网址 思路: 服务器部分采用JavaEE三层架构 (1).表现层:通俗讲就是展现给用户的界面,即用户在使用一个

  • 用Python实现web端用户登录和注册功能的教程

    用户管理是绝大部分Web网站都需要解决的问题.用户管理涉及到用户注册和登录. 用户注册相对简单,我们可以先通过API把用户注册这个功能实现了: _RE_MD5 = re.compile(r'^[0-9a-f]{32}$') @api @post('/api/users') def register_user(): i = ctx.request.input(name='', email='', password='') name = i.name.strip() email = i.email.

  • JSP实现用户登录、注册和退出功能

    本文讲述使用JSP实现用户登录,包括用户登录.注册和退出功能等. 1.系统用例图 2.页面流程图 3.数据库设计 本例使用oracle数据库 创建用户表 包括id,username,password和email,共4个字段 -- Create table create table P_USER ( id VARCHAR2(50) not null, username VARCHAR2(20), password VARCHAR2(20), email VARCHAR2(50) ) tablesp

  • Django用户登录与注册系统的实现示例

    1.1.创建项目和app django-admin startproject mysite_login python manage.py startapp login 1.2.设置时区和语言 Django默认使用美国时间和英语,在项目的settings文件中,如下所示: LANGUAGE_CODE = 'en-us' TIME_ZONE = 'UTC' USE_I18N = True USE_L10N = True USE_TZ = True 我们把它改为亚洲/上海时间和中文 LANGUAGE_

  • jsp+dao+bean+servlet(MVC模式)实现简单用户登录和注册页面

    功能介绍 本项目通过使用jsp和servlet实现简单的用户登录.主要逻辑为: 如果用户不存在,则首先进行注册(注册信息同步到数据库中). 进行注册后,可进入登录页面对账号进行登录. 如果账号存在,则正确跳转到欢迎界面,否则提示用户账号信息输入错误. 用户进行登录页面时需要填写验证码同时可勾选是否两周内免登陆. 用户进入欢迎界面,则会显示这是用户第几次登录,如果不是第一次登录则会显示上次登录时间. 如果用户直接进入welcome,(没有进行登录,直接打开welcome.jsp)则会跳转到登录页面

随机推荐