以下のコードは、IP に基づいてユーザーの都市を決定するものです。IP の場所を決定するための php のソース コードは、IP に基づいて都市を決定するためのコードです。
function ConvertIp($ip) {
$return = '';
if(preg_match("/^d{1,3}.d{1,3}.d{1,3}.d {1,3} $/", $ip)) {
$iparray =explode('.', $ip);
if($iparray[0] == 10 || $iparray[0] == 127 | | ($iparray[0] == 192 && $iparray[1] == 168) || ($iparray[0] == 172 && ($iparray[1] >= 16 && $iparray[1] $return = '- LAN';
} elseif ($iparray[0] > 255 || $iparray[1] > 255 || $iparray[2] > 255 || $ iparray[3] > ; 255) {
$return = '- 無効な IP アドレス';
} else {
$ipfile = MOOPHP_ROOT.'/plugins/ipdata/wry.dat';
if(!@file_exists($ipfile) )) {
$ return = ConvertIpFull($ip, $ipfile);
}
}
}
return $return;
}
return '- 無効な IP データ ファイル';
}
$ipNum = $ip[0] * 16777216 + $ip[1 ] * 65536 + $ ip[2] * 256 + $ip[3];
@ $ipbegin = implode('', unpack('L', $DataBegin));
if($ipbegin @$ipend = implode ('', unpack ('L', $DataEnd));
if($ipend $ipAllNum = ($ipend - $ipbegin) / 7 + 1 ;
$ipAddr1 = $ipAddr2 = '';
$EndNum = $ipAllNum;
fseek($fd, $ipbegin + 7 * $Middle);
$ipData1 = fread($fd, 4);
if(strlen ($ipData1) < ; 4) {
fclose($fd);
return '- システム エラー';
}
$ip1num = implode('', unpack('L', $ipData1));
if($ ip1num
$EndNum = $Middle;
continue;
}
if (strlen($DataSeek) fclose($fd);
return '- システム エラー';
}
$DataSeek = implode('', unpack('L', $DataSeek) .chr(0) ));
fseek($fd, $DataSeek);
$ipData2 = fread($fd, 4);
if(strlen($ipData2) fclose($fd);
return '- システム エラー';
}
$ip2num = implode('', unpack('L', $ipData2));
if($ip2num
fclose($fd);
return '- Unknown';
}
$BeginNum = $Middle;
}
}
$ipFlag = fread($fd, 1);
if($ipFlag == chr(1)) {
$ipSeek = fread($fd, 3);
if(strlen($ipSeek) fclose($ fd);
return '- システム エラー';
}
$ipSeek = implode('', unpack('L', $ipSeek.chr(0)));
fseek($fd, $ ipSeek);
$ ipFlag = fread($fd, 1);
}
$AddrSeek = fread($fd, 3);
if(strlen($AddrSeek ) fclose($fd);
return '- システム エラー';
}
$ipFlag = fread($fd, 1);
if($ipFlag == chr(2)) {
$ AddrSeek2 = fread($ fd, 3);
if(strlen($AddrSeek2) fclose($fd);
return '- システム エラー';
}
$AddrSeek2 = implode('', unpack ('L', $AddrSeek2.chr(0)));
fseek($fd, $AddrSeek2);
} else {
fseek($fd, -1, SEEK_CUR);
}
$ipAddr2 .= $char;
fseek($fd , $AddrSeek);
while(($char = fread($fd, 1)) != chr(0))
$ipAddr1 .= $char;
} else {
fseek($fd, -1, SEEK_CUR);
while(( $char = fread($fd, 1)) != chr(0))
$ipAddr1 .= $char;
$ipFlag = fread($fd, 1);
if($ipFlag == chr(2) ) {
$AddrSeek2 = fread($fd, 3);
if(strlen($AddrSeek2) fclose($fd);
return '- システムエラー';
}
$AddrSeek2 = implode( '', unpack('L', $AddrSeek2.chr(0)));
fseek($fd, $AddrSeek2);
} else {
fseek($fd, -1, SEEK_CUR);
}
while( ($char = fread($fd, 1)) != chr(0))
$ipAddr2 .= $char;
}
fclose($fd);
if(preg_match('/http/i', $ ipAddr2)) {
$ipAddr2 = '';
}
$ipaddr = "$ipAddr1 $ipAddr2";
$ipaddr = preg_replace('/CZ88.NET/is', '', $ipaddr);
$ipaddr = preg_replace('/^s*/is', '', $ipaddr);
$ipaddr = preg_replace('/s*$/is', '', $ipaddr);
if(preg_match('/http/i ', $ipaddr) || $ipaddr == '') {
$ipaddr = '- 不明';
}
return '- '.$ipaddr;
}

phpssionscanStorestrings、numbers、arrays、andobjects.1.strings:textdatalikeusernames.2.numbers:integersorfloatsforcounters.3.arrays:listslikeshoppingcarts.4.objects:complextructuresthataresialized。

tostartaphpsession、outsession_start()atthescript'sbeginning.1)placeitbe foreanyouttosetthesscookie.2)usesionsionsionsionserdatalikelogintatussorshoppingcarts.3)再生セッションインドストップレベントフィックスアタック

セッション再生とは、新しいセッションIDを生成し、セッション固定攻撃の場合にユーザーが機密操作を実行するときに古いIDを無効にすることを指します。実装の手順には次のものが含まれます。1。感度操作を検出、2。新しいセッションIDを生成する、3。古いセッションIDを破壊し、4。ユーザー側のセッション情報を更新します。

PHPセッションは、アプリケーションのパフォーマンスに大きな影響を与えます。最適化方法には以下が含まれます。1。データベースを使用してセッションデータを保存して応答速度を向上させます。 2。セッションデータの使用を削減し、必要な情報のみを保存します。 3.非ブロッキングセッションプロセッサを使用して、同時実行機能を改善します。 4.セッションの有効期限を調整して、ユーザーエクスペリエンスとサーバーの負担のバランスを取ります。 5.永続的なセッションを使用して、データの読み取り時間と書き込み時間を減らします。

phpsesionsareserver-side、whilecookiesareclient-side.1)Sessionsionsionsoredataontheserver、aremoresecure.2)cookiesstoredataontheclient、cookiestoresecure、andlimitedinsizeisize.sesionsionsionivationivationivationivationivationivationivationivate

phpidentifiesauser'ssessionsingsinssessionCookiesIds.1)whensession_start()iscalled、phpgeneratesauniquesidstoredsored incoookienadphpsessidontheuser'sbrowser.2)thisidallowsphptortorieSessiondatadata fromthata

PHPセッションのセキュリティは、次の測定を通じて達成できます。1。session_regenerate_id()を使用して、ユーザーがログインまたは重要な操作である場合にセッションIDを再生します。 2. HTTPSプロトコルを介して送信セッションIDを暗号化します。 3。Session_Save_Path()を使用して、セッションデータを保存し、権限を正しく設定するためのSecure Directoryを指定します。

phpsessionFilesToredInthededirectoryspecifiedBysession.save_path、通常/tmponunix-likesystemsorc:\ windows \ temponwindows.tocustomizethis:1)uesession_save_path()tosetaCustomdirectory、ensuringit'swritadistradistradistradistradistra


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

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

SublimeText3 中国語版
中国語版、とても使いやすい

Dreamweaver Mac版
ビジュアル Web 開発ツール

ホットトピック









