1.Python的源码编译和反编译
2.Ubuntu bochs源码安装时出现: make: *** 没有指明目标并且找不到 makefile。 停止。下载
3.关于Majiro引擎的源码汉化记录
4.exe应用程序怎么查看里面的源代码
5.Ubuntuä¸Bochsçè°è¯åè½å¦ä½å¼å¯ï¼
Python的编译和反编译
在开发中,有时会遇到小伙伴提供的下载代码是pyc或pyd文件,这些文件在常规的源码文本编辑器如VSCode中无法直接阅读或修改。那么,下载外国源码不支持中文显示这些文件分别是源码什么,如何生成,下载以及如何反编译它们呢?
首先,源码pyc文件代表“compiled”,下载是源码Python通过解释器将模块的源代码转换后的字节码文件。它实质上是下载一个字节码文件,用于优化运行效率。源码Python作为解释性语言,下载没有编译过程,源码运行时通过解释器逐行解释执行。
而pyd文件是正品朔源码Python扩展模块的扩展名,用于表示使用C或C++编写的二进制Python扩展模块文件。.pyd文件是编译后的二进制文件,包含编译后的扩展模块代码以及与Python解释器交互所需的信息。通过import语句,开发者可以像导入普通的Python模块一样导入和使用这些文件。
对于如何生成pyc文件,有几种常见方式。通常情况下,直接调用import命令后,程序文件夹中会自动生成一个__pycache__文件夹,并在其中生成对应的.pyc文件。此外,对于单一的脚本文件生成.pyc,可以通过特定公式实现。对于需要加密保护的代码,可以利用pyarmor工具进行高级加密操作,天龙公式源码通过命令行如`python pyarmor obfuscate --advanced 1 foo.py`、`python pyarmor obfuscate --advanced 2 foo.py`等生成加密的.pyc文件。
至于反编译,即还原.pyc和.pyd文件到原始的源代码形式,通常需要使用专门的工具或软件。反编译过程可以揭示源代码的逻辑结构、变量、函数等,对于理解代码、修复错误或学习代码实现非常有帮助。常见的反编译工具包括PyODIDE、pydisasm等,它们可以解析字节码并尝试恢复源代码。然而,反编译过程可能无法完全还原原始代码,尤其是qe官方源码经过加密或混淆处理的代码。
综上所述,pyc和pyd文件分别代表字节码文件和Python扩展模块,通过特定的流程生成,而反编译则是将这些编译后的文件还原成原始的源代码形式。在实际开发中,理解这些概念对于提高代码管理和安全性至关重要。
Ubuntu bochs源码安装时出现: make: *** 没有指明目标并且找不到 makefile。 停止。
用ubuntu中的ubuntu软件安装中心安装的bochs不带调试功能,所以我们要用源码安装bochs.
从piler default output file name… configure: error: C compiler cannot create executables
解决办法:
[thornbird@thornbird bochs-2.4]$ sudo apt-get install libc6-dev
问题2:
...
checking how to run the C++ preprocessor... /lib/cpp
configure: error: C++ preprocessor "/lib/cpp" fails sanity check
See `config.log' for more details.
解决方法:
[thornbird@thornbird bochs-2.4]$ sudo apt-get install build-essential
问题3:
[thornbird@thornbird bochs-2.4]$ make
make: *** 没有指明目标并且找不到 makefile.停止。
解决方法:
[thornbird@thornbird bochs-2.4]$ sudo apt-get install build-essential
问题4:
...
checking for wxWidgets library version...
checking for default gui on this platform... x
ERROR: X windows gui was selected, but X windows libraries were not found.
解决方法: 配置的时候加上"--with-nogui "
或者改成:[thornbird@thornbird bochs-2.4]$sudo apt-get install xorg-dev (建议)
问题5:
Package gtk+-2.0 was not found in the pkg-config search path.Perhaps you should add the directory containing `gtk+-2.0.pc'to the PKG_CONFIG_PATH environment variableNo package 'gtk+-2.0' foundERROR: pkg-config was not found, or unable to access the gtk+-2.0 package.Install pkg-config and the gtk+ development package,or disable the gui debugger, or the wxWidgets display library (whichever is being used).
解决方法:
[thornbird@thornbird bochs-2.4]$sudo apt-get install libgtk2.0-dev
问题6:
install: 无法获取"./bochsdbg" 的文件状态(stat): 没有该文件或目录
解决办法:需要在make后,将bochs拷贝一份,命名为bochsdbg
[thornbird@thornbird bochs-2.4]$ cp bochs bochsdbg
关于Majiro引擎的汉化记录
在处理Majiro引擎相关工作时,遇到的挑战在于它的工具较为分散且历史久远,主要采用OCaml编写。对于使用GBK编码文本导入的外包交付源码需求,我成功修改了源码并记录了流程,以供有需要的开发者参考,避免走不必要的弯路。
为了使Majiro引擎程序本体能够正常播放语音,需要对部分关键代码进行修改。因为程序通常基于日文字符来判断语音播放,当导入GBK文本时,字符对应的十六进制编码发生改变。通过使用OllyDbg工具直接打开主程序并搜索特定代码片段,将`push 0x`改为`push 0xa1b8`即可。这一步操作需进行2-3次,具体位置可能稍有不同,建议在OllyDbg中定位后,使用Winhex进行修改。推荐使用wxMEdit编辑器,它支持Unicode家族、SJIS和GBK等常见编码,方便直接浏览二进制文件内容。
对于Majiro引擎的ARC封包处理,使用`arc_conv`工具可以实现有效转换。Majo对象文件(mjo)在解密状态下有其特定的文件头,如`MajiroObjV1.`表示解密版本,`MajiroObjX1.`则为加密版本。解密版本的mjo文件更易于操作,使用wxMEdit查看时,原版文件需使用SJIS编码才能正确显示字符串内容。
在讨论Majiro引擎的汉化工作时,通常涉及到`mjasm`和`mjdisasm`两个重要工具。通过使用`mjdisasm`,可以将mjo脚本拆分为mjs和sjs文件,其中mjs文件包含脚本逻辑,sjs文件包含字符串。而`mjasm`则可以将修改后的mjs和sjs文件组合成新的mjo文件。由于原版mjo文件采用SJIS编码,无法直接用于汉化工作,因此作者选择了重新编译支持GBK编码导入的版本。
Mjdev工具作为Majiro引擎的重要组成部分,提供了编译好的版本,包含了一系列组件。汉化工作主要依赖于`mjasm`和`mjdisasm`两个工具,它们分别用于处理mjs和sjs文件的编码转换。要实现汉化,作者自行编译了一个支持GBK编码导入的Mjdev版本,通过配置相应的环境依赖,包括OCaml、ExtLib库以及bash环境,最终实现了对Majiro引擎的适应性增强。
针对操作系统环境的优化,作者推荐使用Windows的Ubuntu子系统,替代传统的cygwin环境,以简化配置过程。通过安装Ubuntu子系统并创建普通用户,可以更方便地使用opam等工具来管理OCaml环境。在完成环境配置后,使用opam创建OCaml 3..0的编译环境,并通过下载、编译和安装ExtLib库,实现了Mjdev工具的自定义编译。
为了解决Mjdev中的一些兼容性问题,如对于GBK编码的支持以及特定opcode和指令格式的处理,作者对源代码进行了针对性的修改。具体来说,修改了判断有效字符范围的代码,更新了mjs文件的处理逻辑,以及调整了mjo文件的读取规则,以适应GBK编码的文本。这些修改不仅提升了工具的兼容性,也使得Majiro引擎在处理非日文编码的文本时更加灵活。
最后,作者提供了其编译的Mjdev版本的下载链接,以供有需要的开发者使用。链接中包含了针对GBK编码优化的版本,需要在bash环境下执行。针对原版代码中存在的指令生成顺序问题,作者已进行了修正,以避免不必要的调试工作。
exe应用程序怎么查看里面的源代码
扩展名为exe 的文件来源很多,可以是VB 、VC、 VF、Delphi等不同的软件编译生成的,不同的环境应该用不同的反编译工具,具体的工具可在网上查询下载到。
Windows软件开发工具包(SDK)提供一个叫做 DUMPBIN 的极有用的工具,它有许多有助编程分析的功能. 其中包括反编译功能,反编译命令格式:
dumpbin /DISASM 你的文件.exe
DUMPBIN 详细用法参考,可到微软件公司网站查询介绍。
Ubuntuä¸Bochsçè°è¯åè½å¦ä½å¼å¯ï¼
$ sudo apt-get install vgabios bochs bochs-x bximage
æ²å ¥è¿æ ·ä¸è¡å½ä»¤ï¼ä¸ä¸ä¼å¿å°±è£ 好äºã缺ç¹:没æè°è¯åè½çï¼è¿æ¾ç¶ä¸è½æ»¡è¶³æ们çéè¦ï¼æ以æ好çæ¹æ³è¿æ¯ä»æºä»£ç å®è£ .
é¦å ä¸è½½ææ°çæ¬å°Bochs: /getcurrent.html
ä¸è½½ççæ¬æ¯bochs-2.4.6.tar.gzï¼é£ä¹å®è£ è¿ç¨å·®ä¸å¤æ¯è¿æ ·çï¼
$ tar zxvf bochs-2.4.6.tar.gz
$ cd bochs-2.4.6.
$ ./configure --enable-debugger --enable-disasm
$ make
$ sudo make install
--enable-debugger è¿ä¸ªå°±æ¯å¼å¯è°è¯åè½
2025-01-19 10:38237人浏览
2025-01-19 10:341063人浏览
2025-01-19 10:21721人浏览
2025-01-19 10:151205人浏览
2025-01-19 10:10329人浏览
2025-01-19 09:13813人浏览
據央視新聞客戶端消息,10月27日,朝鮮國防省發言人發布了韓國無人機滲透進入平壤事件的最終偵察結果,結果驗證了在朝鮮首都圈領域被發現的由韓國放飛的無人機起飛地點、入侵渠道和滲透目的。該發言人表示,朝鮮
1.Vue3中deep样式穿透的使用细节及源码解析2.element-plus源码学习日志-033.element-ui 组件库 button 源码分析4.VXETable 中嵌套 ElementPl
1.彩虹骑士2021手游安卓游戏高速2.无奔跑 不青春丨万事兴集成灶赞助武夷山彩虹跑大赛!3.2021成都崇州加勒比冒险水世界怎么样?附玩法)4.江西彩虹光伏有限公司怎么样?5.天涯明月刀手游彩虹锦鲤