佳木斯湛栽影视文化发展公司

主頁(yè) > 知識(shí)庫(kù) > canvas基礎(chǔ)之圖形驗(yàn)證碼的示例

canvas基礎(chǔ)之圖形驗(yàn)證碼的示例

熱門標(biāo)簽:檢查注冊(cè)表項(xiàng) 使用U盤裝系統(tǒng) 網(wǎng)站建設(shè) 硅谷的囚徒呼叫中心 美圖手機(jī) 百度競(jìng)價(jià)點(diǎn)擊價(jià)格的計(jì)算公式 智能手機(jī) 阿里云

在通常的登錄界面我們都可以看到驗(yàn)證碼,驗(yàn)證碼的作用是檢測(cè)是不是人在操作,防止機(jī)器等非人操作,防止數(shù)據(jù)庫(kù)被輕而易舉的攻破。

驗(yàn)證碼一般用PHP和java等后端語(yǔ)言編寫;

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

直接上干貨:

<!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");
        //隨機(jī)字符(透明度)(大小隨機(jī),位置隨機(jī));
        var strStore = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
        //隨機(jī)函數(shù)
        function roundNum(min, max) {
            return parseInt(Math.random() * (max - min) + min);
        }
        //文字內(nèi)容部分:
        var str = "";
        for(var i = 0; i < 5; i++) {
            context.beginPath();
            //隨機(jī)顏色(淺色: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個(gè)左右的隨機(jī)(長(zhǎng)度隨機(jī),位置隨機(jī)),干擾線
        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();
        }

        //干擾項(xiàng):10個(gè)左右的隨機(jī)(半徑隨機(jī),位置隨機(jī)),干擾圓
        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>

結(jié)果如圖:

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

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

標(biāo)簽:黃山 山南 湖北 煙臺(tái) 懷化 通遼 賀州 湘潭

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《canvas基礎(chǔ)之圖形驗(yàn)證碼的示例》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    银川市| 论坛| 从化市| 任丘市| 崇文区| 子洲县| 宁乡县| 海安县| 北安市| 勃利县| 鞍山市| 八宿县| 天长市| 德令哈市| 犍为县| 扎囊县| 宁晋县| 全椒县| 连江县| 东兰县| 永昌县| 宜都市| 黄平县| 绥阳县| 格尔木市| 内丘县| 濉溪县| 临城县| 民丰县| 贵定县| 武义县| 丹东市| 九龙城区| 松原市| 朔州市| 合江县| 沅江市| 五台县| 西华县| 龙川县| 左云县|