java web驗(yàn)證碼實(shí)現(xiàn)代碼分享
驗(yàn)證碼的作用:通常的登錄或者注冊(cè)系統(tǒng)時(shí),都會(huì)要求用戶輸入驗(yàn)證碼,以此區(qū)別用戶行為和計(jì)算機(jī)程序行為,目的是有人防止惡意注冊(cè)、暴力破解密碼等。
實(shí)現(xiàn)驗(yàn)證碼的思路:用 server 實(shí)現(xiàn)隨機(jī)生成數(shù)字和字母組成圖片的功能,用 jsp 頁面實(shí)現(xiàn)顯示驗(yàn)證碼和用戶輸入驗(yàn)證碼的功能,再用 server 類分別獲取圖片和用戶輸入的數(shù)據(jù),判斷兩個(gè)數(shù)據(jù)是否一致。
代碼實(shí)現(xiàn)
1.編寫數(shù)字、英文隨機(jī)生成的 server 類,源碼:
package com;
import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.PrintWriter;
import javax.imageio.ImageIO;
import javax.servlet.ServletException;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
public class logcheck extends HttpServlet {
public logcheck() {
super();
}
public void destroy() {
super.destroy();
}
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doPost(request, response);
}
/*實(shí)現(xiàn)的核心代碼*/
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("image/jpeg");
HttpSession session=request.getSession();
int width=60;
int height=20;
//設(shè)置瀏覽器不要緩存此圖片
response.setHeader("Pragma", "No-cache");
response.setHeader("Cache-Control", "no-cache");
response.setDateHeader("Expires", 0);
//創(chuàng)建內(nèi)存圖像并獲得圖形上下文
BufferedImage image=new BufferedImage(width, height,BufferedImage.TYPE_INT_RGB);
Graphics g=image.getGraphics();
/*
* 產(chǎn)生隨機(jī)驗(yàn)證碼
* 定義驗(yàn)證碼的字符表
*/
String chars="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";
char[] rands=new char[4];
for(int i=0;i<4;i++){
int rand=(int) (Math.random() *36);
rands[i]=chars.charAt(rand);
}
/*
* 產(chǎn)生圖像
* 畫背景
*/
g.setColor(new Color(0xDCDCDC));
g.fillRect(0, 0, width, height);
/*
* 隨機(jī)產(chǎn)生120個(gè)干擾點(diǎn)
*/
for(int i=0;i<120;i++){
int x=(int)(Math.random()*width);
int y=(int)(Math.random()*height);
int red=(int)(Math.random()*255);
int green=(int)(Math.random()*255);
int blue=(int)(Math.random()*255);
g.setColor(new Color(red,green,blue));
g.drawOval(x, y, 1, 0);
}
g.setColor(Color.BLACK);
g.setFont(new Font(null, Font.ITALIC|Font.BOLD,18));
//在不同高度輸出驗(yàn)證碼的不同字符
g.drawString(""+rands[0], 1, 17);
g.drawString(""+rands[1], 16, 15);
g.drawString(""+rands[2], 31, 18);
g.drawString(""+rands[3], 46, 16);
g.dispose();
//將圖像傳到客戶端
ServletOutputStream sos=response.getOutputStream();
ByteArrayOutputStream baos=new ByteArrayOutputStream();
ImageIO.write(image, "JPEG", baos);
byte[] buffer=baos.toByteArray();
response.setContentLength(buffer.length);
sos.write(buffer);
baos.close();
sos.close();
session.setAttribute("checkcode", new String(rands));
}
public void init() throws ServletException {
// Put your code here
}
}
2.用于顯示驗(yàn)證碼的頁面:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>"> <title>index</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <!-- <link rel="stylesheet" type="text/css" href="styles.css"> --> </head> <body> <form action="yanzheng" method="post"> <input type="text" name="name" size="5" maxlength="4"> <a href="index.jsp"><img border="0" src="logcheck"></a><br><br>      <input type="submit" value="提交"> </form> </body> </html>
3.用于檢驗(yàn)輸入的驗(yàn)證碼是否正確:
package com;
import java.io.IOException;
import java.io.PrintWriter;
import javax.jms.Session;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
public class yanzheng extends HttpServlet {
public yanzheng() {
super();
}
public void destroy() {
super.destroy();
}
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doPost(request, response);
}
/*核心代碼*/
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
String info=null;
/*獲取輸入的值*/
String value1=request.getParameter("name");
/*獲取圖片的值*/
HttpSession session=request.getSession();
String value2=(String)session.getAttribute("checkcode");
/*對(duì)比兩個(gè)值(字母不區(qū)分大小寫)*/
if(value2.equalsIgnoreCase(value1)){
info="驗(yàn)證碼輸入正確";
}else{
info="驗(yàn)證碼輸入錯(cuò)誤";
}
System.out.println(info);
request.setAttribute("info", info);
request.getRequestDispatcher("/login.jsp").forward(request, response);
}
public void init() throws ServletException {
// Put your code here
}
}
4.顯示輸入結(jié)構(gòu)界面(輸入驗(yàn)證碼是否正確):
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>">
<title>My JSP 'login.jsp' starting page</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<!--
<link rel="stylesheet" type="text/css" href="styles.css">
-->
</head>
<body>
<%=request.getAttribute("info") %>
</body>
</html>
5.項(xiàng)目結(jié)構(gòu)、效果截圖:


以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- javaweb登錄驗(yàn)證碼的實(shí)現(xiàn)方法
- Java web含驗(yàn)證碼及權(quán)限登錄實(shí)例代碼
- java圖形驗(yàn)證碼生成工具類 web頁面校驗(yàn)驗(yàn)證碼
- JavaWeb 實(shí)現(xiàn)驗(yàn)證碼功能(demo)
- javaWeb使用Kaptcha組件生成驗(yàn)證碼
- java web中圖片驗(yàn)證碼功能的簡單實(shí)現(xiàn)方法
- Java Web項(xiàng)目中驗(yàn)證碼功能的制作攻略
- Java Web開發(fā)過程中登陸模塊的驗(yàn)證碼的實(shí)現(xiàn)方式總結(jié)
- Javaweb開發(fā)中通過Servlet生成驗(yàn)證碼圖片
- java web開發(fā)之servlet圖形驗(yàn)證碼功能的實(shí)現(xiàn)
相關(guān)文章
Java實(shí)現(xiàn)將word轉(zhuǎn)換為html的方法示例【doc與docx格式】
這篇文章主要介紹了Java實(shí)現(xiàn)將word轉(zhuǎn)換為html的方法,結(jié)合實(shí)例形式分析了java針對(duì)doc與docx格式文件的相關(guān)轉(zhuǎn)換操作技巧,需要的朋友可以參考下2019-03-03
詳解J2EE開發(fā)的網(wǎng)站部署到阿里云服務(wù)器的方法
這篇文章主要介紹了詳解J2EE開發(fā)的網(wǎng)站部署到阿里云服務(wù)器的方法,需要的朋友可以參考下2018-01-01
詳解Java編程中final,finalize,finally的區(qū)別
這篇文章主要介紹了詳解Java編程中final,finalize,finally的區(qū)別,這個(gè)在Java面試題中簡直是太常見了...需要的朋友可以參考下2015-11-11
Java反射機(jī)制,反射相關(guān)API,反射API使用方式(反射獲取實(shí)體類字段名和注解值)
這篇文章主要介紹了Java反射機(jī)制,反射相關(guān)API,反射API使用方式(反射獲取實(shí)體類字段名和注解值),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-07-07
Java實(shí)現(xiàn)掃雷游戲詳細(xì)代碼講解
windows自帶的游戲《掃雷》是陪伴了無數(shù)人的經(jīng)典游戲,本文將利用Java語言實(shí)現(xiàn)這一經(jīng)典的游戲,文中的示例代碼講解詳細(xì),感興趣的可以學(xué)習(xí)一下2022-05-05
springboot登陸頁面圖片驗(yàn)證碼簡單的web項(xiàng)目實(shí)現(xiàn)
這篇文章主要介紹了springboot登陸頁面圖片驗(yàn)證碼簡單的web項(xiàng)目實(shí)現(xiàn),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-04-04
Java 基礎(chǔ)之內(nèi)部類詳解及實(shí)例
這篇文章主要介紹了 Java 基礎(chǔ)之內(nèi)部類詳解及實(shí)例的相關(guān)資料,需要的朋友可以參考下2017-03-03
java數(shù)據(jù)結(jié)構(gòu)之搜索二叉樹
這篇文章主要為大家詳細(xì)介紹了java數(shù)據(jù)結(jié)構(gòu)之搜索二叉樹,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01

