欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PHP簡單驗證碼功能機制實例詳解

 更新時間:2019年03月27日 11:07:40   作者:Zhihua_W  
這篇文章主要介紹了PHP簡單驗證碼功能機制,結(jié)合實例形式深入淺出的分析了php驗證碼的原理、實現(xiàn)步驟及相關(guān)操作技巧,需要的朋友可以參考下

本文實例講述了PHP簡單驗證碼功能機制。分享給大家供大家參考,具體如下:

網(wǎng)站的安全性是開發(fā)者不可忽視的一個問題,目前使用最多的一種可以提高網(wǎng)站安全性的方法就是使用驗證碼功能機制,有的僅僅使用一個幾位數(shù)字字母混亂的驗證碼,有的進行手機發(fā)送短信進行驗證,有的使用郵箱發(fā)送郵件進行驗證,但是這個驗證碼功能機制是如何實現(xiàn)的呢?下面就為大家詳細解釋驗證碼功能機制的實現(xiàn)思路以及簡單的實現(xiàn)方法。

1、驗證碼功能機制實現(xiàn)思路

① 常規(guī)的驗證碼實現(xiàn):

a、產(chǎn)生一張png的圖片
b、為圖片設(shè)置背景色
c、設(shè)置字體顏色和樣式
d、產(chǎn)生4位數(shù)的隨機的驗證碼
e、把產(chǎn)生的每個字符調(diào)整旋轉(zhuǎn)角度和位置畫到png圖片上
f、加入噪點和干擾線防止注冊機器分析原圖片來惡意注冊
g、輸出圖片
h、釋放圖片所占內(nèi)存
i、將驗證碼保存到session或是數(shù)據(jù)庫
j、將和輸入的驗證碼進行對比

② 短信(郵箱)驗證碼機制:

a、產(chǎn)生4-6位數(shù)的隨機的驗證碼
b、把產(chǎn)生的每個字符保存到session或是數(shù)據(jù)庫
c、將驗證碼發(fā)送到用戶的手機(郵箱)
d、用戶在規(guī)定時間內(nèi)進行輸入
e、將驗證碼從session或是數(shù)據(jù)庫中取出
f、將和輸入的驗證碼進行對比驗證

2、簡單的實現(xiàn)驗證碼功能機制

① 新建captcha.php,寫入以下代碼

<?php
/**
 * =======================================
 * Created by WeiBang Technology.
 * User: Wei ZhiHua
 * Date: 2016/10/12 0020
 * Time: 下午 4:14
 * Power: 實現(xiàn)驗證碼功能
 * =======================================
 */
//開啟session
session_start();
//創(chuàng)建一個大小為 100*30 的驗證碼
$image = imagecreatetruecolor(100, 30);
$bgcolor = imagecolorallocate($image, 255, 255, 255);
imagefill($image, 0, 0, $bgcolor);
$captch_code = '';
for ($i = 0; $i < 4; $i++) {
  $fontsize = 6;
  $fontcolor = imagecolorallocate($image, rand(0, 120), rand(0, 120), rand(0, 120));
  $data = 'abcdefghijkmnpqrstuvwxy3456789';
  $fontcontent = substr($data, rand(0, strlen($data) - 1), 1);
  $captch_code .= $fontcontent;
  $x = ($i * 100 / 4) + rand(5, 10);
  $y = rand(5, 10);
  imagestring($image, $fontsize, $x, $y, $fontcontent, $fontcolor);
}
//就生成的驗證碼保存到session
$_SESSION['authcode'] = $captch_code;
//在圖片上增加點干擾元素
for ($i = 0; $i < 200; $i++) {
  $pointcolor = imagecolorallocate($image, rand(50, 200), rand(50, 200), rand(50, 200));
  imagesetpixel($image, rand(1, 99), rand(1, 29), $pointcolor);
}
//在圖片上增加線干擾元素
for ($i = 0; $i < 3; $i++) {
  $linecolor = imagecolorallocate($image, rand(80, 220), rand(80, 220), rand(80, 220));
  imageline($image, rand(1, 99), rand(1, 29), rand(1, 99), rand(1, 29), $linecolor);
}
//設(shè)置頭
header('content-type:image/png');
imagepng($image);
imagedestroy($image);
?>

② 新建form.php,寫入以下代碼

<?php
/**
 * =======================================
 * Created by WeiBang Technology.
 * User: Wei ZhiHua
 * Date: 2016/10/12 0021
 * Time: 下午 4:14
 * Power: 實現(xiàn)驗證碼功能
 * =======================================
 */
if (isset($_REQUEST['authcode'])) {
  session_start();
  if (strtolower($_REQUEST['authcode']) == $_SESSION['authcode']) {
    echo "輸入正確!";
  } else {
    echo "輸入錯誤!";
  }
  exit();
}
?>
<!DOCTYPE html>
<html>
<head>
  <meta http-equiv="content-type" content="text/html;charset=utf-8"/>
  <title>確認驗證碼</title>
</head>
<body>
<form method="post" action="./form.php">
  <p>驗證碼圖片:
    <img id="captcha_img" border="1" src="./captcha.php?r=<?php echo rand(); ?>" width=100 height=30>
    <a href="javascript:void(0)" rel="external nofollow" 
      onClick="document.getElementById('captcha_img').src='./captcha.php?r='+Math.random()">換一個?</a>
  </p>
  <p>請輸入圖片中的內(nèi)容:<input type="text" name="authcode" value=""/></p>
  <p><input type="submit" value="提交" style="padding:6px 20px;"></p>
</form>
</body>
</html>

以上就是php驗證碼的制作思路和實現(xiàn)方法,從簡單到復(fù)雜,可以根據(jù)這些寫出非常完美的驗證碼功能機制。

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP圖形與圖片操作技巧匯總》、《PHP數(shù)組(Array)操作技巧大全》、《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計算法總結(jié)》、《PHP數(shù)學運算技巧總結(jié)》、《php字符串(string)用法總結(jié)》及《php常見數(shù)據(jù)庫操作技巧匯總

希望本文所述對大家PHP程序設(shè)計有所幫助。

相關(guān)文章

最新評論