php登陸驗證碼,php模擬登錄識別驗證碼

本文目錄一覽:

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-hant/n/324560.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
HBCUZ的頭像HBCUZ
上一篇 2025-01-13 13:23
下一篇 2025-01-13 13:23

相關推薦

  • PHP和Python哪個好找工作?

    PHP和Python都是非常流行的編程語言,它們被廣泛應用於不同領域的開發中。但是,在考慮擇業方向的時候,很多人都會有一個問題:PHP和Python哪個好找工作?這篇文章將從多個方…

    編程 2025-04-29
  • PHP怎麼接幣

    想要在自己的網站或應用中接受比特幣等加密貨幣的支付,就需要對該加密貨幣擁有一定的了解,並使用對應的API進行開發。本文將從多個方面詳細闡述如何使用PHP接受加密貨幣的支付。 一、環…

    編程 2025-04-29
  • 使用PHP foreach遍歷有相同屬性的值

    本篇文章將介紹如何使用PHP foreach遍歷具有相同屬性的值,並給出相應的代碼示例。 一、基礎概念 在講解如何使用PHP foreach遍歷有相同屬性的值之前,我們需要先了解幾…

    編程 2025-04-28
  • PHP獲取301跳轉後的地址

    本文將為大家介紹如何使用PHP獲取301跳轉後的地址。301重定向是什麼呢?當我們訪問一個網頁A,但是它已經被遷移到了另一個地址B,此時若服務器端做了301重定向,那麼你的瀏覽器在…

    編程 2025-04-27
  • PHP登錄頁面代碼實現

    本文將從多個方面詳細闡述如何使用PHP編寫一個簡單的登錄頁面。 1. PHP登錄頁面基本架構 在PHP登錄頁面中,需要包含HTML表單,用戶在表單中輸入賬號密碼等信息,提交表單後服…

    編程 2025-04-27
  • PHP與Python的比較

    本文將會對PHP與Python進行比較和對比分析,包括語法特性、優缺點等方面。幫助讀者更好地理解和使用這兩種語言。 一、語法特性 PHP語法特性: <?php // 簡單的P…

    編程 2025-04-27
  • PHP版本管理工具phpenv詳解

    在PHP項目開發過程中,我們可能需要用到不同版本的PHP環境來試驗不同的功能或避免不同版本的兼容性問題。或者我們需要在同一台服務器上同時運行多個不同版本的PHP語言。但是每次手動安…

    編程 2025-04-24
  • PHP數組去重詳解

    一、array_unique函數 array_unique是php中常用的數組去重函數,它基於值來判斷元素是否重複,具體使用方法如下: $array = array(‘a’, ‘b…

    編程 2025-04-24
  • PHP導出Excel文件

    一、PHP導出Excel文件列寬調整 當我們使用PHP導出Excel文件時,有時需要調整單元格的列寬。可以使用PHPExcel類庫中的setWidth方法來設置單元格的列寬。下面是…

    編程 2025-04-24
  • php擴展庫初探

    一、什麼是php擴展庫? PHP擴展庫(PHP extension)是一些用C語言編寫的動態鏈接庫,用於擴展PHP的功能。PHP擴展庫使得PHP可以與各種數據庫系統相連、SMTP、…

    編程 2025-04-23

發表回復

登錄後才能評論