root
7 years ago
committed by
ThomasV
2 changed files with 63 additions and 0 deletions
@ -0,0 +1,45 @@ |
|||
#!/bin/bash |
|||
here=$(dirname "$0") |
|||
test -n "$here" -a -d "$here" || exit |
|||
cd $here |
|||
|
|||
if ! which osslsigncode > /dev/null 2>&1; then |
|||
echo "Please install osslsigncode" |
|||
fi |
|||
|
|||
if [ $# -neq 2 ]; then |
|||
echo "Usage: $0 signed_binary unsigned_binary" |
|||
fi |
|||
|
|||
out="$1-stripped.exe" |
|||
|
|||
set -ex |
|||
|
|||
echo "Step 1: Remove PE signature from signed binary" |
|||
osslsigncode remove-signature -in $1 -out $out |
|||
|
|||
echo "Step 2: Remove checksum from signed binary" |
|||
python3 <<EOF |
|||
pe_file = "$out" |
|||
with open(pe_file, "rb") as f: |
|||
binary = bytearray(f.read()) |
|||
|
|||
pe_offset = int.from_bytes(binary[0x3c:0x3c+4], byteorder="little") |
|||
checksum_offset = pe_offset + 88 |
|||
|
|||
for b in range(4): |
|||
binary[checksum_offset + b] = 0 |
|||
|
|||
with open(pe_file, "wb") as f: |
|||
f.write(binary) |
|||
EOF |
|||
|
|||
bytes=$( wc -c < $2 ) |
|||
bytes=$((8 - ($bytes%8))) |
|||
bytes=$(($bytes % 8)) |
|||
|
|||
echo "Step 3: Appending $bytes null bytes to unsigned binary" |
|||
|
|||
truncate -s +$bytes $2 |
|||
|
|||
diff $out $2 && echo "Success!" |
Loading…
Reference in new issue