`
yuanlanjun
  • 浏览: 1181286 次
文章分类
社区版块
存档分类
最新评论

验证码实现方式总结

 
阅读更多

验证码实现方式:


一.js实现验证码:


第一步:建一个login.htm,一个code.js文件,一个code.css文件,准备一张图片code.jpg


第二步:编写login.htm文件,内容为:

<html>
<head>
<script language = "javascript" src = "code.js"></script>
<link rel="stylesheet" type="text/css" href="code.css">
</head>
<body onload="createCode();">
<form>
 <center>验证码:<input type="text" id="input1" />
<input type="text" id="checkCode" class="code" style="width: 55px" /> <a href="#" onclick="createCode()">看不清楚</a>
<input id="Button1" onclick="validate();" type="button" value="确定" /></center>
</form>
</body>
</html>


第三步:编写code.css文件,内容为:

.code{
background-image:url(code.jpg);
font-family:Arial;
font-style:italic;
color:Red;
border:0;
padding:2px 3px;
letter-spacing:3px;
font-weight:bolder;
}


第四步:编写code.js文件,内容为:

var code ; //在全局 定义验证码
function createCode(){ 
code = "";
var codeLength = 4;//验证码的长度
var checkCode = document.getElementById("checkCode");
checkCode.value = "";


var selectChar = new Array(2,3,4,5,6,7,8,9,'A','B','C','D','E','F','G','H','J','K','L','M','N','P','Q','R','S','T','U','V','W','X','Y','Z');


for(var i=0;i<codeLength;i++) {
   var charIndex = Math.floor(Math.random()*32);
   code +=selectChar[charIndex];
}
if(code.length != codeLength){
   createCode();
}
checkCode.value = code;
}


function validate () {
var inputCode = document.getElementById("input1").value.toUpperCase();


if(inputCode.length <=0) {
   alert("请输入验证码!");
   return false;
}
else if(inputCode != code ){
   alert("验证码输入错误!");
   createCode();
   return false;
}
else {
   alert("OK");
   return true;
}


}


第五步:把四个文件放到一个文件夹中,运行login.htm文件,显示结果为:


二.servlet实现验证码:


第一步:建一个动态工程check,一个check.java(servlet类),一个login.jsp文件

第二步:编写check.java文件,内容为:

package check;
import javax.servlet.ServletException;
import javax.servlet.http.*;
import java.io.*;
import java.awt.*;
import java.awt.image.*;
import java.util.*;
import javax.imageio.*; 

/**
 * @author  yeeku.H.lee kongyeeku@163.com
 * @version  1.0
 * <br>Copyright (C), 2005-2008, yeeku.H.Lee
 * <br>This program is protected by copyright laws.
 * <br>Program Name:
 * <br>Date: 
 */
public class check extends HttpServlet
{
    private Font mFont = new Font("Arial Black", Font.PLAIN, 16);
    public void init() throws ServletException
    {
        super.init();
    }
    Color getRandColor(int fc,int bc)
    {
        Random random = new Random();
        if(fc>255) fc=255;
        if(bc>255) bc=255;
        int r=fc+random.nextInt(bc-fc);
        int g=fc+random.nextInt(bc-fc);
        int b=fc+random.nextInt(bc-fc);
        return new Color(r,g,b);
    }

    public void service(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException
    {
        response.setHeader("Pragma","No-cache");
        response.setHeader("Cache-Control","no-cache");
        response.setDateHeader("Expires", 0);
        response.setContentType("image/jpeg");
        
        int width=100, height=18;
        BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
        
        Graphics g = image.getGraphics();
        Random random = new Random();
        g.setColor(getRandColor(200,250));
        g.fillRect(1, 1, width-1, height-1);
        g.setColor(new Color(102,102,102));
        g.drawRect(0, 0, width-1, height-1);
        g.setFont(mFont);

        g.setColor(getRandColor(160,200));
        for (int i=0;i<155;i++)
        {
            int x = random.nextInt(width - 1);
            int y = random.nextInt(height - 1);
            int xl = random.nextInt(6) + 1;
            int yl = random.nextInt(12) + 1;
            g.drawLine(x,y,x + xl,y + yl);
        }
        for (int i = 0;i < 70;i++)
        {
            int x = random.nextInt(width - 1);
            int y = random.nextInt(height - 1);
            int xl = random.nextInt(12) + 1;
            int yl = random.nextInt(6) + 1;
            g.drawLine(x,y,x - xl,y - yl);
        }

        String sRand="";
        for (int i=0;i<6;i++)
        {
   String tmp = getRandomChar();
            sRand += tmp;
            g.setColor(new Color(20+random.nextInt(110),20+random.nextInt(110),20+random.nextInt(110)));
         g.drawString(tmp,15*i+10,15);
        }

        HttpSession session = request.getSession(true);
        session.setAttribute("rand",sRand);
        g.dispose();
        ImageIO.write(image, "JPEG", response.getOutputStream());
    }
    private String getRandomChar()
    {
  int rand = (int)Math.round(Math.random() * 2);
  long itmp = 0;
  char ctmp = '\u0000';
  switch (rand)
  {
   case 1:
    itmp = Math.round(Math.random() * 25 + 65);
    ctmp = (char)itmp;
    return String.valueOf(ctmp);
   case 2:
    itmp = Math.round(Math.random() * 25 + 97);
    ctmp = (char)itmp;
    return String.valueOf(ctmp);
   default :
    itmp = Math.round(Math.random() * 9);
    return String.valueOf(itmp);
  }
    }
}


第三步:编写login.jsp文件,内容为:

<%@ page language="java" import="java.util.*" pageEncoding="GB18030"%>
<%
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 'index.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">
	-->
	<script>
   function refresh()
   {
    document.getElementById("authImg").src='check?now=' + new Date();
   }
  </script>
  </head>
  
  <body>
  <%
 
  
  %>
    验证码如图:<img src="check" id="authImg"/>看不清?<a href="#" onClick="refresh()">单击此处刷新</a>
  </body>
</html>


第四步:在web.xml文件中配置代码,内容为:

<servlet>
        <servlet-name>img</servlet-name>
        <servlet-class>check.check</servlet-class>
    </servlet>

    <servlet-mapping>
        <servlet-name>img</servlet-name>
     <url-pattern>/check</url-pattern>
    </servlet-mapping> 


第五步:在tomcat服务器上发布项目check,运行login.jsp,运行结果为:


分享到:
评论

相关推荐

    Java Web开发过程中登陆模块的验证码的实现方式总结

    验证码及它的作用 验证码为全自动区分计算机和人类的图灵测试的缩写,是一种区分用户是计算机的公共全自动程序,这个问题可以由计算机生成并评判,但是必须只有人类才能解答.可以防止恶意破解密码、刷票、论坛...实现方式

    Maven项目中验证码的实现

    在Maven中实现验证码的功能比较困难。我在这总结了这复杂的操作步骤,写的很详细,并且有代码,希望能帮的到你。

    php实现验证码的识别(初级篇)

    一方面算是对这几天学习知识的总结帮助自己理解;另一方面希望对研究这方面的技术同学有所帮助;另外也希望引起网站管理者的注意,在提供验证码时多些考虑进去。由于刚刚接触这方面的知识,理解比较浅显,有错误再所...

    自动化测试中的验证码处理方法小总结.docx

     验证码一般应用在WEB系统涉及登录和输入的页面上,其实现的一般方法是在页面上显示一幅图片,要求用户肉眼识别图片中的信息并将该信息作为输入的一部 分进行提交。页面上显示的这幅图片一般是一串随机产生的数字或...

    java验证码(关于用jdk去实现验证码)

    关于Java验证码的总结,在网上找到的,然后给整理了的,希望对你们有用

    实验五 AJAX开发及JSP验证码

    1.在实验四基础上使用AJAX技术实现异步登录功能。(40分) Ajax异步的特点为:多个事件并行发生,事件互不影响,请求之后,不刷新整张页面,页面不动,只是刷新页面的局部。异步数据获取技术 XMLHttpRequest对象方法...

    Struts2验证码

    对于WEB项目的Struts框架开发如何实现前端注册验证码的编写

    一些字符图片验证码破解的方法

    个人总结验证码破解方法,用tensorflow在gpu上实现验证码破解,破解了一家网站的具有像素化数字大小写字母字符、斑点背景噪声验证码,初次准确率达50%。

    Vue实现滑动拼图验证码功能

    缘由:之前看哔哩哔哩官网登录的时候有一个拼图验证码,很好奇怎么去实现。然后就想着自己弄一个。先给大家看我的最终效果。后面再一点点拆解代码。   为什么想着写这个功能呢,主要在于拼图验证码在前端这里会...

    asp.net和ajax联合使用注册用户以及漂亮的验证码生成

    自己正在学习ajax,一手总结出来的,都是自己一个一个打出来的有很多我之前从未学到过的知识点,希望可以给你们带来帮助

    Angular.js实现获取验证码倒计时60秒按钮的简单方法

    最近做项目的时候又遇到了验证码倒计时的需求,发现这个功能还是挺实用的,所以就想着总结一下,下面这篇文章主要给大家介绍了关于利用Angular.js如何实现获取验证码倒计时按钮的简单方法,需要的朋友可以参考借鉴,...

    C# 使用AspriseOCR.dll实现验证码识别

    验证码(Captcha)基于十道安全栅栏, 为网页、App、小程序开发者打造立体、全面的人机验证,最大程度地保护注册登录、活动秒杀、点赞发帖、数据保护等各大场景下的业务...总结 本文演示了,C#使用AspriseOCR.dll,实

    谷歌kaptcha图片验证码的使用(图文详解附源码)

    验证码在很多地方都会使用到,本分享是自己在做验证码功能的时候总结的一些经验,是基于谷歌kaptcha来做的,验证码的效果是,可以自定义字符范围,可以自定义背景效果,自定义字体等。总之,根据参数,都可以实现...

    js点击文本框后才加载验证码实例代码

    下面作者也总结了一篇关于如何利用js实现点击文本框然后再加载验证码的效果的。 废话不多说了,下面是具体的实现代码。 &lt;html&gt; &lt;head&gt; &lt;meta http-equiv="Content-Type" content="text/html; ...

    JS实用的密码强度提示及验证码(不需要刷新)

    有玩过动网的人应该知道它在注册和登录页中都有验证码这一项,这验证码还有个功能:当数字不是很清晰时你可以用左键...以前我专门针对这个研究了好久,查阅了资料,后来总结成一篇文章叫"script调用asp实现过程",有兴

    C#验证码识别基础方法实例分析

    主要介绍了C#验证码识别基础方法实例分析,较为详细的总结了C#验证码的实现思路及具体步骤,并对实现思路进行了总结归纳,具有很好的实用价值,需要的朋友可以参考下

    laravel5.4生成验证码的实例讲解

    总结:本篇文章介绍使用gregwar/captcha实现验证码的具体操作步骤,以及可能遇到的问题和解决办法。 操作步骤: 1, 在laravel5.4项目根目录下找到 composer.json 这个文件, 添加 “gregwar/captcha”: “1.*” 到...

    Android拆轮子系列之写验证码控件的方法

    别急下面我就一步一步的教你实现。 用到的知识点总结: 1.Canvas和pint的使用,我们用它画点,线,字 2.View的基本用法 其实做这个东西还是很简单的,总体思路步骤如下: 1.准备一个Canvas。 2.向Canvas里面画几条...

    PHP使用Curl实现模拟登录及抓取数据功能示例

    具体实现的流程如下(个人总结): 1. 首先需要对相应的登录页面的html源代码进行分析,获得一些必要的信息: (1)登录页面的地址; (2)验证码的地址; (3)登录表单需要提交的各个字段的名称和提交方式; (4)...

Global site tag (gtag.js) - Google Analytics