验证码
// -------------------------------------------------------------
// 名称: my_authimg class
//
// 用途: 根据图片数字字母验证
// 实例:
// $ai = new my_authimg();
// $ai->render();
//
// 判断结果是否正确
// $ai = new my_authimg();
// $ai->is_true($str);
//
// @作者: hightman
// @版本: 0.0.0
// @时间: 2005/05/26
// $Id: $
// -------------------------------------------------------------
class my_authimg {
// public var
var $width = 72;
var $height = 20;
var $text_font = 5;
var $text_space = 10;
var $text_length = 5;
var $sess_name = "__auth_xyz_123__";
var $num_only = false;
// private
var $_top = 1;
var $_move = 3;
var $_lines = 5;
function auth_image($params = array()) {
settype($params, "array");
foreach ($params as $key => $value) {
if (isset($this->$key)) {
$this->$key = $value;
}
}
$this->_lines = intval($this->height / 10);
}
function set_sess_name($name = "") {
if (!empty($name)) {
$this->sess_name = $name;
}
}
function set_text_length($length = 5) {
$this->text_length = $length;
}
function set_img_size($width = 100, $height = 15) {
$this->width = $width;
$this->height = $height;
}
function get_sess_value() {
@session_start();
$sess_key = $this->sess_name;
$sess_value = NULL;
if (isset($_SESSION) && isset($_SESSION[$sess_key])) {
$sess_value = $_SESSION[$sess_key];
unset($_SESSION[$sess_key]);
} else {
global $HTTP_SESSION_VARS;
if (isset($HTTP_SESSION_VARS[$sess_key])) {
$sess_value = $HTTP_SESSION_VARS[$sess_key];
session_unregister($this->sess_name);
}
}
if (isset($GLOBALS[$sess_key])) {
unset($GLOBALS[$sess_key]);
}
return $sess_value;
}
function is_true($str) {
$sess_value = $this->get_sess_value();
return (!strcasecmp($sess_value, $str));
}
function render() {
$radix = "123456789";
if (!$this->num_only) {
$radix .= "ABCDEFGHIJKLMNPQRSTUVWXYZ";
}
$radix_len = strlen($radix);
// 种下随机种子
mt_srand();
// 初始化图片
$image = ImageCreate($this->width, $this->height);
// 设定颜色
$r = mt_rand() % 255; //2 ? 255 : 0;
$g = mt_rand() % 255; //2 ? 255 : 0;
$b = mt_rand() % 255; //2 ? 255 : 0;
$fgcolor = ImageColorAllocate($image, $r, $g, $b);
$bgcolor = ImageColorAllocate($image, 255 - $r, 255 - $g, 255 - $b);
$silver = ImageColorAllocate($image, (255 - $r) * 2, (255 - $g) * 2, (255 - $b) * 2);
// 生成背景
ImageFill($image, 0, 0, $bgcolor);
// 画出横向干扰线
$line_space = ceil($this->height / ($this->_lines + 1));
$line_move = ceil($line_space * 2);
for ($i = 1; $i _lines; $i++) {
$y = $line_space * $i;
$y2 = $y + (($i - rand(0, 2 * $i)) % 2) * $line_move;
ImageLine($image, 0, $y, $this->width, $y2, $silver);
}
// 画出干扰点
$pixel_num = intval($this->height * $this->width / 20);
for($i = 0; $i $x = mt_rand() % $this->width;
$y = mt_rand() % $this->height;
ImageSetPixel($image, $x, $y, $silver);
}
// 画出字符
$rand_str = "";
$step_len = intval($this->width / ($this->text_length + 1));
$left_len = $step_len - 6;
for ($i = 0; $i text_length; $i++) {
$x = $left_len + ($step_len * $i);
$y = ($i % 2) * $this->_move + $this->_top;
$rand = mt_rand(0, $radix_len - 1);
$rand_str .= substr($radix, $rand, 1);
ImageString($image, $this->text_font, $x, $y, substr($radix, $rand, 1), $fgcolor);
}
// 设定 SESSION 值
@session_start();
if (isset($_SESSION)) {
$sess_key = $this->sess_name;
$_SESSION[$sess_key] = $rand_str;
}
else {
session_register($this->sess_name, $rand_str);
}
// 输出图象
header("Content-type: image/png");
ImagePNG($image);
ImageDestroy($image);
}
}
?>

phpssionsStrackuserdataacrossmultiplepagerequestsusingauniqueidstoredinacookie.here'showtomanageetheemefectively:1)Startassession withsession_start()andstoredatain $ _ session.2)RegeneratesseSsessidafterloginwithsession_id(the topreventes_id)

PHPでは、次の手順を通じてセッションデータを繰り返すことができます。1。session_start()を使用してセッションを開始します。 2。$ _Sessionアレイのすべてのキー価値ペアを介してforeachループを反復します。 3.複雑なデータ構造を処理する場合、is_array()またはis_object()関数を使用し、print_r()を使用して詳細情報を出力します。 4.トラバーサルを最適化する場合、ページングを使用して、一度に大量のデータの処理を避けることができます。これにより、実際のプロジェクトでPHPセッションデータをより効率的に管理および使用するのに役立ちます。

このセッションは、サーバー側の状態管理メカニズムを介してユーザー認証を実現します。 1)セッションの作成と一意のIDの生成、2)IDはCookieを介して渡されます。3)サーバーストアとIDを介してセッションデータにアクセスします。

tostoreauser'snameInappession、starthessession withsession_start()、thensignthenameto $ _session ['username']。1)ousession_start()toinitializethessession.2)assighttheuser'snameto $ _ session ['username']

PHPSESSIONの障害の理由には、構成エラー、Cookieの問題、セッションの有効期限が含まれます。 1。構成エラー:正しいセッションをチェックして設定します。save_path。 2.Cookieの問題:Cookieが正しく設定されていることを確認してください。 3.セッションの有効期限:セッションを調整してください。GC_MAXLIFETIME値はセッション時間を延長します。

PHPでセッションの問題をデバッグする方法は次のとおりです。1。セッションが正しく開始されるかどうかを確認します。 2.セッションIDの配信を確認します。 3.セッションデータのストレージと読み取りを確認します。 4.サーバーの構成を確認します。セッションIDとデータを出力し、セッションファイルのコンテンツを表示するなど、セッション関連の問題を効果的に診断して解決できます。

session_start()への複数の呼び出しにより、警告メッセージと可能なデータ上書きが行われます。 1)PHPは警告を発し、セッションが開始されたことを促します。 2)セッションデータの予期しない上書きを引き起こす可能性があります。 3)session_status()を使用してセッションステータスを確認して、繰り返しの呼び出しを避けます。

PHPでのセッションライフサイクルの構成は、session.gc_maxlifetimeとsession.cookie_lifetimeを設定することで達成できます。 1)session.gc_maxlifetimeサーバー側のセッションデータのサバイバル時間を制御します。 0に設定すると、ブラウザが閉じているとCookieが期限切れになります。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

SecLists
SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

メモ帳++7.3.1
使いやすく無料のコードエディター

ホットトピック









