驗證碼

源碼

先寫tx.php文件

<?php 
session_start();
header('Content-type:image/gif');
$image_w=100;
$image_h=25;
$number=range(0,9);
$character=range('A','Z');
$result=array_merge($number,$character);
$string="";
$len=count($result);
for ($i=0; $i <4 ; $i++) { 
    $new_number[$i]=$result[rand(0,$len-1)];
    $string=$string.$new_number[$i];
}
$_SESSION['string']=$string;
$check_image=imagecreatetruecolor($image_w, $image_h);
$white=imagecolorallocate($check_image, 255, 255, 255);
$black=imagecolorallocate($check_image, 0,0,0);
imagefill($check_image, 0, 0, $white);
for ($i=0; $i <100 ; $i++) { 
    imagesetpixel($check_image, rand(0,$image_w), rand(0,$image_h),$black);
}
for ($i=0; $i <count($new_number) ; $i++) { 
    $x=mt_rand(1,8)+$image_w*$i/4;
    $y=mt_rand(1,$image_h/4);
    $color=imagecolorallocate($check_image,mt_rand(0,200) , mt_rand(0,200),mt_rand(0,200));
   imagestring($check_image, 5, $x, $y, $new_number[$i], $color);
}
imagepng($check_image);
imagedestroy($check_image);
?>

在另一個頁面寫

<!DOCTYPE html>
<html>
<head>
    <title></title>
    <meta charset="utf-8">
</head>
    <body>
        <form action=""method="post">
            <p>驗證碼:<input type="text"size="10"name="check" />
            <img src="tx.php"/></p>
            <p><input type="submit"name="ok"value="提交" /></p>
        </form>
    </body>
</html>
<?php 
session_start();
if (isset($_POST['ok'])) {
    $checkstr=$_SESSION['string'];
    $str=$_POST['check'];
    if (strcasecmp($str, $checkstr)==0) {
        echo"<script>alert('驗證碼輸入正確');</script>";
    }else{
        echo"<script>alert('輸入錯誤');</script>";
    }

}

?>

幾個問題

session是什么

當您運行一個應用程序時,您會打開它,做些更改,然后關閉它。這很像一次會話。計算機清楚你是誰。它知道你何時啟動應用程序,并在何時終止。但是在因特網上,存在一個問題:服務器不知道你是誰以及你做什么,這是由于 HTTP 地址不能維持狀態。通過在服務器上存儲用戶信息以便隨后使用,PHP session 解決了這個問題(比如用戶名稱、購買商品等)。不過,會話信息是臨時的,在用戶離開網站后將被刪除。如果您需要永久儲存信息,可以把數據存儲在數據庫中。
session_start: 初始 session。
session_destroy: 結束 session。
session_unset: 釋放session內存。
session_name: 存取目前 session 名稱。
session_module_name: 存取目前 session 模塊。
session_save_path: 存取目前 session 路徑。
session_id: 存取目前 session 代號。
session_register: 注冊新的變量。
session_unregister: 刪除已注冊變量。
session_is_registered: 檢查變量是否注冊。
session_decode: Session 資料解碼。
session_encode: Session 資料編碼。
還有個全局變量就是:$_SESSION

header()是什么

PHP 中 header()函數的作用是給客戶端發送頭信息。

什么是頭信息?

這里只作簡單解釋,詳細的自己看http協議。在 HTTP協議中,服務器端的回答(response)內容包括兩部分:頭信息(header) 和 體內容,這里的頭信息不是HTML中的<head></head>部分,同樣,體內容也不是<BODY>< /BODY>。頭信息是用戶看不見的,里面包含了很多項,包括:服務器信息、日期、內容的長度等。而體內容就是整個HTML,也就是你所能看見的全 部東西。

*頭信息有什么用呢?

1、跳轉:當瀏覽器接受到頭信息中的 Location: xxxx 后,就會自動跳轉到 xxxx 指向的URL地址,這點有點類似用 js 寫跳轉。但是這個跳轉只有瀏覽器知道,不管體內容里有沒有東西,用戶都看不到。
2、指定網頁的內容: 同樣一個XML文件,如果頭信息中指定:Content-type: application/xml 的話,瀏覽器會將其按照XML文件格式解析。但是,如果頭信息中是:Content-type: text/xml 的話,瀏覽器就會將其看作存文本解析。(瀏覽器不是按照擴展名解析文件的)**
3、附件**: 不知道大家有沒有注意,有些時候在一些網站下載東西,點下載連接以后,結果瀏覽器將這個附件當成網頁打開 了,里面顯示的都是亂碼,這個問題也和頭信息有關。有時候瀏覽器根據Content-type 來判斷是打開還是保存,這樣有時就會判斷錯誤(主要是網站設計者忘記寫Content-type)。其實,還有一個可以來指定該內容為附件、需要保存,這 個就是:Content-Disposition: attachment; filename="xxxxx"
3、附件:// 指定內容為附件header('Content-Disposition: attachment; filename="downloaded.pdf"');// 打開文件,并輸出readfile('original.pdf');

range()是什么

range() 函數創建一個包含指定范圍的元素的數組
1.返回一個包含從 "0" 到 "50" 之間并以 10 遞增的元素的數組

<?php
$number = range(0,50,10);
print_r ($number);?>

2.使用字母 - 返回一個包含從 "a" 到 "d" 之間的元素的數組

<?php
$letter = range("a","d");
print_r ($letter);
?>

php里面怎么定義數組

<?php
$a = array("中國人","亞州人","龍王爺","西藏自治區");//方法一
$b[0] = "蘋果";                                 //方法二
$b[1] = "蘋果";
$b[2] = "蘋果";
$b[3] = "蘋果";
$b[4] = "蘋果";
$c = array("one" => "中國人","tow" =>"亞州人","three" => "龍王爺","four" => "西藏自治區");         
                                              //方法三
var_dump($a);
echo "<br />";
var_dump($b);
echo "<br />";
var_dump($c);?>

php字符串的連接

連接字符串和連接賦值運算符

其他

1.array_merge() 函數把一個或多個數組合并為一個數組
2.count函數計算數組或者對象里面的所有元素個數**
3.mt_rand() 比rand() 快四倍,很多老的 libc 的隨機數發生器具有一些不確定和未知的特性而且很慢。PHP 的 rand() 函數默認使用 libc 隨機數發生器。mt_rand() 函數是非正式用來替換它的語法 mt_rand(min,max)說明 如果沒有提供可選參數 min 和 max,mt_rand() 返回 0 到 RAND_MAX 之間的偽隨機數。例如想要 5 到 15(包括 5 和 15)之間的隨機數,用 mt_rand(5, 15)。
4.strcasecmp() 比較兩個字符串(不區分大小寫) 一樣則輸出為0

幾個圖像函數

imagecreatetruecolor()//建立的是一幅大小為 x和 y的黑色圖像(默認為黑色)
imagecreate()//函數是基于一個調色板的畫布,函數的單位為像素
imagecolorallocate( resource $image, int $red, int $green, int $blue)// 為一幅圖像分配顏色
imagefill($img,0,0,$color)//填充顏色函數
imagestring()//水平地畫一行字符串
imagesetpixel()//在 image 圖像中用 color 顏色在 x ,y 坐標(圖像左上角為 0,0)上畫一個
imagepng()//以 PNG 格式將圖像輸出到瀏覽器或文件
imagedestroy()//圖像處理完成后,使用imagedestroy()函數銷毀圖像資源釋放內存

更多圖像處理函數

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 227,283評論 6 530
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 97,947評論 3 413
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事?!?“怎么了?”我有些...
    開封第一講書人閱讀 175,094評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,485評論 1 308
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,268評論 6 405
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 54,817評論 1 321
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 42,906評論 3 440
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,039評論 0 285
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,551評論 1 331
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,502評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,662評論 1 366
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,188評論 5 356
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 43,907評論 3 345
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,304評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,563評論 1 281
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,255評論 3 389
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,637評論 2 370

推薦閱讀更多精彩內容