この記事では、まず qqwry.dat のファイル コンテンツ構造を紹介します。次に、その特性に従って、qqwry.dat ip ライブラリのコンテンツを読み取って、必要なコンテンツを見つけることができます。
まず、QQWry.Data ファイルのコンテンツ構造とその解釈方法を見てみましょう。
1. ファイル構造は主に 3 つの構造に分かれています
1. ファイルヘッダ、可変長
3. 長さは 7 の整数倍です。 2、ファイルヘッダー
ファイルヘッダーの8バイトは4バイトずつの2つの部分に分割され、それぞれインデックス領域の開始アドレスと終了アドレスを指定します。したがって、レコードの総数は、2 つのアドレスの差を 7 で割って 1 を加算することで計算できます。
この領域のデータは、インデックス領域のデータを通じて各データの開始位置を取得する必要があります。文字列の前には末尾を表す 0×00 が付きます。
IP に対応する領域を取得するには、IP 開始アドレスに対応するインデックス コンテンツを見つけることが重要です。 IP インデックス データには 7 バイトが含まれており、最初の 4 バイトは IP アドレスの開始値、最後の 3 バイトは IP データ レコード内の対応する IP データ レコードのオフセット アドレスです。スタンザは IP 終了アドレスで、それに続くデータには 0x01 パターンと 0x02 パターンの 2 つのパターンがあります。
————————————————————
4 バイト | 3 バイトのリダイレクト 0x NN NN NN -> 国と地域のデータのファイル オフセット アドレスです
0×02モード、つまりIPデータの5バイト目が0×02で、次の3バイトが0×02のオフセットアドレスです。国別データ、地域別データは 0x00 で終わる次の文字列です。つまり、
————————————————————————–
4 バイト | 3 バイト リダイレクト 0x NN NN NN -> 国内データ移行のファイル バイアス住所 | 地域文字列 | 0×00
0で取得した国と地域のデータ×01 モード、つまり、
————————————–
国文字列 0×00
または
————————————————————————-
各国文字列 | 0×02 |セクション 0x NN NN NN -> 領域文字列のファイルオフセットアドレス
——————————————————————————-
前者の場合、これは比較的単純で、2 つの文字列データを直接読み取るだけです。後者の場合は、地域文字列のオフセット アドレスに再度リダイレクトしてから、文字列の末尾として 0x00 を読み取る必要があります。
実際の文字列値をアドレスによってマッピングするこの方法の主な機能は、文字列値の繰り返しの記録を避けることです。 IP アドレス ライブラリ ファイル全体に同一の文字列レコードが多すぎます。3 バイトのマップされたアドレスを使用すると、文字列値を繰り返し記録するよりも多くのスペースが節約されます。
PHP コード読み取り操作 QQWry.dat ファイル:
コードは次のとおりです
function bin2ip($bin){ | |
for($i = 4; $i > 0; $i--){ $ip .= "." .implode('', unpack(' s', $bd[$i-1] . chr(0)))); $index_begin = implode('', unpack('L', $c)); $ip_num = ($index_end - $index_begin) / 7 + 1; echo "インデックスの開始位置: $index_beginn"; $output = ''; for($i = 0; $i < $ip_num; $i++){ //ファイル ポインタは、インデックス データ (7 バイト) を取得するための各 IP データ ファイルのインデックスを指します if(strlen($ip3) $dataseek = implode('', unpack('L', $ip3 . chr(0 ) )); if($dataseek < 0) $index_ip_record += pow(2, 32); fseek($f, $dataseek); $country = ' '; $flag = fread($f, 1); if($flag == chr(2)){ |