简单的XXXX信息管理系统登录实现

1.工具:IDEA,要用到的包,mysql数据库


项目结构

1.2数据库


1.3.准备连接数据库的封装方法

package com.qf.utils;

import com.alibaba.druid.pool.DruidDataSource;

import com.alibaba.druid.pool.DruidDataSourceFactory;

import java.io.IOException;

import java.io.InputStream;

import java.sql.Connection;

import java.sql.ResultSet;

import java.sql.Statement;

import java.util.Properties;

public class DbUtils {

private static DruidDataSource druidDataSource;

static {

InputStream is =  DbUtils.class.getClassLoader().getResourceAsStream("druid.properties");

Properties properties =new Properties();

try {

properties.load(is);

is.close();

druidDataSource = (DruidDataSource) DruidDataSourceFactory.createDataSource(properties);

}catch (IOException e) {

e.printStackTrace();

}catch (Exception e) {

e.printStackTrace();

}

}

public static Connection getConnection() {

Connection conn =null;

try{

conn = druidDataSource.getConnection();

}catch (Exception ex) {

ex.printStackTrace();

}

return conn;

}

public static void colse(ResultSet rs, Statement statement, Connection conn) {

try{

if(null != rs) {

rs.close();

}

if(null != statement) {

statement.close();

}

if(null != conn) {

conn.close();

}

}catch (Exception ex) {

ex.printStackTrace();

}

}

}

2.编写实体类User

public class User {

private Integer id;

private String username;

private String realname;

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 getRealname() {

return realname;

}

public void setRealname(String realname) {

this.realname = realname;

}

}

3.编写实体类People

public class People {

private Integer id;

private String name;

private String gender;

private String email;

private Date birthday;

private Timestamp createTime;

private Timestamp updateTime;

public Integer getId() {

return id;

}

public void setId(Integer id) {

this.id = id;

}

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

public String getGender() {

return gender;

}

public void setGender(String gender) {

this.gender = gender;

}

public String getEmail() {

return email;

}

public void setEmail(String email) {

this.email = email;

}

public Date getBirthday() {

return birthday;

}

public void setBirthday(Date birthday) {

this.birthday = birthday;

}

public Timestamp getCreateTime() {

return createTime;

}

public void setCreateTime(Timestamp createTime) {

this.createTime = createTime;

}

public Timestamp getUpdateTime() {

return updateTime;

}

public void setUpdateTime(Timestamp updateTime) {

this.updateTime = updateTime;

}

}

3.编写druid.properties配置文件,用于数据库的连接

driverClassName=com.mysql.jdbc.Driver

url=jdbc:mysql://localhost:3306/servlet?characterEncoding=utf8&useSSL=false&serverTimezone=Asia/Shanghai

username=root

password=****

#初始化的时候,连接池中放多少个连接

initialSize=10

# 最大存货的连接数量

maxActive=50

#最小空闲数量

minIdle=5

#配置获取连接等待超时的时间

maxWait=10000

#验证连接池中的连接是否有效的sql语句

validationQuery='select 1'

#在获取连接的时候,验证拿到连接是否为有效连接

testOnBorrow=false

#在归还连接的时候,验证是否为有效连接

test-on-return=false

#空闲的时候验证是否有效

test-while-idle=true

4.准备前端用户登录页面


<%@ page contentType="text/html;charset=UTF-8" language="java" %>

<html lang="en">

<head> 

 <meta charset="UTF-8">

 <title>Title</title> 

 <link rel="stylesheet" href="css/bootstrap.min.css"> 

 <style> 

 body {

          background-color:#eeeeee;

}

        .login-panel {

            margin-top:100px;

} </style>

</head>

<body>

<div class="container">   

 <div class="row">       

 <div class="col-xs-6 col-xs-push-3 login-panel">           

     <div class="panel panel-primary">               

           <div class="panel-heading">                    

                <h3 class="panel-title">用户登录</h3>               

          </div>                

      <div class="panel-body">                    

       <p class="alert-danger">                   

              ${param.code == 'error' ? '用户名或者密码错误' : ''}                   

         </p>                    

         <form action="login" method="post">                       

         <div class="form-group">                            

           <label for="username">用户名</label>                           

                 <input class="form-control" autocomplete="off" id="username" name="username">                                          </div>                        

          <div class="form-group">                           

                 <label for="password">密 码</label>                            

                         <input type="password" class="form-control" id="password" name="password">                       

          </div>                       

         <div class="form-group">                           

                      <input type="checkbox" name="rememberMe" value="rememberMe"> 记住我

        </div>                        

       <div class="form-group">                           

               <button class="btn btn-block btn-primary">登录</button>                       

        </div>                   

       </form>                

       </div>            

       </div>        

      </div>    

      </div>

     </div>

</body>

</html>

5.编写UserDao接口

public interface UserDao{

    //查寻一个用户

    User checkUser(String username, String password);

}

6.编写UserDao接口实现类

package com.qf.dao.impl;

import com.qf.dao.UserDao;

import com.qf.info.People;

import com.qf.info.User;

import com.qf.utils.DataUtils;

import com.qf.utils.DbUtils;

import java.sql.Connection;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

public class UserDaoImplimplements UserDao{

    @Override

    public User checkUser(String username, String password) {

        User user =null;

Connection conn = DbUtils.getConnection();

String sql ="select id, username, realname from user where username = ? and password = ?";

try {

            PreparedStatement ps = conn.prepareStatement(sql);

ps.setObject(1,username);

ps.setObject(2,password);

ResultSet rs = ps.executeQuery();

if (rs.next()){

                user =new User();

user.setId(rs.getInt("id"));

user.setUsername(rs.getNString("username"));

user.setRealname(rs.getString("realname"));

}

            DbUtils.colse(rs,ps,conn);

} catch (Exception e) {

            e.printStackTrace();

}

        return user;

}

}

7.编写UserService接口

package com.qf.service;

import com.qf.domain.User;

public interface UserService {

//比较用户的用户名和密码

    User checkUser(String username, String password);

}

8.编写UserService接口实现类

package com.qf.service.impl;

import com.qf.dao.UserDao;

import com.qf.dao.impl.UserDaoImpl;

import com.qf.domain.User;

import com.qf.service.UserService;

public class UserServiceImplimplements UserService {

private UserDao userDao =new UserDaoImpl();

@Override

public User checkUser(String username, String password) {

return userDao.checkUser(username, password);

}

}

9.编写LoginServlet

package com.qf.servlet;

import com.qf.domain.User;

import com.qf.service.UserService;

import com.qf.service.impl.UserServiceImpl;

import org.apache.commons.codec.digest.DigestUtils;

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;

@WebServlet(value ="/login", name ="LoginServlet")

public class LoginServletextends HttpServlet {

// ctrl + shift + 左右键

    private UserService userService =new UserServiceImpl();

/**

    * 在数据库密码存储上会采取一定加密机制。md5(不可逆).  了解:加盐。

    * @param req

    * @param resp

    * @throws ServletException

    * @throws IOException

*/

    @Override

protected void doPost(HttpServletRequest req, HttpServletResponse resp)throws ServletException, IOException {

String username = req.getParameter("username");

String password = req.getParameter("password");

/**

        * 将密码做md5运算之后的字符串。

        * 例如:1 -> c4ca4238a0b923820dcc509a6f75849b, 然后再数据库中去比较密文

        */

        String md5Pwd = DigestUtils.md5Hex(password);

User user = userService.checkUser(username, md5Pwd);

/**

        *  1.当用户为空,表示用户名和密码错误,然后要回到登录页面。

        *  2. 要给用户一个提示信息: "用户名或密码错误".

        *  3. 要重定向到登录页面.

*/

        if(null == user) {

// 如果通过请求转发到登录页面的时候,用户一直刷新,会一直拿着错误的用户名/密码在校验。

            resp.sendRedirect("login.jsp?code=error");

}else {

/**

            * 正确的处理流程:

            *    1.设置到session中。

            *    2.到首页,重定向到 /people 对应的Servlet.

*/

            HttpSession session = req.getSession();

session.setAttribute("user", user);

/**

            * 为什么需要重定向到 PeopleServlet, 从后台携带参数到主页。

            */

            resp.sendRedirect("people");

}

}

}

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容