reversing.kr ImagePrc
今回の問題は以下のようなBitmapの推論問題である。
data:image/s3,"s3://crabby-images/7de80/7de805626ea0b3380cb87b05b39f11143f510b65" alt=""
早速IDA Proによりデバッグしてもると、以下のような流れを確認できる。
まず、CreateCompatibleBitmap関数により、200x150のピクセルを持ったbitmapを生成する。
data:image/s3,"s3://crabby-images/50120/50120fbe9dbd692e47ab845e0d18f3c25b54b4f0" alt=""
次に、GetDIBits関数からポインターされているBitmapのBitを検索して、bufferにコピーする。
data:image/s3,"s3://crabby-images/dfe61/dfe61e2a0a8f2e6682fa0ada635349b2c7985568" alt=""
上記のコードからわかるのは、このプログラムが受けるデータは0x18、つまり、24BitのBitmapとなっていることである。
そして、文字列を検索すると、入力されたデータが間違えてることを示す
演算が存在することを確認できる。
data:image/s3,"s3://crabby-images/4d843/4d843bdad2755a92ba771b936dedfba57443501d" alt=""
そして、この文字列はLoc_4013CD関数から呼び出されていて、さらにその関数はLoc_4013A3から呼び出されていることが確認できる。
data:image/s3,"s3://crabby-images/671c7/671c785b558e1ca7331b610aa108e540afc027bb" alt=""
この時、4013A3から、描かれたBitmapデータを比較する。もっと詳しく見るために以下のコードに着目する。
data:image/s3,"s3://crabby-images/71edd/71eddda40bce4541fd4a95520e0256af1a26759a" alt=""
ecx レジスタには描かれたBitmapデータのポインタ(&esi)が入って、LoadResource関数により比較の元となるデータ(eax+ecx)が1byteごとに呼び出され、それを90000byteの大きさまで比較して、間違ってる場合には、Wrongを出力する。
data:image/s3,"s3://crabby-images/9f0c5/9f0c55936d4b51f1c320ac8ad44ba0bca9ec739b" alt=""
実際に実行して見ると、FFFFFFFのようなBitmapデータが確認できる。
以上の結果からeax+ecxからその90000byteまでデータを出力して、Bitmapを作ると、以下のような答えを得る。
data:image/s3,"s3://crabby-images/71d71/71d715421c613967c0e73ce70ae171c37c418413" alt=""