验证码模块化安装

最近在完成一个基于SSH(struts+spring+hibernate)组合框架集成的J2EE商城项目

在完成登录注册时需要集成验证码功能,所以记下模块化集成验证码的步骤:

1.创建一个画布

2.设置一个画笔

3.生成四个随机的字母或数字

4.将四个字母或数字写到图片上.

5.将图片输出到浏览器.

*编写一个Action类,生成验证码

创建一个CheckImgAction类


package cn.itcast.shop.user;

import java.awt.Color;

import java.awt.Font;

import java.awt.Graphics;

import java.awt.Graphics2D;

import java.awt.image.BufferedImage;

import java.util.Random;

import javax.imageio.ImageIO;

import org.apache.struts2.ServletActionContext;

import com.opensymphony.xwork2.ActionSupport;

/**

* 验证码程序

* @author 喻可伟

*

*/

public class CheckImgAction extends ActionSupport {

@Override

public String execute() throws Exception {

int width = 120;

int height = 30;

// 步骤一 绘制一张内存中图片

BufferedImage bufferedImage = new BufferedImage(width, height,

BufferedImage.TYPE_INT_RGB);

// 步骤二 图片绘制背景颜色 ---通过绘图对象

Graphics graphics = bufferedImage.getGraphics();// 得到画图对象 --- 画笔

// 绘制任何图形之前 都必须指定一个颜色

graphics.setColor(getRandColor(200, 250));

graphics.fillRect(0, 0, width, height);

// 步骤三 绘制边框

graphics.setColor(Color.WHITE);

graphics.drawRect(0, 0, width - 1, height - 1);

// 步骤四 四个随机数字

Graphics2D graphics2d = (Graphics2D) graphics;

// 设置输出字体

graphics2d.setFont(new Font("宋体", Font.BOLD, 18));

String words = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz1234567890";



Random random = new Random();// 生成随机数

// 定义StringBuffer

StringBuffer sb = new StringBuffer();

// 定义x坐标

int x = 10;

for (int i = 0; i < 4; i++) {

// 随机颜色

graphics2d.setColor(new Color(20 + random.nextInt(110), 20 + random

.nextInt(110), 20 + random.nextInt(110)));

// 旋转 -30 --- 30度

int jiaodu = random.nextInt(60) - 30;

// 换算弧度

double theta = jiaodu * Math.PI / 180;

// 生成一个随机数字

int index = random.nextInt(words.length()); // 生成随机数 0 到 length - 1

// 获得字母数字

char c = words.charAt(index);

sb.append(c);

// 将c 输出到图片

graphics2d.rotate(theta, x, 20);

graphics2d.drawString(String.valueOf(c), x, 20);

graphics2d.rotate(-theta, x, 20);

x += 30;

}

// 将生成的字母存入到session中

ServletActionContext.getRequest().getSession()

.setAttribute("checkcode", sb.toString());

// 步骤五 绘制干扰线

graphics.setColor(getRandColor(160, 200));

int x1;

int x2;

int y1;

int y2;

for (int i = 0; i < 30; i++) {

x1 = random.nextInt(width);

x2 = random.nextInt(12);

y1 = random.nextInt(height);

y2 = random.nextInt(12);

graphics.drawLine(x1, y1, x1 + x2, x2 + y2);

}

// 将上面图片输出到浏览器 ImageIO

graphics.dispose();// 释放资源

ImageIO.write(bufferedImage, "jpg", ServletActionContext.getResponse()

.getOutputStream());

return NONE;

}

/**

* 取其某一范围的color

*

* @param fc

*            int 范围参数1

* @param bc

*            int 范围参数2

* @return Color

*/

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

}

}

在struts.xml中配置

<!-- 配置验证码的Action -->
<action name="checkImg" class="checkImg"></action>

在applicationContext.xml中配置

<bean id="checkImg" class="cn.yiyuan.shop.user.CheckImgAction" scope="prototype"></bean>

在regist1.jsp中验证码图片的位置

src="${pageContext.request.contextPath}/checkImg.action"

到这时验证码已经可以在页面显示了,并且刷新页面可以刷新验证码的显示,但是如果要实现点击验证码图片切换验证码效果需要再写js进行切换

导入vuejs实现点击切换验证码效果

导入vue.js与app.js,主要实现在app.js里

//register.jsp img验证码标签
 @click="change()"

var vm = new Vue({
    el: '#app',
     data: {
        
     },
    //在methods对象中定义方法
    methods:{
        change:function (){
            //点击切换验证码图片
            var img = document.getElementById("checkImg");
            img.src = "${pageContext.request.contextPath}/checkImg.action?"+new Date().getTime();
            
        }
    }       
})

此时已经可以通过点击来修改验证码图片了

实现点击注册按钮提交验证码校验

在UserAction中regist方法上进行校验.

    /**
     * 前台:注册用户的方法:
     */
    @InputConfig(resultName="registInput")
    public String regist(){
        // 从session中获得存的验证码
        String checkcodeRegister = (String) ServletActionContext.getRequest().getSession().getAttribute("checkcode");
        if(checkcode == null || !checkcode.equalsIgnoreCase(checkcodeRegister)){
            this.addActionError("验证码错误!");
            return "registInput";
        }
        userService.regist(user);
        this.addActionMessage("注册成功!请去邮箱激活!");
        return "registSuccess";
    }

当你完成这一步时,恭喜你可以模块化集成验证码就已经完成了

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 196,099评论 5 462
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,473评论 2 373
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 143,229评论 0 325
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,570评论 1 267
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,427评论 5 358
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,335评论 1 273
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,737评论 3 386
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,392评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,693评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,730评论 2 312
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,512评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,349评论 3 314
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,750评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,017评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,290评论 1 251
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,706评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,904评论 2 335

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,140评论 25 707
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 11,952评论 4 60
  • 玄幻加穿越,想像力无界限吗?——评血红《巫颂》(第一部)(上、下) 文/北风来袭 读罢《巫颂》(第一部),不禁震惊...
    北风来袭阅读 427评论 0 2
  • 写了这么多天,都不知道写什么了。 天气转冷,北方的天气还是那么冷,虽然是艳阳高照,风和日丽。都是心情不是很好。 人...
    求无1824阅读 294评论 0 0
  • 梦醒了望向窗外落叶一片两片的随风飞舞降落,秋天一个凋零的季节。 有些时候我还是会期待在我这平凡的日子里会遇见一直期...
    遇见泡沫阅读 247评论 0 0