มีเครื่องมือหลายอย่างที่กล่าวถึงโดยคำตอบที่ดีมากมายฉันจะเลือกอย่างใดอย่างหนึ่ง
แฮ็กเกอร์ทรัพยากร
ฉันดาวน์โหลดเวอร์ชันล่าสุด ( 5.1.7 ) จาก[AngusJ]: ทรัพยากร Hacker ข้อมูลที่จำเป็นทั้งหมดสามารถพบได้ในหน้านั้น (ตัวเลือกบรรทัดคำสั่งสคริปต์ ... ) ในคำแนะนำต่อไปนี้ฉันจะใช้งานไฟล์ปฏิบัติการ 2 ตัว (หนูทดลอง) ซึ่ง (ด้วยเหตุผลที่ชัดเจน) ฉันคัดลอกในcwdของฉัน:
- ResourceHacker.exe : ฉันคิดว่ามันน่าสนใจที่จะดำเนินการเอง
- cmake.exe : ปฏิบัติการแบบสุ่มโดยไม่มีชุดข้อมูลเวอร์ชัน (ส่วนหนึ่งของการติดตั้งv3.6.3บนเครื่องของฉัน)
ก่อนที่จะดำเนินการต่อไปฉันต้องการพูดถึงว่าResourceHackerมีเอาต์พุตเทอร์มินัลที่ตลกและชิ้นส่วนคัดลอก / วางต่อไปนี้อาจสร้างความสับสนเล็กน้อย
1. การตั้งค่า
นี่เป็นเหมือนขั้นตอนเบื้องต้นในการทำความคุ้นเคยกับสิ่งแวดล้อมเพื่อแสดงว่าไม่มีธุรกิจขี้ขลาดเกิดขึ้น ...
e:\Work\Dev\StackOverflow\q000284258> sopr.bat
*** Set shorter prompt to better fit when pasted in StackOverflow (or other) pages ***
[prompt]> dir
Volume in drive E is Work
Volume Serial Number is 3655-6FED
Directory of e:\Work\Dev\StackOverflow\q000284258
2019-01-28 20:09 <DIR> .
2019-01-28 20:09 <DIR> ..
2016-11-03 09:17 5,413,376 cmake.exe
2019-01-03 02:06 5,479,424 ResourceHacker.exe
2019-01-28 20:30 496 ResourceHacker.ini
3 File(s) 10,893,296 bytes
2 Dir(s) 103,723,261,952 bytes free
[prompt]> set PATH=%PATH%;c:\Install\x64\CMake\CMake\3.6.3\bin
[prompt]> .\cmake --help >nul 2>&1
[prompt]> echo %errorlevel%
0
[prompt]> .\ResourceHacker.exe -help
[prompt]>
==================================
Resource Hacker Command Line Help:
==================================
-help : displays these abbreviated help instructions.
-help commandline : displays help for single commandline instructions
-help script : displays help for script file instructions.
[prompt]> echo %errorlevel%
0
อย่างที่เห็นไฟล์ปฏิบัติการนั้นใช้ได้มันทำงานได้ดีและนี่คือลักษณะของรายละเอียด (ที่เราสนใจ):
2. ทรัพยากร
ไฟล์ทรัพยากรคือไฟล์ข้อความที่มีทรัพยากร ทรัพยากร (แบบง่าย) มี:
สำหรับรายละเอียดเพิ่มเติมตรวจสอบ[MS.Docs]: เกี่ยวกับแฟ้มทรัพยากร มีเครื่องมือมากมาย (กล่าวถึงในคำตอบที่มีอยู่) ที่อำนวยความสะดวกในการแก้ไขไฟล์ทรัพยากรเช่น:
ถัดไปเพื่อให้ทรัพยากรถูกฝังลงใน. exe ( .dll , ... ) จะต้องคอมไพล์เป็นรูปแบบไบนารีซึ่งพอดีกับรูปแบบPE อีกครั้งมีเครื่องมือมากมายที่สามารถบรรลุเป้าหมายนี้ได้ แต่อย่างที่คุณคาดเดาได้ว่าฉันจะติดResource Hacker ( -action compile
)
[prompt]> :: Extract the resources into a file
[prompt]> .\ResourceHacker.exe -open .\ResourceHacker.exe -save .\sample.rc -action extract -mask VersionInfo,, -log con
[prompt]>
[28 Jan 2019, 20:58:03]
Current Directory:
e:\Work\Dev\StackOverflow\q000284258
Commandline:
.\ResourceHacker.exe -open .\ResourceHacker.exe -save .\sample.rc -action extract -mask VersionInfo,, -log con
Open : e:\Work\Dev\StackOverflow\q000284258\ResourceHacker.exe
Save : e:\Work\Dev\StackOverflow\q000284258\sample.rc
Success!
[prompt]> :: Modify the resource file and set our own values
[prompt]>
[prompt]> :: Compile the resource file
[prompt]> .\ResourceHacker.exe -open .\sample.rc -save .\sample.res -action compile -log con
[prompt]>
[28 Jan 2019, 20:59:51]
Current Directory:
e:\Work\Dev\StackOverflow\q000284258
Commandline:
.\ResourceHacker.exe -open .\sample.rc -save .\sample.res -action compile -log con
Open : e:\Work\Dev\StackOverflow\q000284258\sample.rc
Save : e:\Work\Dev\StackOverflow\q000284258\sample.res
Compiling: e:\Work\Dev\StackOverflow\q000284258\sample.rc
Success!
[prompt]> dir /b
cmake.exe
ResourceHacker.exe
ResourceHacker.ini
sample.rc
sample.res
ในกรณีของคุณไม่จำเป็นต้องบันทึกและแก้ไขไฟล์ทรัพยากรเนื่องจากไฟล์จะปรากฏอยู่แล้วฉันเพิ่งทำเพื่อสาธิตวัตถุประสงค์ ด้านล่างเป็นไฟล์ทรัพยากรหลังจากแก้ไขแล้ว (ก่อนที่จะคอมไพล์)
ตัวอย่าง.rc :
1 VERSIONINFO
FILEVERSION 3,1,4,1592
PRODUCTVERSION 2,7,1,8
FILEOS 0x4
FILETYPE 0x1
{
BLOCK "StringFileInfo"
{
BLOCK "040904E4"
{
VALUE "CompanyName", "Cristi Fati\0"
VALUE "FileDescription", "20190128 - SO q000284258 demo\0"
VALUE "FileVersion", "3.1.4.1592\0"
VALUE "ProductName", "Colonel Panic\0"
VALUE "InternalName", "100\0"
VALUE "LegalCopyright", "(c) Cristi Fati 1999-2999\0"
VALUE "OriginalFilename", "ResHack\0"
VALUE "ProductVersion", "2.7.1.8\0"
}
}
BLOCK "VarFileInfo"
{
VALUE "Translation", 0x0409 0x04E4
}
}
3. ฝัง
นอกจากนี้ยังจะดำเนินการโดยResource Hacker ( -action addoverwrite
) เนื่องจากไฟล์. exeถูกคัดลอกไปแล้วฉันจะแก้ไขทรัพยากรให้ถูกต้อง
[prompt]> .\ResourceHacker.exe -open .\cmake.exe -save .\cmake.exe -res .\sample.res -action addoverwrite -mask VersionInfo,, -log con
[prompt]>
[28 Jan 2019, 21:17:19]
Current Directory:
e:\Work\Dev\StackOverflow\q000284258
Commandline:
.\ResourceHacker.exe -open .\cmake.exe -save .\cmake.exe -res .\sample.res -action addoverwrite -mask VersionInfo,, -log con
Open : e:\Work\Dev\StackOverflow\q000284258\cmake.exe
Save : e:\Work\Dev\StackOverflow\q000284258\cmake.exe
Resource: e:\Work\Dev\StackOverflow\q000284258\sample.res
Added: VERSIONINFO,1,1033
Success!
[prompt]> copy ResourceHacker.exe ResourceHackerTemp.exe
1 file(s) copied.
[prompt]> .\ResourceHackerTemp.exe -open .\ResourceHacker.exe -save .\ResourceHacker.exe -res .\sample.res -action addoverwrite -mask VersionInfo,, -log con
[prompt]>
[28 Jan 2019, 21:19:29]
Current Directory:
e:\Work\Dev\StackOverflow\q000284258
Commandline:
.\ResourceHackerTemp.exe -open .\ResourceHacker.exe -save .\ResourceHacker.exe -res .\sample.res -action addoverwrite -mask VersionInfo,, -log con
Open : e:\Work\Dev\StackOverflow\q000284258\ResourceHacker.exe
Save : e:\Work\Dev\StackOverflow\q000284258\ResourceHacker.exe
Resource: e:\Work\Dev\StackOverflow\q000284258\sample.res
Modified: VERSIONINFO,1,1033
Success!
[prompt]> del /f /q ResourceHackerTemp.*
[prompt]> dir
Volume in drive E is Work
Volume Serial Number is 3655-6FED
Directory of e:\Work\Dev\StackOverflow\q000284258
2019-01-28 21:20 <DIR> .
2019-01-28 21:20 <DIR> ..
2016-11-03 09:17 5,414,400 cmake.exe
2019-01-03 02:06 5,479,424 ResourceHacker.exe
2019-01-28 21:17 551 ResourceHacker.ini
2019-01-28 20:05 1,156 sample.rc
2019-01-28 20:59 792 sample.res
5 File(s) 10,896,323 bytes
2 Dir(s) 103,723,253,760 bytes free
อย่างที่เห็นฉันต้องใช้เคล็ดลับเล็ก ๆ น้อย ๆ ( gainarie ) เพราะฉันทำไม่ได้ (อย่างน้อยฉันก็ไม่คิดว่าจะทำได้) แก้ไข. exeขณะใช้งาน
4. ทดสอบ
นี่เป็นเฟสทางเลือกเพื่อให้แน่ใจว่า:
- ไฟล์ปฏิบัติการยังคงใช้งานได้ (ไม่ได้ยุ่งเหยิงในกระบวนการ)
- มีการเพิ่ม / อัปเดตทรัพยากร
[prompt]> .\cmake --help >nul 2>&1
[prompt]> echo %errorlevel%
0
[prompt]> .\ResourceHacker.exe -help
[prompt]>
==================================
Resource Hacker Command Line Help:
==================================
-help : displays these abbreviated help instructions.
-help commandline : displays help for single commandline instructions
-help script : displays help for script file instructions.
[prompt]> echo %errorlevel%
0
และรายละเอียดของพวกเขา:
UpdateResource
ฟังก์ชั่นถ้างานอัพเดตเวอร์ชั่นใน pe ที่มีอยู่