亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Java > 正文

Java實現驗證碼具體代碼

2019-11-26 15:51:14
字體:
來源:轉載
供稿:網友

這里實現我使用到了struts2模擬一個登錄功能來驗證java實現的驗證碼功能。

Java實現驗證碼的步驟:

1、創建RandomImageGenerator.java類,該類實現驗證碼圖片的生成

2、創建一個servlet類,RandomImageServlet.java,將生成的驗證碼輸出到頁面

3、創建一個Action類,LoginAction.java,控制登錄

4、配置struts.xml一個web.xml文件

5、編寫頁面

具體實現用代碼表達

1、創建RandomImageGenerator.java類

復制代碼 代碼如下:

package com.tenghu.code;

import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics2D;
import java.awt.image.BufferedImage;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.util.Random;
import javax.imageio.ImageIO;

/**
 * 驗證碼生成類
 * @author xiaohu
 *
 */
public class RandomImageGenerator {
 //創建Random對象
 static Random random=new Random();
 //隨機生成包含驗證碼字符串
 public static String random(int num){
  //初始化種子
  String[] str={"0","1","2","3","4","5","6","7","8","9",
       "a","b","c","d","e","f","g","h","i","j",
       "k","l","m","n","p","q","r","s","t"};
  int number=str.length;
  //接收隨機字符
  String text = "";
  //隨機產生4個字符的字符串
  for(int i=0;i<num;i++){
   text+=str[random.nextInt(number)];
  }
  return text;
 }
 /**
  * 隨機產生定義的顏色
  *
  * @return
  */
 private static Color getRandColor() {
  Random random = new Random();
  Color color[] = new Color[10];
  color[0] = new Color(32, 158, 25);
  color[1] = new Color(218, 42, 19);
  color[2] = new Color(31, 75, 208);
  color[3] = new Color(0, 102, 182);
  color[4] = new Color(171, 0, 85);
  return color[random.nextInt(5)];
 }
 /**
  * 產生隨機字體
  *
  * @return
  */
 private static Font getFont() {
  Random random = new Random();
  Font font[] = new Font[5];
  font[0] = new Font("Ravie", Font.BOLD, 30);
  font[1] = new Font("Antique Olive Compact", Font.BOLD, 30);
  font[2] = new Font("Forte", Font.BOLD, 30);
  font[3] = new Font("Wide Latin", Font.BOLD, 30);
  font[4] = new Font("Gill Sans Ultra Bold", Font.BOLD, 30);
  return font[random.nextInt(5)];
 }
 /**
  * 生成圖片
  * @throws IOException
  */
 public static void render(String randomStr,OutputStream out,int width,int height) throws IOException{
  //在內存中創建圖像
  BufferedImage bi=new BufferedImage(width, height, BufferedImage.TYPE_BYTE_INDEXED);
  //獲取圖形上下文
  Graphics2D g=(Graphics2D) bi.getGraphics();
  //話邊框
  g.setColor(Color.white);
  g.fillRect(0, 0, width, height);
  g.setFont(getFont());
  g.setColor(Color.BLACK);
  //畫認證碼,每個認證碼在不同的水平位置
  String str1[]=new String[randomStr.length()];
  for(int i=0;i<str1.length;i++){
   str1[i]=randomStr.substring(i,i+1);
   int w=0;
   int x=(i+1)%3;
   //隨機生成驗證碼字符水平偏移量
   if(x==random.nextInt(7)){
    w=30-random.nextInt(7);
   }else{
    w=30+random.nextInt(7);
   }
   //隨機生成顏色
   g.setColor(getRandColor());
   g.drawString(str1[i], 20*i+10, w);
  }
  //隨機產生干擾點,并用不同的顏色表示,事圖像的認證碼不易被其他程序探測到
  for(int i=0;i<100;i++){
   int x=random.nextInt(width);
   int y=random.nextInt(height);
   Color color=new Color(random.nextInt(255), random.nextInt(255), random.nextInt(255));
   //隨機畫各種顏色的線
   g.setColor(color);
   g.drawOval(x, y, 0, 0);
  }
  //畫干擾線
  for(int i=0;i<15;i++){
   int x=random.nextInt(width);
   int y=random.nextInt(height);
   int x1=random.nextInt(width);
   int y1=random.nextInt(height);
   Color color=new Color(random.nextInt(255), random.nextInt(255), random.nextInt(255));
   //隨機畫各種顏色線
   g.setColor(color);
   g.drawLine(x, y, x1, y1);
  }
  //圖像生效
  g.dispose();
  //輸出頁面
  ImageIO.write(bi, "jpg", out);
 }
 public static void main(String[] args) throws FileNotFoundException, IOException {
  //獲取隨機字符串
  String randomStr=random(5);
  System.out.println(randomStr);
  //生成圖片
  render(randomStr, new FileOutputStream("D://test.jpg"),130,40);
 }
}

2、創建RandomImageServlet.java

復制代碼 代碼如下:

package com.tenghu.code.servlet;

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

import com.tenghu.code.RandomImageGenerator;

public class RandomImageServlet extends HttpServlet {
 //圖片寬度
 int width=0;
 //圖片高度
 int height=0;
 //圖片上隨機字符個數
 int randomStrNum=0;
 public void destroy() {
 }
 public void doGet(HttpServletRequest request, HttpServletResponse response)
   throws ServletException, IOException {
  doPost(request, response);
 }
 public void doPost(HttpServletRequest request, HttpServletResponse response)
   throws ServletException, IOException {
  request.setCharacterEncoding("UTF-8");
  //獲取HttpSession對象
  HttpSession session=request.getSession();
  //獲取隨機字符串
  String randomStr=RandomImageGenerator.random(randomStrNum);
  if(null!=session){
   //設置參數
   session.setAttribute("randomStr", randomStr);
   //設置響應類型,輸出圖片客戶端不緩存
   response.setDateHeader("Expires", 1L); 
   response.setHeader("Cache-Control", "no-cache, no-store, max-age=0");
   response.addHeader("Pragma", "no-cache");
   response.setContentType("image/jpeg"); 
   //輸出到頁面
   RandomImageGenerator.render(randomStr, response.getOutputStream(), width, height);
  }
 }
 public void init() throws ServletException {
  //獲取寬度
  width=Integer.parseInt(this.getInitParameter("width"));
  //獲取高度
  height=Integer.parseInt(this.getInitParameter("height"));
  //獲取個數
  randomStrNum=Integer.parseInt(this.getInitParameter("num"));
 }
}   

3、創建LoginAction.java類

復制代碼 代碼如下:

package com.tenghu.code.action;

import java.io.ByteArrayInputStream;
import java.io.InputStream;
import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionSupport;

public class LoginAction extends ActionSupport{
 //用戶名
 private String userName;
 //密碼
 private String password;
 //驗證碼
 private String code;
 private InputStream inputStream;
 public InputStream getResult(){
  return inputStream;
 }
 //成功
 public String success() throws Exception{
  return SUCCESS;
 }
 //測試登錄
 public String testLogin() throws Exception{
  //獲取圖片的驗證碼
  String randomStr=(String) ActionContext.getContext().getSession().get("randomStr");
  if(code.trim().equalsIgnoreCase(randomStr)){
   if("admin".equals(userName.trim())&&"admin".equals(password.trim())){
    //成功
    inputStream=new ByteArrayInputStream("1".getBytes("UTF-8"));
   }else{
    //用戶名或密碼錯誤
    inputStream=new ByteArrayInputStream("2".getBytes("UTF-8"));
   }
  }else{
   //驗證碼錯誤
   inputStream=new ByteArrayInputStream("0".getBytes("UTF-8"));
  }
  return "result";
 }
 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 getCode() {
  return code;
 }
 public void setCode(String code) {
  this.code = code;
 }
}

4、配置struts.xml、web.xml文件

復制代碼 代碼如下:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
 "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
 "http://struts.apache.org/dtds/struts-2.3.dtd">
<struts> 
 <package name="installs" extends="struts-default">
  <action name="login" class="com.tenghu.code.action.LoginAction">
   <!-- 登錄成功到success.jsp頁面 -->
   <result name="success">success.jsp</result>
   <!-- 登錄驗證返回的數據 -->
   <result name="result" type="stream">
    <param name="contentType">text/html</param>
    <param name="inputName">result</param>
   </result>
  </action>
 </package>
</struts>

復制代碼 代碼如下:

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5"
 xmlns="http://java.sun.com/xml/ns/javaee"
 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
 http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
  <servlet>
    <description>This is the description of my J2EE component</description>
    <display-name>This is the display name of my J2EE component</display-name>
    <servlet-name>RandomImageServlet</servlet-name>
    <servlet-class>com.tenghu.code.servlet.RandomImageServlet</servlet-class>
    <!-- 初始化圖片寬度 -->
    <init-param>
     <param-name>width</param-name>
     <param-value>130</param-value>
    </init-param>
    <!-- 初始化圖片高度 -->
    <init-param>
     <param-name>height</param-name>
     <param-value>40</param-value>
    </init-param>
    <!-- 初始化圖片隨機數個數 -->
    <init-param>
     <param-name>num</param-name>
     <param-value>4</param-value>
    </init-param>
  </servlet>

  <servlet-mapping>
    <servlet-name>RandomImageServlet</servlet-name>
    <url-pattern>/verification.do</url-pattern>
  </servlet-mapping>
  <!-- 配置struts核心過濾器 -->
  <filter>
   <filter-name>struts2</filter-name>
   <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
  </filter>
  <filter-mapping>
   <filter-name>struts2</filter-name>
   <url-pattern>/*</url-pattern>
  </filter-mapping>
  <welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
  </welcome-file-list>
</web-app>

5、編寫測試頁面

復制代碼 代碼如下:

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <base href="<%=basePath%>">

    <title>My JSP 'index.jsp' starting page</title>
 <script type="text/javascript" src="js/jquery-1.10.2.min.js"></script>
 <script type="text/javascript" src="js/jquery.form.js"></script>
 <script type="text/javascript">
  $(document).ready(function(){
   CODE.initCode();
   //驗證輸入
   function checkInput(){
    if($('#userName').val()==''){
     alert('用戶名不能為空!');
     return false;
    }
    if($('#password').val()==''){
     alert('密碼不能為空!');
     return false;
    }
    if($('#code').val()==''){
     alert('驗證碼不能為空!');
     return false;
    }
    return true;
   }

   //點擊按鈕
   $('#btn').click(function(){
    if(checkInput()==true){
     $('#login_request').ajaxSubmit({
      url:'login!testLogin',
      cache:false,
      type:'POST',
      success:function(data){
       if(data==0){
        alert('驗證碼錯誤!');
        //改變驗證碼
        CODE.initCode();
       }else if(data==1){
        alert('登錄成功!');
        //提交到登錄成功頁面
        $('#login_request')[0].submit();
       }else if(data==2){
        alert('用戶名或密碼錯誤!');
        //改變驗證碼
        CODE.initCode();
       }
      },
      error:function(e){
       alert('出錯了!');
      }
     });
     }
   });
  });
  var CODE={
    //初始化化驗證碼
    initCode:function(){
     $("#code_img").attr("src","verification.do?rmd="+new Date().getTime())//如果需要點擊圖片改變圖片的內容,則必須添加時間搓
     .click(function(){
      $(this).attr("src","verification.do?rmd="+new Date().getTime());
     }); 
    }};
 </script>
  </head>

  <body>
   <form action="login!success" id="login_request" method="post">
    UserName:<input type="text" id="userName" name="userName"/><br/>
    Password:<input type="password" id="password" name="password"/><br>
    Verification_Code:<input type="text" id="code" name="code"/><img id="code_img" style="position:relative;top:8px;height:25px"><br>
    <input type="button" id="btn" value="登錄"/>
   </form>
  </body>
</html>

成功頁面就部貼出來了,就是一段文字而已
顯示結果:

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产一区二区免费| 色综合久综合久久综合久鬼88| 日韩三级成人av网| 色婷婷综合久久久久| 欧亚精品在线观看| 6080yy精品一区二区三区| 亚洲福利视频专区| 中文字幕日韩精品在线| 欧美性xxxx| 国产亚洲一区精品| 国产精品九九九| 日韩av手机在线看| 欧美午夜性色大片在线观看| 97av在线影院| 色爱av美腿丝袜综合粉嫩av| 欧美日韩激情美女| 91人人爽人人爽人人精88v| 日韩免费在线电影| 一区二区日韩精品| 亚洲精品国产精品久久清纯直播| 国产精品三级美女白浆呻吟| 热久久视久久精品18亚洲精品| 亚洲天堂一区二区三区| 国模吧一区二区三区| 国产福利视频一区二区| 91在线高清视频| 91精品国产自产在线| 国产精品久久久久久久久久久久| 大伊人狠狠躁夜夜躁av一区| 久久精品视频导航| 国产精品久久久久久久7电影| 国模gogo一区二区大胆私拍| 欧美日韩免费区域视频在线观看| 日韩国产精品一区| 亚洲女人天堂av| 欧美日韩国产综合新一区| 狠狠躁夜夜躁人人躁婷婷91| 日本a级片电影一区二区| 国产精品入口免费视| 亚洲区免费影片| 国产精品成人一区二区| 91免费精品视频| 日韩在线播放一区| 国产精品久久久久久婷婷天堂| 国产99久久精品一区二区 夜夜躁日日躁| 欧美电影在线观看完整版| 色婷婷亚洲mv天堂mv在影片| 91精品国产91久久久| 亚洲人精品午夜在线观看| 国产精品中文字幕久久久| 91大神福利视频在线| 日韩精品有码在线观看| 在线a欧美视频| 日韩一区二区欧美| 亚洲免费av电影| 欧美最猛性xxxx| 亚洲 日韩 国产第一| 96精品久久久久中文字幕| 91探花福利精品国产自产在线| 久久久久北条麻妃免费看| 亚洲天天在线日亚洲洲精| 韩国国内大量揄拍精品视频| 亚洲高清一区二| 成人xxxx视频| 国产综合香蕉五月婷在线| 精品一区二区电影| 国产人妖伪娘一区91| 日韩美女av在线免费观看| 中文字幕在线观看亚洲| 精品无人区太爽高潮在线播放| 亚洲成人久久一区| 成人午夜在线观看| 国产a级全部精品| 伊人久久五月天| 色婷婷久久一区二区| 国产成人精品999| 亚洲午夜女主播在线直播| 国产91露脸中文字幕在线| 亚洲精品一区二区三区婷婷月| 亚洲精品一区久久久久久| 国产精品白嫩美女在线观看| 色播久久人人爽人人爽人人片视av| 奇门遁甲1982国语版免费观看高清| 国产视频999| 国产精品偷伦一区二区| 色综合伊人色综合网| 米奇精品一区二区三区在线观看| 日韩精品视频在线观看免费| 欧美人在线视频| 97成人精品视频在线观看| 亚洲精品国产拍免费91在线| 精品久久久久久中文字幕一区奶水| 日韩一区二区在线视频| 亚洲国产精品va在线| 国产一区二区丝袜高跟鞋图片| 亚洲欧美日韩一区在线| 欧美国产日韩视频| 成人黄色午夜影院| 日韩高清中文字幕| 人妖精品videosex性欧美| 国产日韩在线精品av| 亚洲精品电影在线观看| 清纯唯美亚洲综合| 日本不卡视频在线播放| 亚洲女人天堂av| 欧美韩国理论所午夜片917电影| 亚洲欧美在线一区| 国产成人综合亚洲| 免费成人高清视频| 欧美小视频在线| 国产精品成人av在线| 乱亲女秽乱长久久久| 亚洲人成77777在线观看网| 欧美成人精品在线| 欧美日韩国产一区在线| 亚洲精品suv精品一区二区| 国产精品1234| 亚洲国产高清自拍| 操人视频在线观看欧美| 欧美在线视频免费| 欧美亚洲在线视频| 在线成人免费网站| 国产剧情久久久久久| 精品视频久久久久久久| 亚洲欧洲黄色网| 亚洲精品中文字幕有码专区| 深夜福利日韩在线看| 亚洲国产精品成人一区二区| 日韩视频永久免费观看| 欧美电影院免费观看| 欧美精品国产精品日韩精品| 日韩国产高清污视频在线观看| 国产一区二区三区中文| 国产69精品久久久| 九九热最新视频//这里只有精品| 91香蕉嫩草神马影院在线观看| 精品视频中文字幕| 黄色成人在线播放| 亚洲男人天堂2019| 亚洲精品狠狠操| 色噜噜久久综合伊人一本| 欧美性色19p| 国产日韩中文在线| 久久久久久国产精品| 亚洲国产高清高潮精品美女| 国产精品久久久久福利| 亚洲福利视频久久| 国内精品久久久久久中文字幕| 亚洲高清一区二| 亚洲美女精品久久| 日韩欧美精品在线观看| 91精品国产99久久久久久| 国产日韩在线观看av| 国产精品久久久久久久久久久久久| 精品国产一区二区三区久久狼黑人| 日韩欧美中文第一页| 日韩精品在线私人| 成人在线精品视频| 九九视频直播综合网| 欧美极品欧美精品欧美视频| 高潮白浆女日韩av免费看| 日韩资源在线观看| 亚洲欧洲xxxx| 久久理论片午夜琪琪电影网|