20160406javaweb 之JDBC简单案例

Posted 华裳绕指柔

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了20160406javaweb 之JDBC简单案例相关的知识,希望对你有一定的参考价值。

前几天写的user注册登录注销案例,没有用到数据库,现在做出改动,使用数据库存储信息:

一、首先我们需要建立一个数据库:

如下图:

 

创建数据库的代码如下:

-- 导出 database02 的数据库结构
CREATE DATABASE IF NOT EXISTS `database02` /*!40100 DEFAULT CHARACTER SET utf8 */;
USE `database02`;


-- 导出  表 database02.users 结构
CREATE TABLE IF NOT EXISTS `users` (
  `id` int(10) NOT NULL AUTO_INCREMENT,
  `username` varchar(20) NOT NULL,
  `password` varchar(50) NOT NULL,
  `nickname` varchar(40) NOT NULL,
  `email` varchar(50) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

二、创建包和类

1.创建一个接口

package com.dzq.dao;

import com.dzq.domian.User;

public interface UserDao {
   
    /**
     * 根据用户名查找用户
     * @param username 用户名
     * @return 根据用户名找到的用户信息,如果没找到,返回null
     */
    public User findUserByUserName(String username);
    
    /**
     * 添加用户
     * @param user 要添加用户信息的bean
     */
    public void addUser(User user);
    /**
     * 根据用户名密码查找用户信息
     * @param username 用户名
     * @param password 密码
     * @return 找到的用户,找不到返回null 
     */
    public User findUserByUNAndPWD(String username,String password);
}

2.创建操作数据库的工具类:

 

package com.dzq.util;

import java.io.FileReader;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Properties;

public class JDBCUtils {
    
   private static  Properties prop=null;
   
   private JDBCUtils(){
    
   }
   
   /**
    * 静态代码块,加载数据库配置文件
    */
   static{
       try{
        prop=new Properties();
        prop.load(new FileReader(JDBCUtils.class.getClassLoader().getResource("config.properties").getPath()));
       }catch(Exception e){
           e.printStackTrace();
           throw new RuntimeException();
       }
   }
   
   /**
    * 获取连接
    */
   public static Connection getConn() throws Exception{
      
       
       Class.forName(prop.getProperty("driver"));
       return DriverManager.getConnection(prop.getProperty("url"), prop.getProperty("user"), prop.getProperty("password"));
   }
   
   /**
    * 关闭连接
    */
   public static void close(ResultSet rs,Statement stat,Connection conn){
       if(rs!=null){
            try {
                rs.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }finally{
                rs=null;
            }
        }
        if(stat!=null){
            try {
                stat.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }finally{
                stat=null;
            }
        }
        if(conn!=null){
            try {
                conn.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }finally{
                conn=null;
            }
        }
   }
}

 

3.创建异常处理类

package com.dzq.exception;

public class MsgException extends Exception {
public MsgException(){

}

public MsgException(String msg){
    super(msg);
}
}

 

4.创建javabean类

package com.dzq.domian;

import java.io.Serializable;

import com.dzq.exception.MsgException;

public class User implements Serializable{
    private int id;
private String username;
private String password;
private String password2;
private String nickname;
private String email;


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;
}
public String getPassword2() {
    return password2;
}
public void setPassword2(String password2) {
    this.password2 = password2;
}
public String getNickname() {
    return nickname;
}
public void setNickname(String nickname) {
    this.nickname = nickname;
}
public String getEmail() {
    return email;
}
public void setEmail(String email) {
    this.email = email;
}

public User(){
    
}
public User(String username, String password, String password2,
        String nickname, String email) {
    
    this.username = username;
    this.password = password;
    this.password2 = password2;
    this.nickname = nickname;
    this.email = email;
}
@Override
public String toString() {
    return username+":"+password;
}
public void checkValue() throws MsgException{
    if(username==null||"".equals(username)){
        throw new MsgException("用户名不能为空");
    }
    if(password==null||"".equals(password)){
        throw new MsgException("密码不能为空");
    }
    if(password2==null||"".equals(password2)){
        throw new MsgException("密码不能为空");
    }
    if(!password.equals(password2)){
        throw new MsgException("两次密码输入不一致");
    }
    if(nickname==null||"".equals(nickname)){
        throw new MsgException("昵称不能为空");
    }
    if(email==null||"".equals(email)){
        throw new MsgException("邮箱不能为空");
    }
}

}

5.实现上述接口

package com.dzq.dao;

import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.Statement;

import com.dzq.domian.User;
import com.dzq.util.JDBCUtils;

public class mysqlUserDao implements UserDao{
    
    @Override
    public User findUserByUserName(String username) {
        String sql="select * from users where username=\'"+username+"\'";
        Connection conn=null;
        Statement stat=null;
        ResultSet rs=null;
        try {
            conn=JDBCUtils.getConn();
            stat=conn.createStatement();
            rs=stat.executeQuery(sql);
            if(rs.next()){
                User user=new User();
                user.setId(rs.getInt("id"));
                user.setUsername(rs.getString("username"));
                user.setPassword(rs.getString("password"));
                user.setNickname(rs.getString("nickname"));
                user.setEmail(rs.getString("email"));
                return user;
            }else{
                return null;
            }
        } catch (Exception e) {
            e.printStackTrace();
            throw new RuntimeException(e);
        }finally{
            JDBCUtils.close(rs, stat, conn);
        }
    }

    @Override
    public void addUser(User user) {
    String sql="insert into users values (null,\'"+user.getUsername()+"\',\'"+user.getPassword()+"\',\'"+user.getNickname()+"\',\'"+user.getEmail()+"\')";
    Connection conn=null;
    Statement stat=null;
    ResultSet rs=null;
    try {
        conn=JDBCUtils.getConn();
        stat=conn.createStatement();
        int count=stat.executeUpdate(sql);
        
    } catch (Exception e) {
        e.printStackTrace();
        throw new RuntimeException(e);
    }finally{
        JDBCUtils.close(rs, stat, conn);
    }
    }

    @Override
    public User findUserByUNAndPWD(String username, String password) {
        String sql="select * from users where username=\'"+username+"\'and password=\'"+password+"\'";
        Connection conn=null;
        Statement stat=null;
        ResultSet rs=null;
        try {
            conn=JDBCUtils.getConn();
            stat=conn.createStatement();
            rs=stat.executeQuery(sql);
            if(rs.next()){
                User user=new User();
                user.setId(rs.getInt("id"));
                user.setUsername(rs.getString("username"));
                user.setPassword(rs.getString("password"));
                user.setNickname(rs.getString("nickname"));
                user.setEmail(rs.getString("email"));
                return user;
            }else{
                return null;
            }
        } catch (Exception e) {
            e.printStackTrace();
            throw new RuntimeException(e);
        }finally{
            JDBCUtils.close(rs, stat, conn);
        }
    }

}

6.创建service类

package com.dzq.service;

import com.dzq.dao.MySqlUserDao;
import com.dzq.dao.XmlUserDao;
import com.dzq.domian.User;
import com.dzq.exception.MsgException;

public class UserService {
    //private  XmlUserDao dao=new XmlUserDao();
    private MySqlUserDao dao=new MySqlUserDao();
    /**
     * 添加用户
     * @param user
     * @throws MsgException 
     */
    public void registUser(User user) throws MsgException{
        if(dao.findUserByUserName(user.getUsername())!=null){
            throw new MsgException("用户名已经存在");
        }
        dao.addUser(user);
    }
    /**
     * 检查用户名是否正确
     * @param username
     * @param password
     */
    public User isUser(String username,String password){
        return dao.findUserByUNAndPWD(username, password);
        
    }
}

7.建立几个servlet

package com.dzq.web;

import java.io.IOException;
import java.net.URLEncoder;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.dzq.domian.User;
import com.dzq.service.UserService;


@WebServlet("/LoginServlet")
public class LoginServlet extends HttpServlet {
    private static final long serialVersionUID = 1L;
   
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        request.setCharacterEncoding("utf-8");
        response.setContentType("text/html;charset=utf-8");
        String username=request.getParameter("username");
        String password=request.getParameter("password");
        UserService service=new UserService();
        User user=service.isUser(username, password);
        if(user==null){
            request.setAttribute("msg", "用户名或者密码错误");
            request.getRequestDispatcher("/login.jsp").forward(request, response);
        }else{
            request.getSession().setAttribute("user", user);
            if("ok".equals(request.getParameter("remname"))){
                Cookie remNameC=new Cookie("remname",URLEncoder.encode(user.getUsername(),"utf-8"));
                remNameC.setPath(request.getContextPath());
                remNameC.setMaxAge(3600*24*30);
                response.addCookie(remNameC);
            }else{
                Cookie remNameC=new Cookie("remname","");
                remNameC.setPath(request.getContextPath());
                remNameC.setMaxAge(0);
                response.addCookie(remNameC);
            }
            response.sendRedirect(request.getContextPath()+"/index.jsp");
        }
    }

    
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doGet(request, response);
    }

}
package com.dzq.web;

import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;


@WebServlet("/LogOutServlet")
public class LogOutServlet extends HttpServlet {
    private static final long serialVersionUID = 1L;
       
    
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        if(request.getSession(false)!=null&&request.getSession().getAttribute("user")!=null){
            request.getSession().invalidate();
            response.sendRedirect(request.getContextPath()+"/index.jsp");
        }
    }

    
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doGet(request, response);
    }

}
package com.dzq.web;

import java.io.IOException;

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 org.apache.commons.beanutils.BeanUtils;

import com.dzq.domian.User;
import com.dzq.exception.MsgException;
import com.dzq.service.UserService;


@WebServlet("/RegistServlet")
public class RegistServlet extends HttpServlet {
    private static final long serialVersionUID = 1L;
       
   
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        try {
            UserService service=new UserService();
        request.setCharacterEncoding("utf-8");
        response.setContentType("text/html;charset=utf-8");
        //1。检验验证码
        String valistr=request.getParameter("valistr");
        String valistr2=(String) request.getSession().getAttribute("valistr");
        if(valistr==null||valistr2==null||!valistr.equals(valistr2)){
            request.setAttribute("msg", "验证码不正确");
            request.getRequestDispatcher("/regist.jsp").forward(request, response);
            return;
        }
        //2.封装数据,校验数据
        User user=new User();
        BeanUtils.populate(user, request.getParameterMap());
        user.checkValue();
        service.registUser(user);
        request.getSession().setAttribute("user", user);
        response.getWriter().write("恭喜您注册成功,3秒回到主页");
        response.setHeader("refresh", "3;url="+request.getContextPath()+"/index.jsp");
        }catch(MsgException e){
            request.setAttribute("msg",e.getMessage());
            request.getRequestDispatcher("/regist.jsp").forward(request, response);
            return;
        }catch (Exception e) {
            e.printStackTrace();
            throw new RuntimeException(e);
        } 
        //3.调用service方法添加用户
        
        //4.提示注册成功,3秒跳转主页
    }

    
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doGet(request, response);
    }

}
package com.dzq.web;

import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics2D;
import java.awt.image.BufferedImage;
import java.io.IOException;
import java.util.Random;

import javax.imageio.ImageIO;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;


@WebServlet("/ValiImg")
public class ValiImg extends HttpServlet {
    private static final long serialVersionUID = 1L;
       
   
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        request.setCharacterEncoding("utf-8");
        response.setContentType("text/html;charset=utf-8");
        response.setDateHeader("Expires", -1);
        response.setHeader("Cache-Control", "no-cache");
        response.setHeader("Pragma","no-cache");
        //1.在内存中构建一张图片
        int height=30;
        int width=120;
        int xpyl=5;
        int ypyl=22;
        int bang=20;
        BufferedImage img=new BufferedImage(width, height, BufferedImage.TYPE_INT_BGR);
        //2.获取图像上的画布
        Graphics2D g=(Graphics2D) img.getGraphics();
        //3.设置背景色
        g.setColor(Color.LIGHT_GRAY);
        g.fillRect(0, 0, width, height);
        //4.设置边框
        g.setColor(Color.BLUE);
        g.drawRect(0, 0, width-2, height-2);
        //5.画干扰线
        for(int i=0;i<5;i++){
        g.setColor(Color.RED);
        g.drawLine(randNum(0, width), randNum(0, height), randNum(0, width), randNum(0, height));
        }
        //6.写字
        String base = "\\u7684\\u4e00\\u4e86\\u662f\\u6211\\u4e0d\\u5728\\u4eba\\u4eec\\u6709\\u6765\\u4ed6\\u8fd9\\u4e0a\\u7740\\u4e2a\\u5730\\u5230\\u5927\\u91cc\\u8bf4\\u5c31\\u53bb\\u5b50\\u5f97\\u4e5f\\u548c\\u90a3\\u8981\\u4e0b\\u770b\\u5929\\u65f6\\u8fc7\\u51fa\\u5c0f\\u4e48\\u8d77\\u4f60\\u90fd\\u628a\\u597d\\u8fd8\\u591a\\u6ca1\\u4e3a\\u53c8\\u53ef\\u5bb6\\u5b66\\u53ea\\u4ee5\\u4e3b\\u4f1a\\u6837\\u5e74\\u60f3\\u751f\\u540c\\u8001\\u4e2d\\u5341\\u4ece\\u81ea\\u9762\\u524d\\u5934\\u9053\\u5b83\\u540e\\u7136\\u8d70\\u5f88\\u50cf\\u89c1\\u4e24\\u7528\\u5979\\u56fd\\u52a8\\u8fdb\\u6210\\u56de\\u4ec0\\u8fb9\\u4f5c\\u5bf9\\u5f00\\u800c\\u5df1\\u4e9b\\u73b0\\u5c71\\u6c11\\u5019\\u7ecf\\u53d1\\u5de5\\u5411\\u4e8b\\u547d\\u7ed9\\u957f\\u6c34\\u51e0\\u4e49\\u4e09\\u58f0\\u4e8e\\u9ad8\\u624b\\u77e5\\u7406\\u773c\\u5fd7\\u70b9\\u5fc3\\u6218\\u4e8c\\u95ee\\u4f46\\u8eab\\u65b9\\u5b9e\\u5403\\u505a\\u53eb\\u5f53\\u4f4f\\u542c\\u9769\\u6253\\u5462\\u771f\\u5168\\u624d\\u56db\\u5df2\\u6240\\u654c\\u4e4b\\u6700\\u5149\\u4ea7\\u60c5\\u8def\\u5206\\u603b\\u6761\\u767d\\u8bdd\\u4e1c\\u5e2d\\u6b21\\u4eb2\\u5982\\u88ab\\u82b1\\u53e3\\u653e\\u513f\\u5e38\\u6c14\\u4e94\\u7b2c\\u4f7f\\u5199\\u519b\\u5427\\u6587\\u8fd0\\u518d\\u679c\\u600e\\u5b9a\\u8bb8\\u5feb\\u660e\\u884c\\u56e0\\u522b\\u98de\\u5916\\u6811\\u7269\\u6d3b\\u90e8\\u95e8\\u65e0\\u5f80\\u8239\\u671b\\u65b0\\u5e26\\u961f\\u5148\\u529b\\u5b8c\\u5374\\u7ad9\\u4ee3\\u5458\\u673a\\u66f4\\u4e5d\\u60a8\\u6bcf\\u98ce\\u7ea7\\u8ddf\\u7b11\\u554a\\u5b69\\u4e07\\u5c11\\u76f4\\u610f\\u591c\\u6bd4\\u9636\\u8fde\\u8f66\\u91cd\\u4fbf\\u6597\\u9a6c\\u54ea\\u5316\\u592a\\u6307\\u53d8\\u793e\\u4f3c\\u58eb\\u8005\\u5e72\\u77f3\\u6ee1\\u65e5\\u51b3\\u767e\\u539f\\u62ff\\u7fa4\\u7a76\\u5404\\u516d\\u672c\\u601d\\u89e3\\u7acb\\u6cb3\\u6751\\u516b\\u96be\\u65e9\\u8bba\\u5417\\u6839\\u5171\\u8ba9\\u76f8\\u7814\\u4eca\\u5176\\u4e66\\u5750\\u63a5\\u5e94\\u5173\\u4fe1\\u89c9\\u6b65\\u53cd\\u5904\\u8bb0\\u5c06\\u5343\\u627e\\u4e89\\u9886\\u6216\\u5e08\\u7ed3\\u5757\\u8dd1\\u8c01\\u8349\\u8d8a\\u5b57\\u52a0\\u811a\\u7d27\\u7231\\u7b49\\u4e60\\u9635\\u6015\\u6708\\u9752\\u534a\\u706b\\u6cd5\\u9898\\u5efa\\u8d76\\u4f4d\\u5531\\u6d77\\u4e03\\u5973\\u4efb\\u4ef6\\u611f\\u51c6\\u5f20\\u56e2\\u5c4b\\u79bb\\u8272\\u8138\\u7247\\u79d1\\u5012\\u775b\\u5229\\u4e16\\u521a\\u4e14\\u7531\\u9001\\u5207\\u661f\\u5bfc\\u665a\\u8868\\u591f\\u6574\\u8ba4\\u54cd\\u96ea\\u6d41\\u672a\\u573a\\u8be5\\u5e76\\u5e95\\u6df1\\u523b\\u5e73\\u4f1f\\u5fd9\\u63d0\\u786e\\u8fd1\\u4eae\\u8f7b\\u8bb2\\u519c\\u53e4\\u9ed1\\u544a\\u754c\\u62c9\\u540d\\u5440\\u571f\\u6e05\\u9633\\u7167\\u529e\\u53f2\\u6539\\u5386\\u8f6c\\u753b\\u9020\\u5634\\u6b64\\u6cbb\\u5317\\u5fc5\\u670d\\u96e8\\u7a7f\\u5185\\u8bc6\\u9a8c\\u4f20\\u4e1a\\u83dc\\u722c\\u7761\\u5174\\u5f62\\u91cf\\u54b1\\u89c2\\u82e6\\u4f53\\u4f17\\u901a\\u51b2\\u5408\\u7834\\u53cb\\u5ea6\\u672f\\u996d\\u516c\\u65c1\\u623f\\u6781\\u5357\\u67aa\\u8bfb\\u6c99\\u5c81\\u7ebf\\u91ce\\u575a\\u7a7a\\u6536\\u7b97\\u81f3\\u653f\\u57ce\\u52b3\\u843d\\u94b1\\u7279\\u56f4\\u5f1f\\u80dc\\u6559\\u70ed\\u5c55\\u5305\\u6b4c\\u7c7b\\u6e10\\u5f3a\\u6570\\u4e61\\u547c\\u6027\\u97f3\\u7b54\\u54e5\\u9645\\u65e7\\u795e\\u5ea7\\u7ae0\\u5e2e\\u5566\\u53d7\\u7cfb\\u4ee4\\u8df3\\u975e\\u4f55\\u725b\\u53d6\\u5165\\u5cb8\\u6562\\u6389\\u5ffd\\u79cd\\u88c5\\u9876\\u6025\\u6797\\u505c\\u606f\\u53e5\\u533a\\u8863\\u822c\\u62a5\\u53f6\\u538b\\u6162\\u53d4\\u80cc\\u7ec6";
        StringBuffer buffer=new StringBuffer();
        
        for(int i=0;i<4;i++){
            g.setColor(new Color(randNum(0, 255),randNum(0, 255),randNum(0, 255)));
            g.setFont(new Font("黑体",Font.BOLD,bang));
            int r=randNum(-45, 45);
            g.rotate(1.0*r/180*Math.PI,xpyl+i*30, ypyl);
            String s=base.charAt(randNum(0, base.length()-1))+"";
            buffer.append(s);
            g.drawString(s, xpyl+i*30, ypyl);
            g.rotate(1.0*-r/180*Math.PI,xpyl+i*30, ypyl);
        }
        request.getSession().setAttribute("valistr", buffer.toString());
        System.out.println(buffer.toString());
        //将图片输出到浏览器
        ImageIO.write(img, "jpg", response.getOutputStream());
        
    }
    private Random rand=new Random();
    private int randNum(int begin,int end){
        
     return rand.nextInt((end-begin)+begin);        
        
    }
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    doGet(request, response);
    }
}

8. jsp页面:

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
    <%@taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
<html>
<head>
</head>
<body>
<h1>我的网站</h1><hr>
<c:if test="${sessionScope.user!=null}">
欢迎回来!${sessionScope.user.username }<a href="${pageContext.request.contextPath }/LogOutServlet">注销</a>
</c:if>

<c:if test="${sessionScope.user==null}">
游客,欢迎你!<a href="${pageContext.request.contextPath }/regist.jsp">注册</a>|<a href="${pageContext.request.contextPath }/login.jsp">登录</a>
</c:if>
</body>
</html>
<%@ page language="java" contentType="text/html; charset=UTF-8"JavaWeb5.6JDBC:JDBC控制事务转账案例

初学者学javaweb的学习内容有啥

JavaWEB-03-JDBC

老男孩经典语录-20160406

Java实战之04JavaWeb-06DBUtils

JavaWeb之JDBC