真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

JavaScript中怎么生成隨機(jī)驗(yàn)證碼

這篇文章將為大家詳細(xì)講解有關(guān)JavaScript中怎么生成隨機(jī)驗(yàn)證碼,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。

創(chuàng)新互聯(lián)專(zhuān)注于企業(yè)成都全網(wǎng)營(yíng)銷(xiāo)推廣、網(wǎng)站重做改版、舒城網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、H5場(chǎng)景定制、成都商城網(wǎng)站開(kāi)發(fā)、集團(tuán)公司官網(wǎng)建設(shè)、成都外貿(mào)網(wǎng)站建設(shè)、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁(yè)設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性?xún)r(jià)比高,為舒城等各大城市提供網(wǎng)站開(kāi)發(fā)制作服務(wù)。

利用canvas制作一個(gè)隨機(jī)驗(yàn)證碼:

1、clearRect:context.clearRect(x,y,width,height);清空給定矩形內(nèi)的指定像素

2、fillStyle:設(shè)置畫(huà)筆的顏色

3、rotate(deg):旋轉(zhuǎn)角度,以弧度旋轉(zhuǎn)(弧度=degrees*Math.PI/180 )

4、translate(): 方法重新映射畫(huà)布上的位置

5、Math.random():獲取0-1之間的一個(gè)隨機(jī)數(shù),不包含1

JavaScript中怎么生成隨機(jī)驗(yàn)證碼




  
    
    canvas隨機(jī)驗(yàn)證碼
  
  
    
  
  
    var myCanvas = document.querySelector("#canvas");
    var blur = myCanvas.getContext("2d");
    // 當(dāng)點(diǎn)擊畫(huà)布時(shí)創(chuàng)建一個(gè)新的路徑
    // 驗(yàn)證碼封裝
    myCanvas.onclick = function() {
      // 實(shí)現(xiàn)點(diǎn)擊畫(huà)布創(chuàng)建一個(gè)新的驗(yàn)證碼
      blur.clearRect(0,0,100,40);
      verify();
    }
    verify();
    function verify() {
      // 繪制矩形框
      // blur.strokeRect(0,0,100,40);
      // 隨機(jī)驗(yàn)證碼
      var arr = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "s", "t", "u",
        "v", "w", "x", "y", "z", "A", "B", "C", "D", "F", "G", "H", "I", "J", "K", "L", "S", "T", "U", "V", "W", "X", "Y",
        "Z"
      ];
      // 顯示四位數(shù)的驗(yàn)證碼
      for (var i = 0; i < 4; i++) {
        var x = 20 + 20 * i;
        var y = 20 + 10 * Math.random();
        // console.log(x,y);
        // 在數(shù)組中獲取到隨機(jī)的索引整數(shù)
        var index = Math.floor(Math.random() * arr.length);
        // 通過(guò)隨機(jī)的索引獲取到隨機(jī)的元素
        var texts = arr[index];
        // 設(shè)置驗(yàn)證碼的相關(guān)樣式
        blur.font = "bold 20px 微軟雅黑";
        blur.fillStyle = textColor();
        // 畫(huà)布旋轉(zhuǎn)顯示
        // translate() 方法重新映射畫(huà)布上的位置
        blur.translate(x, y);
        // 將畫(huà)布旋轉(zhuǎn),旋轉(zhuǎn)角度,以弧度旋轉(zhuǎn)(弧度=degrees*Math.PI/180 )
        var deg = 90 * Math.random() * Math.PI / 180;
        blur.rotate(deg); //
        blur.fillText(texts, 0, 0);
        // 將畫(huà)布映射返回原來(lái)的位置
        blur.rotate(-deg);
        blur.translate(-x, -y);
      }
      
      // 制作驗(yàn)證碼的干擾線(xiàn)制作
      for(var i=0;i<6;i++){
        blur.beginPath();
        blur.moveTo(Math.random()*100,Math.random()*40);
        blur.lineTo(Math.random()*100,Math.random()*40);
        // 設(shè)置干擾線(xiàn)的顏色
        blur.strokeStyle=textColor();
        blur.stroke();
      }
      // 制作驗(yàn)證碼的干擾圓點(diǎn)
      for(var i=0;i<20;i++){
        blur.beginPath();
        var x=Math.random()*100;
        var y=Math.random()*100;
        blur.moveTo(x,y);
        blur.lineTo(x+1,y+1);
        // 設(shè)置干擾線(xiàn)的顏色
        blur.strokeStyle=textColor();
        blur.stroke();
      }
    }
    // 獲取隨機(jī)顏色封裝
    function textColor(){
      var red=Math.floor(Math.random()*256);
      var green=Math.floor(Math.random()*256);
      var blue=Math.floor(Math.random()*256);
      return "rgb("+red+","+green+","+blue+")";
    }
  
x要清除的矩形左上角的 x 坐標(biāo)
y要清除的矩形左上角的 y 坐標(biāo)
width要清除的矩形的寬度,以像素計(jì)
height要清除的矩形的高度,以像素計(jì)

關(guān)于JavaScript中怎么生成隨機(jī)驗(yàn)證碼就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。


當(dāng)前標(biāo)題:JavaScript中怎么生成隨機(jī)驗(yàn)證碼
文章網(wǎng)址:http://weahome.cn/article/jgiscp.html

其他資訊

在線(xiàn)咨詢(xún)

微信咨詢(xún)

電話(huà)咨詢(xún)

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部