登录加入验证码功能

刚才网吧没机子,我把一个小学生机子下了 ,我强行上机了。、他说要把我头按在键盘上,逗逼,哈哈哈哈哈,就凭
shsjxhjsnwndkkclswkwjksjhskxkckxkskwnnncmcbsb

以下代码,均可以粘贴复制到任何项目中使用。

登录+验证码。

验证码生成是单独的一个servlet,通过web.xml进行拦截。

先贴web.xml配置代码,很简单。

	<servlet>
		<servlet-name>/CheckCode</servlet-name>
		<servlet-class>com.wswhr.LoginServer.servlet.CheckCode</servlet-class>
	</servlet>
	<servlet-mapping>
		<servlet-name>/CheckCode</servlet-name>
		<url-pattern>/CheckCode</url-pattern>
	</servlet-mapping>

然后,是这个checkCode的代码。

package com.wswhr.LoginServer.servlet;

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 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;

//import cn.com.daxtech.framework.security.UidPwdAuthenticationFilter;

@SuppressWarnings("serial")
public class CheckCode extends HttpServlet

{
	private static int WIDTH = 60;
	private static int HEIGHT = 20;

	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		HttpSession session = request.getSession();
		response.setContentType("image/jpeg");
		ServletOutputStream sos = response.getOutputStream();
		// 设置浏览器不要缓存此图片
		response.setHeader("Pragma", "No-cache");
		response.setHeader("Cache-Control", "no-cache");
		response.setDateHeader("Expires", 0);

		// 创建内存图象并获得其图形上下文
		BufferedImage image = new BufferedImage(WIDTH, HEIGHT,
				BufferedImage.TYPE_INT_RGB);
		Graphics g = image.getGraphics();

		// 产生随机的认证码
		char[] rands = generateCheckCode();
		// 产生图像
		drawBackground(g);
		drawRands(g, rands);
		// 结束图像 的绘制 过程, 完成图像
		g.dispose();
		// 将图像输出到客户端
		ByteArrayOutputStream bos = new ByteArrayOutputStream();
		ImageIO.write(image, "JPEG", bos);
		byte[] buf = bos.toByteArray();
		response.setContentLength(buf.length);
		// 下面的语句也可写成: bos.writeTo(sos);
		sos.write(buf);
		bos.close();
		sos.close();
		// 将当前验证码存入到 Session 中
		session.setAttribute("validateCode", new String(rands));
		//session.setAttribute(UidPwdAuthenticationFilter.VALIDATE_CODE, new String(rands));
		// 直接使用下面的代码将有问题, Session 对象必须在提交响应前获得
		//request.getSession().setAttribute("check_code",new String(rands));
	}

	private char[] generateCheckCode() {
		// 定义验证码的字符表
		String chars = "2345678abcdefghjkmnprstuwxz";
		char[] rands = new char[4];
		for (int i = 0; i < 4; i++) {
			int rand = (int) (Math.random() * chars.length());
			rands[i] = chars.charAt(rand);
		}
		return rands;
	}

	private void drawRands(Graphics g, char[] rands) {
		g.setColor(Color.BLACK);
		g.setFont(new Font(null, Font.ITALIC | Font.BOLD, 18));
		// 在不同的高度上输出验证码的每个字符
		g.drawString("" + rands[0], 1, 17);
		g.drawString("" + rands[1], 16, 15);
		g.drawString("" + rands[2], 31, 18);
		g.drawString("" + rands[3], 46, 16);
		// System.out.println(rands);
	}

	private void drawBackground(Graphics g) {
		// 画背景
		g.setColor(new Color(0xDCDCDC));
		g.fillRect(0, 0, WIDTH, HEIGHT);
		// 随机产生 120 个干扰点
		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);
		}
	}
}

最后,是使用验证码的jsp代码,以及JS代码

<label>
														<span>
															<span class="lbl input-icon input-icon-right">
																<input id="validateCode" name="validateCode" type="text" class="span12" maxlength="15" placeholder="验证码" />
																<i class="icon-retweet"></i>
															</span>
															<span class="lbl">
																<img src="${ctx}/CheckCode" id="yzmPic" onclick="reloadCheckCode()" style="cursor:pointer;" title="点击刷新验证码"/>
																<a href="#" onclick="reloadCheckCode()" data-action="reload">
																	<i class="icon-refresh"></i>
																</a>
															</span>
														</span>
													</label>

js代码如下:

function reloadCheckCode(){
	document.getElementById("yzmPic").src = $("#ctx").val()+"/CheckCode?r=" + new Date().getTime();
}

最后的  r=  new Date().getTime();    相当于,生成一个随机数,避免缓存, 否则,在servlet中,会一直生成同一个验证码(并不是没有生成,而是一直生成同一个。)

<input type="hidden" id="ctx" value="${pageContext.request.contextPath}"/>
时间: 2024-09-19 09:02:34

登录加入验证码功能的相关文章

SSO单点登录系列5:cas单点登录增加验证码功能完整步骤

详见 http://blog.csdn.net/ae6623/article/details/8919718 环境: server端:cas-server-core-3.5.2.jar.cas-client-core-3.2.1.jar client端:cas-client-core-3.1.3.jar.http屏蔽了https后的casclient.jar(http://blog.csdn.net/dengtaowei/article/details/7039399)   之前做的界面里面缺少

登录界面-delphi 实现验证码功能

问题描述 delphi 实现验证码功能 本人在用delphi做一个登录界面,想实现验证码的功能.但在百度上没找到源码.求源码连接地址或源码,谢谢. 解决方案 很久之前做过一个,源码找不到了,可以提供一个思路: 1.将待生成验证码的字符分解,对每一个字符进行以下处理: 2.将当前字符使用随机颜色(白色除外)输出到一个大小固定的矩形图像中(使用textout函数) 3.将此图像进行随机角度(可以在一定范围内)旋转(可能会用到图像处理中的rotate函数) 4.将此图像复制且追加到目标图像中的尾部(可

PHP编写登录验证码功能 附调用方法_php技巧

本文实例为大家分享了一个PHP写的登录验证码功能,供大家参考,具体内容如下  ShowKey.php <?php session_start(); //设置COOKIE或Session function esetcookie($name,$str,$life=0){ //本函数将字符串 str 全部变小写字符串使验证码输入不区分大小写----在提交表单进行session比较同样需要次函数转化 $_SESSION[$name]=strtolower($str); } //获取随机字符 此函数区分字

通过PHP来实现登录验证码功能

通过PHP来实现登录验证码功能:<?phpsession_start();session_register("login_check_number");//昨晚看到了chianren上的验证码效果,就考虑了一下,用PHP的GD库完成了类似功能//先成生背景,再把生成的验证码放上去$img_height=120; //先定义图片的长.宽$img_width=40;if($HTTP_GET_VARS["act"]== "init"){ //sr

Yii框架实现的验证码、登录及退出功能示例

本文实例讲述了Yii框架实现的验证码.登录及退出功能.分享给大家供大家参考,具体如下: 捣鼓了一下午,总算走通了,下面贴出代码. Model <?php class Auth extends CActiveRecord { public static function model($className = __CLASS__) { return parent::model($className); } public function tableName() { return '{{auth}}'

用PHP实现验证码功能

验证码 目前,不少网站为了防止用户利用机器人自动注册.登录.灌水,都采用了 验证码技术.所谓验证码,就是将一串随机产生的数字或符号,生成一幅图片, 图片里加上一些干扰象素(防止OCR),由用户肉眼识别其中的验证码信息,输 入表单提交网站验证,验证成功后才能使用某项功能. 我们这里展示了如何编写PHP程序实现验证码功能: 代码一: <?php /* * Filename: authpage.php * Author: hutuworm * Date: 2003-04-28 * @Cop

java-请问,12306登录时验证码的实现方法是什么?或者实现思路,谢谢!

问题描述 请问,12306登录时验证码的实现方法是什么?或者实现思路,谢谢! 最近做登录的验证码,需要实现的效果跟12306网站登录时的验证一样.请问如何实现该功能.自己在下面百度了一下,这方面的资料感觉挺少的,只看到一个说用Python的,但是我没用过Python,想请问一下有没有其他的实现方法.谢谢了 解决方案 现在好像换成几个图片,一个名词,让你识别哪个是哪个.难度不是一般大.建议你使用人工打码. 解决方案二: Python的PIL库实现验证码图片http://blog.csdn.net/

用PHP实现验证码功能_php基础

作者:hutuworm 来源:糊涂馋寺 目前,不少网站为了防止用户利用机器人自动注册.登录.灌水,都采用了 验证码技术.所谓验证码,就是将一串随机产生的数字或符号,生成一幅图片, 图片里加上一些干扰象素(防止OCR),由用户肉眼识别其中的验证码信息,输 入表单提交网站验证,验证成功后才能使用某项功能. 我们这里展示了如何编写PHP程序实现验证码功能: 代码一:      <?php    /*     *   Filename:    authpage.php     *   Aut

dedeCms登录后台验证码错误解决办法

dedeCms登录后台验证码错误解决办法 1.查阅资料后得知,session没有清除,去data/session目录下,将除index.html以外文件全部删除就可以了. 2.如果还是不行,看session是否有写入权限,如果没有的话,给"internet来宾账户"添加写入权限,Linux的话,目录权限设置为"777". 3.另外就是去掉验证码功能 1.打开 login.php教程 找到:if($validate==" || $validate != $s