PHP驗證碼類文件及調用方式代碼詳解
代碼如下所示:
//驗證碼類
class ValidateCode {
private $charset = 'abcdefghkmnprstuvwxyzABCDEFGHKMNPRSTUVWXYZ23456789';//隨機因子
private $code;//驗證碼
private $codelen = 4;//驗證碼長度
private $width = 130;//寬度
private $height = 50;//高度
private $img;//圖形資源句柄
private $font;//指定的字體
private $fontsize = 20;//指定字體大小
private $fontcolor;//指定字體顏色
//構造方法初始化
public function __construct() {
$this->font = dirname(__FILE__).'/font/elephant.ttf';//注意字體路徑要寫對,否則顯示不了圖片
}
//生成隨機碼
private function createCode() {
$_len = strlen($this->charset)-1;
for ($i=0;$i<$this->codelen;$i++) {
$this->code .= $this->charset[mt_rand(0,$_len)];
}
}
//生成背景
private function createBg() {
$this->img = imagecreatetruecolor($this->width, $this->height);
$color = imagecolorallocate($this->img, mt_rand(157,255), mt_rand(157,255), mt_rand(157,255));
imagefilledrectangle($this->img,0,$this->height,$this->width,0,$color);
}
//生成文字
private function createFont() {
$_x = $this->width / $this->codelen;
for ($i=0;$i<$this->codelen;$i++) {
$this->fontcolor = imagecolorallocate($this->img,mt_rand(0,156),mt_rand(0,156),mt_rand(0,156));
imagettftext($this->img,$this->fontsize,mt_rand(-30,30),$_x*$i+mt_rand(1,5),$this->height / 1.4,$this->fontcolor,$this->font,$this->code[$i]);
}
}
//生成線條、雪花
private function createLine() {
//線條
for ($i=0;$i<6;$i++) {
$color = imagecolorallocate($this->img,mt_rand(0,156),mt_rand(0,156),mt_rand(0,156));
imageline($this->img,mt_rand(0,$this->width),mt_rand(0,$this->height),mt_rand(0,$this->width),mt_rand(0,$this->height),$color);
}
//雪花
for ($i=0;$i<100;$i++) {
$color = imagecolorallocate($this->img,mt_rand(200,255),mt_rand(200,255),mt_rand(200,255));
imagestring($this->img,mt_rand(1,5),mt_rand(0,$this->width),mt_rand(0,$this->height),'*',$color);
}
}
//輸出
private function outPut() {
header('Content-type:image/png');
imagepng($this->img);
imagedestroy($this->img);
}
//對外生成
public function doimg() {
$this->createBg();
$this->createCode();
$this->createLine();
$this->createFont();
$this->outPut();
}
//獲取驗證碼
public function getCode() {
return strtolower($this->code);
}
}

使用方法:
1、先把驗證碼類保存為一個名為 ValidateCode.class.php 的文件;
2、新建一個名為 captcha.php 的文件進行調用該類;
captcha.php

3、引用到頁面中,代碼如下:

4、一個完整的驗證頁面,代碼如下:
<?php
session_start();
//在頁首先要開啟session,
//error_reporting(2047);
session_destroy();
//將session去掉,以每次都能取新的session值;
//用seesion 效果不錯,也很方便
?>
<html>
<head>
<title>session 圖片驗證實例</title>
<style type="text/css">
#login p{
margin-top: 15px;
line-height: 20px;
font-size: 14px;
font-weight: bold;
}
#login img{
cursor:pointer;
}
form{
margin-left:20px;
}
</style>
</head>
<body>
<form id="login" action="" method="post">
<p>此例為session驗證實例</p>
<p>
<span>驗證碼:</span>
<input type="text" name="validate" value="" size=10>
<img title="點擊刷新" src="./captcha.php" align="absbottom" onclick="this.src='captcha.php?'+Math.random();"></img>
</p>
<p>
<input type="submit">
</p>
</form>
<?php
//打印上一個session;
//echo "上一個session:<b>".$_SESSION["authnum_session"]."</b><br>";
$validate="";
if(isset($_POST["validate"])){
$validate=$_POST["validate"];
echo "您剛才輸入的是:".$_POST["validate"]."<br>狀態(tài):";
if($validate!=$_SESSION["authnum_session"]){
//判斷session值與用戶輸入的驗證碼是否一致;
echo "<font color=red>輸入有誤</font>";
}else{
echo "<font color=green>通過驗證</font>";
}
}
?>
總結
以上所述是小編給大家介紹的PHP驗證碼類文件及調用方式代碼詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關文章
destoon調用企業(yè)會員公司形象圖片的實現(xiàn)方法
這篇文章主要介紹了destoon調用企業(yè)會員公司形象圖片的實現(xiàn)方法,非常實用,需要的朋友可以參考下2014-08-08
ThinkPHP做文字水印時提示call an undefined function exif_imagetype()解
這篇文章主要介紹了ThinkPHP做文字水印時提示call an undefined function exif_imagetype()解決方法,是項目開發(fā)中非常實用的技巧,需要的朋友可以參考下2014-10-10
mysqli_set_charset和SET NAMES使用抉擇及優(yōu)劣分析
盡量使用mysqli_set_charset(mysqli:set_charset)而不是SET NAMES, 當然, 這個內容在PHP手冊中也有敘及, 但是卻沒有解釋為什么,接下來為您揭下神秘面紗2013-01-01
部署和發(fā)布PHP網(wǎng)站到IIS服務器的全過程
這篇文章主要介紹了如何在IIS服務器上部署PHP網(wǎng)站,PHP的優(yōu)勢在于易學易用、開源免費、跨平臺性、強大社區(qū)支持、與MySQL的良好集成、豐富的框架和庫、安全性以及高效的服務器端處理能力,文中通過圖文介紹的非常詳細,需要的朋友可以參考下2025-02-02
thinkphp5 模型實例化獲得數(shù)據(jù)對象的教程
今天小編就為大家分享一篇thinkphp5 模型實例化獲得數(shù)據(jù)對象的教程,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10
全世界最小的php網(wǎng)頁木馬一枚 附PHP木馬的防范方法
php網(wǎng)頁木馬代碼,大家可以看下自己的網(wǎng)站里面是不是有這樣的代碼,注意網(wǎng)站安全用mcafee限制w3wp.exe生成php或者asp文件。并在php.ini中設置一下。2009-10-10

