1. 程式人生 > 其它 >2020-12-31 利用現有資料庫用ajax設計登入附帶驗證碼驗證

2020-12-31 利用現有資料庫用ajax設計登入附帶驗證碼驗證

技術標籤:jspajaxjsp

1.登入頁面的jsp檔案程式碼如下:

<%@ page language="java" contentType="text/html; charset=utf-8"
    pageEncoding="utf-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>使用者登入</title>
</head>
<body>
	<input type="text" name="username" id="username"><span id="nameerror"></span><br>
	<input type="password" name="password" id="password"><span id="pwderror"></span><br>
	<input type="text" name="code" id="code" placeholder="請輸入驗證碼">
	<img src="VerfyCodeServlet" onclick="myRefersh(this)"><br>
	<input type="submit" value="登入" id="bt"><br>
</body>
<script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>
<script type="text/javascript">
	$("#bt").click(function() {
		$.ajax({
			url:"LoginServlet",
			type:'post',
			data:{
				username:$("#username").val(),
				password:$("#password").val(),
				code:$("#code").val()
			},
		success:function(data){
			//判斷伺服器返回的資料是否正確
			if(data.status=="ok"){
				window.location.href="index.jsp";
			}else{
				$("#nameerror").text(data.msg);
			}
		}
		});
	});
	$("#username").blur(function() {
		$.ajax({
			url:"ChackServlet",
			type:'post',
			data:{
				username:$("#username").val()
			},
		success:function(data){
				$("#nameerror").text(data.msg);
			}
		});
	});
	function myRefersh( e ) {
		
		const source = e.src ; // 獲得原來的 src 中的內容
		//console.log( "source : " + source  ) ;
		
		var index = source.indexOf( "?" ) ;  // 從 source 中尋找 ? 第一次出現的位置 (如果不存在則返回 -1 )
		//console.log( "index : " + index  ) ;
		
		if( index > -1 ) { // 如果找到了 ?  就進入內部
			var s = source.substring( 0 , index ) ; // 從 source 中擷取 index 之前的內容 ( index 以及 index 之後的內容都被捨棄 )
			//console.log( "s : " + s  ) ;
			
			var date = new Date(); // 建立一個 Date 物件的 一個 例項
			var time = date.getTime() ; // 從 新建立的 Date 物件的例項中獲得該時間對應毫秒值
			e.src = s + "?time=" + time ; // 將 加了 尾巴 的 地址 重新放入到 src 上
			
			//console.log( e.src ) ;
		} else {
			var date = new Date();
			e.src = source + "?time=" + date.getTime();
		}
		
	}
</script>
</html>

2.User包的User類:

package com.cvs.bean;

public class User {
	private String username;
	private String password;
	private int 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 int getId() {
		return id;
	}
	public void setId(int id) {
		this.id = id;
	}
	public User(String username, String password, int id) {
		super();
		this.username = username;
		this.password = password;
		this.id = id;
	}
	public User() {
		super();
		// TODO 自動生成的建構函式存根
	}
	
}

3.Dao包中兩個類:
1).BaseDao類

package com.cvs.dao;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

public class BaseDao {

	protected Connection conn;
	protected PreparedStatement ps;
	public Connection getConnection() {
		String driver ="com.mysql.jdbc.Driver";
		String url="jdbc:mysql://localhost:3306/soft6";
		Connection conn=null;
		try {
			Class.forName(driver);
			
			conn =DriverManager.getConnection(url, "root", "root");
		} catch (ClassNotFoundException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		return conn;
	}
	public void closeAll(Connection conn ,Statement statement,ResultSet resultSet) {
		
		
			try {
				if (resultSet!=null) {
					resultSet.close();
				}
				if (statement!=null) {
					statement.close();
				}
				if (conn!=null) {
					conn.close();
				}
			} catch (SQLException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}
		
	}
	
}

2).UserDao類

package com.cvs.dao;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

import com.cvs.bean.User;

public class UserDao extends BaseDao{
	public User findUserbyuw(String username,String password) {
		try {
			User user=null;
		//1.
		//2.
		Connection conn=getConnection();
		//3.
		PreparedStatement ps=conn.prepareStatement("select * from user where username=? and password=?");
		ps.setString(1, username);//替換佔位符的?
		ps.setString(2, password);
		//4.
		ResultSet res=ps.executeQuery();
		while(res.next()) {
			user=new User();
			user.setId(res.getInt("id"));
			user.setPassword(res.getString("password"));
			user.setUsername(res.getString("username"));
		}
		while(res.next()) {
			user=new User();
			user.setId(res.getInt("id"));
			user.setUsername(res.getString("username"));
		}
		//5.
		closeAll(conn,ps,res);
		return user;
		}catch(SQLException e) {
			e.printStackTrace();
		}
		return null;
	}

	public User findUserbyname(String username) {
			try {
				User user=null;
			//1.
			//2.
			Connection conn=getConnection();
			//3.
			PreparedStatement ps=conn.prepareStatement("select * from user where username=?");
			ps.setString(1, username);//替換佔位符的?
			
			//4.
			ResultSet res=ps.executeQuery();
			while(res.next()) {
				user=new User();
				user.setUsername(res.getString("username"));
			}
			//5.
			closeAll(conn,ps,res);
			return user;
			}catch(SQLException e) {
				e.printStackTrace();
			}
			return null;
		}

	}


4.servlet包中的三個類:
1).ChackServlet類

package com.cvs.servlet;

import java.io.IOException;
import java.util.HashMap;
import java.util.Map;

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 com.alibaba.fastjson.JSON;
import com.cvs.bean.User;
import com.cvs.dao.UserDao;

/**
 * Servlet implementation class ChackServlet
 */
@WebServlet("/ChackServlet")
public class ChackServlet extends HttpServlet {
	private static final long serialVersionUID = 1L;
       
    /**
     * @see HttpServlet#HttpServlet()
     */
    public ChackServlet() {
        super();
        // TODO Auto-generated constructor stub
    }

	/**
	 * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
	 */
	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		response.getWriter().append("Served at: ").append(request.getContextPath());
	}
	/**
	 * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
	 */
	protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		String username=request.getParameter("username");
		UserDao userDao=new UserDao();
		User user=userDao.findUserbyname(username);
		Map map=new HashMap();
		if(user !=null) {
			//判斷成功跑村使用者資訊到session
			request.getSession().setAttribute("user", user);
			map.put("msg", "已被註冊不可使用");
			map.put("status", "ok");
		} else {
			map.put("msg","未被註冊可使用");
			map.put("status", "error");
		}
		request.setCharacterEncoding("utf-8");
		response.setCharacterEncoding("utf-8");
		response.setContentType("application/json;charset=UTF-8");
		response.getWriter().print(JSON.toJSONString(map));
	}

}

2).LoginServlet類

package com.cvs.servlet;

import java.io.IOException;
import java.util.HashMap;
import java.util.Map;

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 com.alibaba.fastjson.JSON;
import com.cvs.bean.User;
import com.cvs.dao.UserDao;

/**
 * Servlet implementation class LoginServlet
 */
@WebServlet("/LoginServlet")
public class LoginServlet extends HttpServlet {
	private static final long serialVersionUID = 1L; 
    /**
     * @see HttpServlet#HttpServlet()
     */
    public LoginServlet() {
        super();
        // TODO Auto-generated constructor stub
    }
	/**
	 * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
	 */
	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		// TODO Auto-generated method stub
		response.getWriter().append("Served at: ").append(request.getContextPath());
	}
	/**
	 * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
	 */
	protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		String code=(String) request.getSession().getAttribute("code");
		String codes=request.getParameter("code");
		String username=request.getParameter("username");
		String password=request.getParameter("password");
		//map設定返回的json資料
		Map map=new HashMap();
		if(!code.equals(codes)) {
		map.put("msg", "驗證碼錯誤");
		//輸出資訊到客戶端
		response.setCharacterEncoding("utf-8");
		response.setContentType("application/json;charset=UTF-8");
		response.getWriter().print(JSON.toJSONString(map));
		return;
		}
		UserDao userDao=new UserDao();
		User user=userDao.findUserbyuw(username, password);
		if(user != null) {
			//判斷成功跑村使用者資訊到session
			request.getSession().setAttribute("user", user);
			map.put("msg","使用者登入成功");
			map.put("status", "ok");
		} else {
			map.put("msg", "使用者名稱或者密碼錯誤");
			map.put("status", "error");
		}
		//輸出資訊到客戶端
		request.setCharacterEncoding("utf-8");
		response.setCharacterEncoding("utf-8");
		response.setContentType("application/json;charset=UTF-8");
		response.getWriter().print(JSON.toJSONString(map));
	}
}

3).VerfyCodeServlet類

package com.cvs.servlet;
import java.io.IOException;
import java.io.OutputStream;
 
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 com.cvs.uitl.GraphicHelper;
 
@WebServlet(urlPatterns = "/VerfyCodeServlet" )
public class VerfyCodeServlet extends HttpServlet {
 
    private static final long serialVersionUID = 3398560501558431737L;
 
    @Override
    protected void service(HttpServletRequest request, HttpServletResponse response)
	    throws ServletException, IOException {
 
	// 獲得 當前請求 對應的 會話物件
	HttpSession session = request.getSession();
 
	// 從請求中獲得 URI ( 統一資源識別符號 )
	String uri = request.getRequestURI();
	System.out.println("hello : " + uri);
 
	final int width = 180; // 圖片寬度
	final int height = 40; // 圖片高度
	final String imgType = "jpeg"; // 指定圖片格式 (不是指MIME型別)
	final OutputStream output = response.getOutputStream(); // 獲得可以向客戶端返回圖片的輸出流
								// (位元組流)
	// 建立驗證碼圖片並返回圖片上的字串
	String code = GraphicHelper.create(width, height, imgType, output);
	System.out.println("驗證碼內容: " + code);
 
	// 建立 uri 和 相應的 驗證碼 的關聯 ( 儲存到當前會話物件的屬性中 )
	session.setAttribute("code", code);
 
//	System.out.println(session.getAttribute(uri));
 
    }
 
}

5.uitl包中的GraphicHelper類

package com.cvs.uitl;

import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.io.IOException;
import java.io.OutputStream;
import java.util.Random;
 
import javax.imageio.ImageIO;
 
public final class GraphicHelper {
 
    /**
     * 以字串形式返回生成的驗證碼,同時輸出一個圖片
     * 
     * @param width
     *            圖片的寬度
     * @param height
     *            圖片的高度
     * @param imgType
     *            圖片的型別
     * @param output
     *            圖片的輸出流(圖片將輸出到這個流中)
     * @return 返回所生成的驗證碼(字串)
     */
    public static String create(final int width, final int height, final String imgType, OutputStream output) {
	StringBuffer sb = new StringBuffer();
	Random random = new Random();
 
	BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
	Graphics graphic = image.getGraphics();
 
	graphic.setColor(Color.getColor("F8F8F8"));
	graphic.fillRect(0, 0, width, height);
 
	Color[] colors = new Color[] { Color.BLUE, Color.GRAY, Color.GREEN, Color.RED, Color.BLACK, Color.ORANGE,
		Color.CYAN };
	// 在 "畫板"上生成干擾線條 ( 50 是線條個數)
	for (int i = 0; i < 50; i++) {
	    graphic.setColor(colors[random.nextInt(colors.length)]);
	    final int x = random.nextInt(width);
	    final int y = random.nextInt(height);
	    final int w = random.nextInt(20);
	    final int h = random.nextInt(20);
	    final int signA = random.nextBoolean() ? 1 : -1;
	    final int signB = random.nextBoolean() ? 1 : -1;
	    graphic.drawLine(x, y, x + w * signA, y + h * signB);
	}
 
	// 在 "畫板"上繪製字母
	graphic.setFont(new Font("Comic Sans MS", Font.BOLD, 30));
	for (int i = 0; i < 6; i++) {
	    final int temp = random.nextInt(26) + 97;
	    String s = String.valueOf((char) temp);
	    sb.append(s);
	    graphic.setColor(colors[random.nextInt(colors.length)]);
	    graphic.drawString(s, i * (width / 6), height - (height / 3));
	}
	graphic.dispose();
	try {
	    ImageIO.write(image, imgType, output);
	} catch (IOException e) {
	    e.printStackTrace();
	}
	return sb.toString();
    }
 
}

其中需要兩個jar包與資料庫,jar包分別為JSON的jar包和mysql的jar包,另外資料庫與登入成功頁面自行建立。

執行截圖如下:
執行截圖