驗證碼模塊化安裝

最近在完成一個基于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閱讀 230,002評論 6 542
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,400評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事?!?“怎么了?”我有些...
    開封第一講書人閱讀 178,136評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,714評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,452評論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,818評論 1 328
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,812評論 3 446
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,997評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,552評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,292評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,510評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,035評論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,721評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,121評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,429評論 1 294
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,235評論 3 398
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,480評論 2 379

推薦閱讀更多精彩內容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,725評論 25 708
  • 發現 關注 消息 iOS 第三方庫、插件、知名博客總結 作者大灰狼的小綿羊哥哥關注 2017.06.26 09:4...
    肇東周閱讀 12,170評論 4 61
  • 玄幻加穿越,想像力無界限嗎?——評血紅《巫頌》(第一部)(上、下) 文/北風來襲 讀罷《巫頌》(第一部),不禁震驚...
    北風來襲閱讀 451評論 0 2
  • 寫了這么多天,都不知道寫什么了。 天氣轉冷,北方的天氣還是那么冷,雖然是艷陽高照,風和日麗。都是心情不是很好。 人...
    求無1824閱讀 318評論 0 0
  • 夢醒了望向窗外落葉一片兩片的隨風飛舞降落,秋天一個凋零的季節。 有些時候我還是會期待在我這平凡的日子里會遇見一直期...
    遇見泡沫閱讀 271評論 0 0