好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > canvas基礎之圖形驗證碼的示例

canvas基礎之圖形驗證碼的示例

熱門標簽:農村住宅地圖標注 漳州人工外呼系統排名 中紳電銷智能機器人 濟南辦理400電話 ai電銷機器人連接網關 跟電銷機器人做同事 鄭州電銷外呼系統違法嗎 威海營銷外呼系統招商 鶴壁手機自動外呼系統怎么安裝

在通常的登錄界面我們都可以看到驗證碼,驗證碼的作用是檢測是不是人在操作,防止機器等非人操作,防止數據庫被輕而易舉的攻破。

驗證碼一般用PHP和java等后端語言編寫;

但是在前端,用canva或者SVG也可以繪制驗證碼;

直接上干貨:

<!DOCTYPE html>
<html>

    <head>
        <meta charset="UTF-8">
        <title></title>
        <style type="text/css">
            canvas {
                border: 1px solid red;
            }
        </style>
    </head>

    <body>
        <canvas id="myCanvas" width="100" height="40">
            您的瀏覽器不支持canvas
        </canvas>
    </body>
    <script type="text/javascript">
        var myCanvas = document.getElementById("myCanvas");
        var context = myCanvas.getContext("2d");
        //隨機字符(透明度)(大小隨機,位置隨機);
        var strStore = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
        //隨機函數
        function roundNum(min, max) {
            return parseInt(Math.random() * (max - min) + min);
        }
        //文字內容部分:
        var str = "";
        for(var i = 0; i < 5; i++) {
            context.beginPath();
            //隨機顏色(淺色:RGB - 200~250)
            var color = `rgb(${roundNum(0,255)},${roundNum(0,255)},${roundNum(0,255)})`;
            context.fillStyle = color;
            context.font = roundNum(20,30)+"px Arial";
            context.textAlign = "center";
            str = strStore[roundNum(0,strStore.length)];
            context.fillText(str, 10 + 18 * i, roundNum(20,35));
        }

        //10個左右的隨機(長度隨機,位置隨機),干擾線
        for(var j = 0; j < roundNum(5, 10); j++) {
            context.beginPath();
            var color = `rgb(${roundNum(0,255)},${roundNum(0,255)},${roundNum(0,255)})`;
            context.strokeStyle = color;
            context.moveTo(roundNum(0, 100), roundNum(0, 40));
            context.lineTo(roundNum(0, 100), roundNum(0, 40));
            context.stroke();
        }

        //干擾項:10個左右的隨機(半徑隨機,位置隨機),干擾圓
        for(var j = 0; j < roundNum(5, 10); j++) {
            context.beginPath();
            context.fillStyle = color;
            context.arc(roundNum(0, 100), roundNum(0, 40), roundNum(0, 5), Math.PI * 2 / (roundNum(1, 360)), Math.PI * 2 / (roundNum(1, 360)));
            context.fill();
        }
        
    </script>

</html>

結果如圖:

至于要拿來咋用,就看大家高興了。想怎么整這么整。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

標簽:紅河 文山 甘南 咸陽 萍鄉 蘇州 營口 惠州

巨人網絡通訊聲明:本文標題《canvas基礎之圖形驗證碼的示例》,本文關鍵詞  canvas,基礎,之,圖形,驗證,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《canvas基礎之圖形驗證碼的示例》相關的同類信息!
  • 本頁收集關于canvas基礎之圖形驗證碼的示例的相關信息資訊供網民參考!
  • 推薦文章