ファイル(バイナリ)を開き、bin2hex 関数を使用してそれを 16 進文字列に変換し、特定の位置の値を変更しました。問題は、それを保存し直したいのですが、変更が加えられていることがわかりました。 ASCIIファイルになってしまったのですが、ソースファイルと同じコード形式で保存する方法を教えてください。
コードは次のとおりです:
$fp=fopen("sample.bin",'rb');
$word=''; = bin2hex(fread($fp,48));
$pos = strpos($buf, '02000100'); // 土地を検索
//if $pos == 0 {
// echo "これは土地です" ;
//}
echo $buf;
echo ($pos/2);
echo $buf2=str_replace("02000100") , "BE010000",$buf);
$word=$word.$buf2;
}
fclose($fp);
$new= fopen( ' new.bin','w');
fwrite($new,$word);
ディスカッションに返信 (解決策)
1 つのファイル、1 つの形式で保存この形式は意味がありません。必要に応じて取り出して変換できます。 16 進数に変換する必要はありません。 $fp=fopen("sample.bin",' rb'); を使用します。このファイルは、プログラムがウィンドウ システムで動作できることを意味します。そのため、書き込むときは、 $new= fopen('new.bin','w b'); である必要があります。
b はバイナリ モードを意味し、次のようにする必要があります。 window では厳密に区別されますが、Linux
2 では、$word の処理内容は 16 進数で表現されます。ファイルを書き込むときにバイナリに変換し直さなかったので、$word = Pack('H) を使用できます。 *', $word);
$word = ' ';
$target = Pack('H*', 'BE010000'); while(!feof($fp)){
$word = '';
$from = Pack('H*', '02000100');
$target = Pack('H*', 'BE010000) ');
while(!feof($fp)){
$buf = bin2hex(fread($fp,48));
$buf2 = str_replace($from, $target, $buf); $buf2;
xuzuning さん、ご意見ありがとうございます。アドバイスに従います。 コードは次のように変更されました。
$fp=fopen("old.bin",'rb');
$word='';
$from = パック('H*', '02000100') ;
$target = パック('H*', 'BE010000');
$buf = bin2hex(fread($fp,48));
$buf2 = str_replace($ from, $target, $buf);
//if $pos == 0 {
// echo "これは土地です"
/ /}
echo "n-----------n"; echo ($pos/2);
echo $buf2;
$buf2=str_replace( "02000100","BE010000",$buf);
echo "n" ;
}
fclose($fp) //echo $word;
$new= fwrite($new,$word); ($new);
?>
ただし、生成された new.bin のサイズは以前の 2 倍です。私のテスト環境は WIN2008 サーバーです。他に何か提案はありますか?
申し訳ありませんが、#3 のコードは次のようになります
$word = '';
$from = Pack('H*', '02000100');
$target = Pack('H*') , ' BE010000');
while(!feof($fp)){
$buf = fread($fp,48);
$buf2 = str_replace($from, $target, $buf); $buf2 ;
}
完全にバイナリモードで動作します
申し訳ありませんが、#3 のコードは間違っています。次のようにする必要があります
$word = '';
$from = Pack('H*', '02000100');
$target = Pack('H*', 'BE010000 ');
while(!feof($fp)){
$buf = fread($fp,48);
$buf2 = str_replace($from, $target, $buf);
ありがとう、問題は解決しました!
WINDOWS では、あまり知識のない学生がバイナリを開くために fgetc 関数をよく使用します。テキストを含むファイルをバイトごとに読み取ろうとしましたが、実際には、特定のバイトがたまたま終了文字として機能する特殊なバイトであったため、半分しか読み取ることができませんでした。本文中。
ただし、Linux は常にシステム API を使用します。つまり、read はファイルの終わりとして 0 を返すため、b パラメーターは無視されます。
投稿者のアプローチは冗長です。単に「land」という単語を見つけて置き換えたいだけではありませんか?
投稿者が言及したバイナリ ファイルがどのように生成されるかはわかりません。 open と non- b で開いた場合の結果は異なります。 b 以外で開いた場合とテキスト エディタで編集した場合の結果は同じです。
元のファイルが「land」という単語を含む utf8 テキスト ファイルであると仮定します。メソッドは非常に単純です。UTF8 マルチバイト エンコーディングの場合、ループ fread は単語「land」の完全なバイトをバッファに読み込むことができない可能性があります。そのため、より良い方法は file_get_contents を使用してから、直接 str_replace を実行することです。 ("land", "brother" ) つまり、C 言語では、実際にはメモリ マッピングを行ってから文字列を置き換えます
16 進数への変換はまったく不要で、おそらく "land" という単語にバグがあるはずです。 「」は別途読んでください。
vim のようなソフトウェアでもメモリマップされています。ファイルが大きすぎると何もできません。失敗したことしかわかりません。
を保存するには?