验证码模块化安装

最近在完成一个基于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";
    }

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

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