首頁 >後端開發 >php教程 >php驗證碼的實例與思路分析

php驗證碼的實例與思路分析

*文
*文原創
2017-12-28 15:41:161664瀏覽

本文主要介紹了php驗證碼的製作想法和實作方法,我們不能盲目的去實作php產生驗證碼,更應該了解php驗證碼的基本原理,真正的掌握php驗證碼的實作方法,需要的朋友可以參考下。希望對大家有幫助。

一、製作想法

由於註冊的時候常常會用到註冊碼來防止機器惡意註冊,這裡我發表一個產生png圖片驗證碼的基本圖像,簡單的思路分析:

1、產生一張png的圖片
2、為圖片設定背景色
3、設定字體顏色和樣式
4、產生4位數的隨機的驗證碼
5、把產生的每個字元調整旋轉角度和位置畫到png圖片上
6、加入雜訊和乾擾線防止註冊機器分析原始圖片來惡意註冊
7.輸出圖片
8、釋放圖片所佔記憶體

二、實作方法

##authcode.php檔案



<?php
    session_start ();
    header ( &#39;Content-type: image/png&#39; );
    //创建图片
    $im = imagecreate($x=130,$y=45 );
    $bg = imagecolorallocate($im,rand(50,200),rand(0,155),rand(0,155)); //第一次对 imagecolorallocate() 的调用会给基于调色板的图像填充背景色
    $fontColor = imageColorAllocate ( $im, 255, 255, 255 );  //字体颜色
    $fontstyle = &#39;rock.ttf&#39;;          //字体样式,这个可以从c:\windows\Fonts\文件夹下找到,我把它放到和authcode.php文件同一个目录,这里可以替换其他的字体样式
    //产生随机字符
    for($i = 0; $i < 4; $i ++) {
        $randAsciiNumArray     = array (rand(48,57),rand(65,90));
        $randAsciiNum         = $randAsciiNumArray [rand ( 0, 1 )];
        $randStr             = chr ( $randAsciiNum );
        imagettftext($im,30,rand(0,20)-rand(0,25),5+$i*30,rand(30,35),$fontColor,$fontstyle,$randStr);
        $authcode            .= $randStr; 
    }
    $_SESSION[&#39;authcode&#39;]    = $randFourStr;//用户和用户输入的验证码做比较
    //干扰线
    for ($i=0;$i<8;$i++){
        $lineColor    = imagecolorallocate($im,rand(0,255),rand(0,255),rand(0,255));
        imageline ($im,rand(0,$x),0,rand(0,$x),$y,$lineColor);
    }
    //干扰点
    for ($i=0;$i<250;$i++){
        imagesetpixel($im,rand(0,$x),rand(0,$y),$fontColor);
    }
    imagepng($im);
    imagedestroy($im);        
?>


效果圖:

相關推薦:

怎麼用php實作簡訊驗證碼發送

#Laravel的驗證碼庫

如何在ecshop中解決驗證碼圖片不出問題

以上是php驗證碼的實例與思路分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn