本文目錄一覽:
PHP 驗證碼
問題一、你的驗證碼代碼,沒有發現開啟session,也沒有將隨機產生的字符串保存到session,沒保存,自然就無法比對
問題二、要點擊一下刷新,其實很簡單,給圖片加一個點擊事件,讓圖片重新請求一次服務器執行php驗證碼文件,需要注意的是,有於緩存的關係,在重新請求服務器的時候,給驗證碼圖片路徑加一個隨機參數,防止刷新而驗證碼不變化,代碼示例如下:
img src=’code.php’ onclick=”this.src=’code.php?’+Math.random();” /
php 登陸驗證碼通不過
?php
session_start();
$CheckCode=@$_POST[‘CheckCode’];
$chak=@$_POST[‘yes’];
if($chak != “ok”){
? form action=”abc.php” method=”post”
驗證碼:input type=’text’ name=’CheckCode’ /img src=’換成你的這個產生驗證碼代碼頁面’ /
input type=”hidden” name=”yes” value=”ok”
input type=”submit” value=”提交”
/form
?php
}else{
if(strtolower($CheckCode)!=$_SESSION[‘authnum’]){
echo “scriptalert(‘校驗碼不正確!’);window.location.href=’abc.php’;/script”;
exit;
}else{
echo “對的checkcode=”.$CheckCode.”相等於session(authum)”.$_SESSION[‘authnum’];
echo “scriptalert(‘校驗碼正確!’);window.location.href=’bcd.php’;/script”;
}
}//bcd.php這個什麼都沒有就是一個空頁,你試一下。
?
PHP中模擬登錄的驗證碼問題應該如何解決
基本思路:
首先獲取一個cookies值,再帶着這個cookies去獲取驗證碼圖片,你再帶着驗證碼值和登錄數據去模擬post登錄。下面是一個模擬獲取驗證碼的。
這裡忽略獲取cookies的過程。注意文件為UTF-8無BOM格式
?php
header(‘Content-Type:image/png’);
$url = “”;//圖片鏈接
$ch = curl_init();
//Cookie:PHPSESSID=121b1127dcded8702c6a1e702c40eca4
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch,CURLOPT_COOKIE,’PHPSESSID=121b1127dcded8702c6a1e702c40eca4′);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 0);
curl_setopt($ch, CURLOPT_TIMEOUT,0);//忽略超時
curl_setopt($ch, CURLOPT_NOBODY, false);
$str = curl_exec($ch);
curl_close($ch);
php驗證碼怎麼實現
1. 新建code.php驗證碼生成文件
在此之前必須打開php的GD庫,修改php.ini文件的配置,取消extension=php_gd2.dll前面的分號。代碼如下:
?php
session_start();
//生成驗證碼圖片
Header(“Content-type: image/PNG”);
$im = imagecreate(44,18);
$back = ImageColorAllocate($im, 245,245,245);
imagefill($im,0,0,$back); //背景
srand((double)microtime()*1000000);
//生成4位數字
for($i=0;$i4;$i++){
$font = ImageColorAllocate($im, rand(100,255),rand(0,100),rand(100,255));
$authnum=rand(1,9);
$vcodes.=$authnum;
imagestring($im, 5, 2+$i*10, 1, $authnum, $font);
}
for($i=0;$i100;$i++) //加入干擾象素
{
$randcolor = ImageColorallocate($im,rand(0,255),rand(0,255),rand(0,255));
imagesetpixel($im, rand()p , rand()0 , $randcolor);
}
ImagePNG($im);
ImageDestroy($im);
$_SESSION[‘Checknum’] = $vcodes;
?
2. 顯示驗證碼圖片
在需要顯示驗證碼的頁面中加入
input type=”text” name=”passcode”
img src=”code.php”
3.判斷並獲取驗證碼的值
驗證碼是通過第一步驟代碼中的$_SESSION[‘Checknum’] = $vcodes;賦的值,所以驗證碼的值存在$_SESSION[‘Checknum’]當中。在驗證頁面,使用以下代碼,
…
session_start();//啟動會話
$code=$_POST[“passcode”];
if( $code == $_SESSION[“Checknum”])
{…}即可完成驗證碼登錄。
運行截圖:
望採納,謝謝
如何用PHP生成驗證碼
PHP生成驗證碼的原理:使用PHP的GD庫,生成一張帶驗證碼的圖片,並將驗證碼保存在Session中。PHP生成驗證碼的大致流程有:
1、產生一張png的圖片;
2、為圖片設置背景色;
3、設置字體顏色和樣式;
4、產生4位數的隨機的驗證碼;
5、把產生的每個字符調整旋轉角度和位置畫到png圖片上;
6、加入噪點和干擾線防止註冊機器分析原圖片來惡意破解驗證碼;
7、輸出圖片;
8、釋放圖片所佔內存。
session_start();
getCode(4,60,20);
function getCode($num,$w,$h) {
$code = “”;
for ($i = 0; $i $num; $i++) {
$code .= rand(0, 9);
}
//4位驗證碼也可以用rand(1000,9999)直接生成
//將生成的驗證碼寫入session,備驗證時用
$_SESSION[“helloweba_num”] = $code;
//創建圖片,定義顏色值
header(“Content-type: image/PNG”);
$im = imagecreate($w, $h);
$black = imagecolorallocate($im, 0, 0, 0);
$gray = imagecolorallocate($im, 200, 200, 200);
$bgcolor = imagecolorallocate($im, 255, 255, 255);
//填充背景
imagefill($im, 0, 0, $gray);
//畫邊框
imagerectangle($im, 0, 0, $w-1, $h-1, $black);
//隨機繪製兩條虛線,起干擾作用
$style = array ($black,$black,$black,$black,$black,
$gray,$gray,$gray,$gray,$gray
);
imagesetstyle($im, $style);
$y1 = rand(0, $h);
$y2 = rand(0, $h);
$y3 = rand(0, $h);
$y4 = rand(0, $h);
imageline($im, 0, $y1, $w, $y3, IMG_COLOR_STYLED);
imageline($im, 0, $y2, $w, $y4, IMG_COLOR_STYLED);
//在畫布上隨機生成大量黑點,起干擾作用;
for ($i = 0; $i 80; $i++) {
imagesetpixel($im, rand(0, $w), rand(0, $h), $black);
}
//將數字隨機顯示在畫布上,字符的水平間距和位置都按一定波動範圍隨機生成
$strx = rand(3, 8);
for ($i = 0; $i $num; $i++) {
$strpos = rand(1, 6);
imagestring($im, 5, $strx, $strpos, substr($code, $i, 1), $black);
$strx += rand(8, 12);
}
imagepng($im);//輸出圖片
imagedestroy($im);//釋放圖片所佔內存
}
在Thinkphp中怎麼做登陸的驗證碼
tp3.2.3中做的一個驗證碼的例子:
①模塊Common/function:
function check_verify($code, $id = “”){
$verify = new \Think\Verify();
return $verify-check($code, $id);
}
②控制器中添加:
public function index(){
$this-display();
}
public function verify_show(){
$config = array(
‘fontSize’ = 30, // 驗證碼字體大小
‘length’ = 4, // 驗證碼位數
‘useNoise’ = false, // 關閉驗證碼雜點
‘fontttf’ =’5.ttf’,
‘useImgBg’ = true,
);
$Verify = new \Think\Verify($config);
$Verify-entry();
}
public function verify_check(){
$verify = I(‘post.code’);
if(!check_verify($verify)){
$this-error(“親,驗證碼輸錯了哦!”);
}else{
$this-success(‘驗證碼測試成功!’);
}
}
③模板中index.html
form action=”{:U(‘Index/VerifyCode/verify_check’)}” method=”post” class=”form-horizontal”
div class=”form-group”
label for=”code” class=”col-sm-2″ 驗證碼/label
div class=”col-sm-2″
input type=”text” class=”form-control” id=”code” name=”code”
/div
div class=”col-sm-5″
img src=”{:U(‘Index/VerifyCode/verify_show’)}” onclick=”change_verify()” id=”img” title=”點擊刷新”
/div
/div
div class=”form-group”
button class=”btn btn-primary col-sm-offset-2″ type=”submit”提交/button
/div
/form
script
function change_verify(){
var url = “{:U(‘Index/VerifyCode/verify_show’)}”;
$(‘#img’).attr(‘src’,url);
}
/script
原創文章,作者:HBCUZ,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/324560.html