vue+SSM驗證碼實現

来源:https://www.cnblogs.com/HannahLihui/archive/2018/12/06/10075354.html
-Advertisement-
Play Games

源碼:https://github.com/HannahLihui/StudentManager-SSM/tree/master/SSM-git/StudentManager-SSM-master 1.前端有一個img引入,這裡this.src=this.src+'?'就會調用映射到後臺的check ...


源碼:https://github.com/HannahLihui/StudentManager-SSM/tree/master/SSM-git/StudentManager-SSM-master

1.前端有一個img引入,這裡this.src=this.src+'?'就會調用映射到後臺的checkCode

<el-form-item prop="code">

                                 <img src="checkCode" alt="" width="100" height="32" class="passcode" style="height:43px;cursor:pointer; float:left;"onclick="this.src=this.src+'?'">>

                              <el-input v-model="login.code" placeholder="請輸入驗證碼" style="width: 100px; float:center"  auto-complete="off"></el-input>

</el-form-item>

2.後臺返回一個圖片

 1 @RequestMapping(value="/checkCode")
 2 
 3 public void checkCode(HttpServletRequest request, HttpServletResponse response)
 4 
 5             throws ServletException, IOException {
 6 
 7 //設置相應類型,告訴瀏覽器輸出的內容為圖片
 8 
 9         response.setContentType("image/jpeg");
10 
11         HttpSession session = request.getSession();
12 
13         //設置響應頭信息,告訴瀏覽器不要緩存此內容
14 
15         response.setHeader("pragma", "no-cache");
16 
17         response.setHeader("Cache-Control", "no-cache");
18 
19         response.setDateHeader("Expire", 0);
20 
21         RandomValidateCode randomValidateCode = new RandomValidateCode();
22 
23         try {
24 
25             randomValidateCode.getRandcode(request, response);
26 
27         } catch (Exception e) {
28 
29             e.printStackTrace();
30 
31         }
32 
33 }

3.是通過RandomValidateCode生成隨機字元串以及圖片。下麵這個代碼可以直接用一下。來自博客:

https://blog.csdn.net/weidong_y/article/details/80630383

public class RandomValidateCode {

public static final String RANDOMCODEKEY = "randomcode_key";//放到session中的key

    private Random random = new Random();

    private String randString = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";//隨機產生的字元串



    private int width = 80;//圖片寬

    private int height = 26;//圖片高

    private int lineSize = 40;//干擾線數量

    private int stringNum = 4;//隨機產生字元數量



    /**

    * 生成隨機圖片

    */

    public void getRandcode(HttpServletRequest request,

            HttpServletResponse response) {

        HttpSession session = request.getSession();

        //BufferedImage類是具有緩衝區的Image類,Image類是用於描述圖像信息的類

        BufferedImage image = new BufferedImage(width,height,BufferedImage.TYPE_INT_BGR);

        //產生Image對象的Graphics對象,改對象可以在圖像上進行各種繪製操作

        Graphics g = image.getGraphics();

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

        g.setFont(new Font("Times New Roman",Font.ROMAN_BASELINE,18));

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

        //繪製干擾線

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

            drowLine(g);

        }

        //繪製隨機字元

        String randomString = "";

        for(int i=1;i<=stringNum;i++){

            randomString=drowString(g,randomString,i);

        }

        session.removeAttribute(RANDOMCODEKEY);



        session.setAttribute(RANDOMCODEKEY, randomString);





        g.dispose();

        try {

        //將記憶體中的圖片通過流動形式輸出到客戶端

            ImageIO.write(image, "JPEG", response.getOutputStream());

        } catch (Exception e) {

            e.printStackTrace();

        }

    }

    /*

    * 獲得字體

    */

    private Font getFont(){

        return new Font("Fixedsys",Font.CENTER_BASELINE,18);

    }

    /*

    * 獲得顏色

    */

    private Color getRandColor(int fc,int bc){

        if(fc > 255)

            fc = 255;

        if(bc > 255)

            bc = 255;

        int r = fc + random.nextInt(bc-fc-16);

        int g = fc + random.nextInt(bc-fc-14);

        int b = fc + random.nextInt(bc-fc-18);

        return new Color(r,g,b);

    }



    /*

    * 繪製字元串

    */

    private String drowString(Graphics g,String randomString,int i){

        g.setFont(getFont());

        g.setColor(new Color(random.nextInt(101),random.nextInt(111),random.nextInt(121)));

        String rand = String.valueOf(getRandomString(random.nextInt(randString.length())));

        randomString +=rand;

        g.translate(random.nextInt(3), random.nextInt(3));

        g.drawString(rand, 13*i, 16);

        return randomString;

    }

    /*

    * 繪製干擾線

    */

    private void drowLine(Graphics g){

        int x = random.nextInt(width);

        int y = random.nextInt(height);

        int xl = random.nextInt(13);

        int yl = random.nextInt(15);

        g.drawLine(x, y, x+xl, y+yl);

    }

    /*

    * 獲取隨機的字元

    */

    public String getRandomString(int num){

        return String.valueOf(randString.charAt(num));

    }

}

4.至於驗證驗證碼就是我弄了半天的東西。。。

因為我不太會vue 然後寫前端研究了會會才知道它是怎麼用的。然後我開始是想從前端拿到後端的session,但是vue這個是html頁面,不能<%@ %>引入java代碼,然後我又試了一下js的ajax引入,但是報錯,vue框架我也不太懂。。然後還是交給後端驗證嘛。

然後就很簡單了,從login那裡驗證,提交的時候多了一個驗證碼,但是我覺得這樣做其實是不太好的,因為驗證碼跟登錄一起驗證,有點耗時,分開比較好。

submitForm(login) {

            this.$refs[login].validate((valid) => {

                if (valid) {

                    this.loadings(); //載入動畫

                // window.alert(this.login.code);



                    this.$http.post('/login', {

                        username: this.login.username,

                        password: this.login.password,

                        remember: this.login.remember,

                        code:this.login.code

                    }).then(result => {

                    //window.alert(result);



                        // 判斷用戶是否登錄成功,後端返回JSON格式數據,不然娶不到數據

                        if (result.body.success) {

                        alert("success");

                            window.location.href = "/listStudentInfo";

                            this.loading.close(); //關閉動畫載入

                        } else {



                            // 彈出錯誤信息框

                            this.$emit(

                                'submit-form',

                                this.$message({

                                    message:result.body.message,

                                    type: 'warning',

                                    duration: 6000

                                }),

                            );

                            // 清空表單狀態

                            this.$refs[login].resetFields();

                        }

                    });

          }

                else {



                    this.$emit(

                        'submit-form',

                        this.$message({

                            message: '輸入信息有誤!',

                            type: 'warning',

                            duration: 6000

                        }),

                    );

                    return false;

                }

            });

        },
@RequestMapping("/login")

public Result Login( @RequestParam(value = "username", required = false) String username,

            @RequestParam(value = "password", required = false) String password,

            @RequestParam(value = "remember", required = false) String remember,

            @RequestParam(value = "code", required = false) String code,

            HttpServletRequest request

            ) {

String error = null;

HttpSession session = request.getSession();

  System.out.println(code);

  //System.out.println(session.getAttribute( RandomValidateCode.RANDOMCODEKEY));

if(username==null||session.getAttribute( RandomValidateCode.RANDOMCODEKEY).equals(code)) {

//System.out.println("code 有問題");

return new Result(false, error);

}

//System.out.println(password);

//System.out.println("調試");

Subject subject=SecurityUtils.getSubject();

UsernamePasswordToken token=new UsernamePasswordToken(username,password);

if (remember != null) {

            if (remember.equals("true")) {

                //說明選擇了記住我

                token.setRememberMe(true);

            } else {

                token.setRememberMe(false);

            }

        } else {

            token.setRememberMe(false);

        }

System.out.println(token.isRememberMe());

try {

subject.login(token);

Result re=new Result(true, "success");

return new Result(true,error);

} catch (UnknownAccountException e) {

      System.out.println( "登陸出錯");

        error = "用戶賬戶不存在,錯誤信息:" + e.getMessage();

    }catch (IncorrectCredentialsException ex) {

    System.out.println( "用戶名和密碼不匹配");

    error = "用戶名或密碼錯誤,錯誤信息:" + ex.getMessage();

    }catch (AuthenticationException e) {

    System.out.println( "其他的登陸錯誤");

    error = "錯誤信息:" + e.getMessage();



    }

return new Result(false, error);

}

5.session

簡單說一下我理解的session和cookie的區別吧,session是保存在服務端的,cookie是保存在客戶端的,就是本地會有一個文件夾專門保存cookie。cookie主要是為了保存用戶狀態嘛,因為http是無狀態的連接,每次連接完就不會知道下一次是不是同一個用戶。但是保存用戶信息在很多應用場景中都是必要的。而session比cookie更加安全,因為session信息保存在服務端的,不容易被盜用。所以重要登陸信息還是應該保存在session上。而且服務端能夠保存的session比較大,而單個cookie一般不超過20k.

session是怎麼保存用戶信息的呢?就是一個用戶有一個sessionId,通過sessionId保存用戶信息。

session的使用:

session.setAttribute("key","value");

session.getAttribute("key");

6.登陸界面

 

 第一次用博客園寫技術博客,以前都是在簡書,感覺格式功能比較強,編輯起來看著舒服,有可能以後就在這裡寫博客了,畢竟程式員的地方嘛

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、配置MySQL資料庫 MySQL的官網www.mysql.com 1、解壓綠色版mysql,並改名為mysql5.7,如下圖 對比一下下圖5.6以前的版本,少data目錄(存放數據)和my-default.ini文件(配置信息) 二、安裝服務 1、運行cmd(管理員版本,否則沒有許可權),如下圖 ...
  • 一、發佈 上面有多種發佈方式,這裡我選擇事物發佈,具體區別請自行百度。 點擊下一步、然後繼續選擇需要發佈的對象。 如果需要篩選發佈的數據點擊添加。 根據自己的計劃選擇發佈的時間。 點擊安全設置,設置代理信息。 最後單擊完成系統會自動創建發佈。 如出現上述警告,則需要在電腦的服務中打開 SQL Se ...
  • 上面這條sql語句,仔細看一下,揣摩出思路也不難,大概也分為3步來理解: 根據條件,刪除原表中id大於t2中id的記錄 ...
  • create table,show tables,describe table,DROP TABLE,ALTER TABLE ,怎麼使用? ...
  • 先決條件 先運行mongodb肯定是必須的,然後導入以下包: MongoClient MongoClient()實例表示到資料庫的連接池; 你將只需要MongoClient類的一個實例,即使有多個線程也是一樣。 重要: 通常,您只能為給定的MongoDB部署(例如獨立,副本集或分片群集)創建一個Mo ...
  • create database ,drop database ,show Databases,use 資料庫 ,怎麼使用? ...
  • [TOC] 安裝依賴 (1)cmake是新版MySQL的編譯工具 安裝boost 如果安裝的MySQL5.7及以上的版本,在編譯安裝之前需要安裝boost,因為高版本mysql需要boots庫的安裝才可以正常運行。否則會報 錯誤 1. 切換到 目錄,然後在這個目錄下下載boost MySQL5.7. ...
  • 大數據已經成為時代發展的趨勢,很多人紛紛選擇學習大數據,想要進入大數據行業。大數據技術體系龐大,包括的知識較多,系統的學習大數據可以讓你全面掌握大數據技能。學習大數據需要掌握哪些知識?我還是要推薦下我自己創建的大數據資料分享群142973723,這是大數據學習交流的地方,不管你是小白還是大牛,小編都 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...