as3加密入门-4使用avm2内嵌式汇编指令混淆简介

来源:互联网 发布:oppo手机usb共享网络 编辑:程序博客网 时间:2024/05/29 19:16

as3加密入门-4使用avm2内嵌式汇编指令混淆简介

from: http://bbs.9ria.com/viewthread.php?tid=48730

最近在考虑SWF安全方面的技术,看到一些关于这方面不错的技术文章,记录下来方便查阅.以下为转载内容:

 

(p.s.这篇教程也可以看做as3c的入门教程
这里主要是使用avm2跳转指令Jump,在在源代码中写入asm进行跳转,两个跳转中间插入大量无用代码(不会被执行,但反编译出的文件中看得到)
asv对跳转反编译不好,会出现“//unresolved jump”字样,sothink反编译出代码也无法实现原跳转。
重编译后,无用代码会被执行。总之,使用跳转指令后,as3代码基本上可以混淆到无法还原,要想破解,只能手动进行(人工翻译pcode),
所以只要你的原始代码够长,没人愿意去翻译/破解你的代码。

跳转指令好处就是大量无用代码不会被执行,混淆不会降低运行效率。
不太推荐跳转指令或asm混淆,因为内嵌汇编写东西比较麻烦(主要是现在avm2没有一个像as2时代的flasm那样好用的工具)。
当然,如果你能研究透avm2指令,使用asm像as3一样熟练,优化代码、加密、破解都不在话下。
as2可以用flasm直接操作(编译/反编译)bytecode,这是高手们作优化、加密、游戏作弊、破解甚至逆向工程的一件利器。
可惜flasm没再更新,只支持到flash8。不过幸好我们还有其继承者,Joa Ebert 的As3c,虽然可能使用起来不如flasm那么方便。

推荐工具:As3c

简单的跳转混淆:

1. 到As3c项目地址http://code.google.com/p/as3c/source/browse/#svn/trunk/bin/Release
下载As3c.exe,As3c.pdb,SwfLibrary.dll,SwfLibrary.pdb,zlib.net.dll几个文件,
以及所需as3类文件http://code.google.com/p/as3c/source/browse/#svn/trunk/src/as3/AsmLibrary/src/de
(下载整个de文件夹)
将As3c.exe,As3c.pdb,SwfLibrary.dll,SwfLibrary.pdb,zlib.net.dll几个文件和de文件夹保存到C:/as3c
附件中已包含以上文件,可直接下载附件。
2.写好待混淆代码:

  1. package {
  2. import flash.display.*;
  3. import flash.text.*;
  4.         public class Jump extends Sprite {
  5. var Bruce_Jawn_Encrypt= new TextField();
  6. Bruce_Jawn_Encrypt.text="跳转指令";
  7. Bruce_Jawn_Encrypt.textColor=0xff0000;
  8. Bruce_Jawn_Encrypt.scaleX=10;
  9. Bruce_Jawn_Encrypt.scaleY=10;
  10. addChild(Bruce_Jawn_Encrypt);
  11. }
  12. }
复制代码

3.原代码中插入asm跳转指令,并用注释分割

  1. package {
  2. import flash.display.*;
  3. import flash.text.*;
  4. import de.popforge.asm.Op;
  5. import de.popforge.asm.__asm;
  6.         public class Jump extends Sprite {
  7. __asm(Op.jump('.text'));//跳转到.text位置
  8. //==============================
  9. //==============================
  10. //**********此处随便插入大量混淆用代码(不会被执行)
  11. //==============================
  12. //==============================
  13. __asm('.text:'); // .text位置
  14. var Bruce_Jawn_Encrypt= new TextField();
  15. __asm(Op.jump('.text2')); //跳转到.text2位置
  16. //==============================
  17. //==============================
  18. //**********此处随便插入大量混淆用代码(不会被执行)
  19. //==============================
  20. //==============================
  21. __asm('.text2:'); // .text2位置
  22. Bruce_Jawn_Encrypt.text="跳转指令";
  23. __asm(Op.jump('.text3')); //跳转到.text3位置
  24. //==============================
  25. //==============================
  26. //**********此处随便插入大量混淆用代码(不会被执行)
  27. //==============================
  28. //==============================
  29. __asm('.text3:'); // .text3位置
  30. Bruce_Jawn_Encrypt.textColor=0xff0000;
  31. __asm(Op.jump('.text4')); //跳转到.text4位置
  32. //==============================
  33. //==============================
  34. //**********此处随便插入大量混淆用代码(不会被执行)
  35. //==============================
  36. //==============================
  37. __asm('.text4:'); // .text4位置
  38. Bruce_Jawn_Encrypt.scaleX=10;
  39. Bruce_Jawn_Encrypt.scaleY=10;
  40. __asm(Op.jump('.text5')); //跳转到.text5位置
  41. //==============================
  42. //==============================
  43. //**********此处随便插入大量混淆用代码(不会被执行)
  44. //==============================
  45. //==============================
  46. __asm('.text5:');// .text5位置
  47. addChild(Bruce_Jawn_Encrypt);
  48. __asm(Op.jump('.text6')); //跳转到.text6位置
  49. //==============================
  50. //==============================
  51. //**********此处随便插入大量混淆用代码(不会被执行)
  52. //==============================
  53. //==============================
  54. __asm('.text6:');// .text6位置
  55. }
  56. }
复制代码

4.在//********** 处随便复制插入大量混淆用代码
5.编译Jump.as得到Jump.swf,复制到C:/as3c文件夹(此时asm跳转指令未编译,运行swf会发现混淆代码将被执行)
6.使用as3c编译asm跳转指令
运行dos命令符,cd到C:/as3c文件夹
as3c.exe -inline Jump.swf
7.再次测试Jump.swf,跳转成功,混淆代码不被执行。
上面的例子比较简单,要想达到更好跳转混淆效果,可以把跳转加到循环,嵌套函数,条件判断…语句中,并打乱代码顺序,使用多次折返跳转而非例子中的顺序跳跃。
as3c.zip (157.61 KB)