首页 > 其他分享 >Flash加密解密(一)——doswf混淆还原

Flash加密解密(一)——doswf混淆还原

时间:2023-04-07 10:03:12浏览次数:45  
标签:混淆 加密 doswf 代码 Flash 解密 swf 编译


 研究了一段时间的加密解密技术,对比其他类型的软件加密,swf加密方法是非常有限的,想要彻底保护swf十分困难。而且随着技术的进步,个人认为swf加密技术难以抵挡解密技术的发展,只能在一定程度给予保护。

这次主要带大家分析doswf中最简单的混淆处理。后续我会给大家介绍使用doswf最强加密后的文件如何恢复出来。介绍这些也是让大家更深入的了解swf中的原理,同时也可以了解到保护自己swf的一些基本方法。

混淆的意思就是改变函数或变量名,让解密者难以很直观的看出其中的含义。而在swf中,我们可以利用十六进制编辑器对其中的变量名和函数名进行更改,改成一些奇怪的符号或者编译难以通过的非ANSI字符,这并不影响swf的运行,但是反编译回去再编译就会出现编译错误。

 

好的,现在开始,我们目标很简单,还原被doswf混淆的源代码:


本帖隐藏的内容

首先我们准备了一个测试文件:


所有的代码很简单:


1. package 
2. {

3. 
4.         import flash.display.MovieClip;
5.         
6.         public class Main extends MovieClip
7.         {

8.                 private var a:int;
9.                 private var b:String;
10.                 public function Main()
11.                 {

12.                         var i:int;
13.                         a=45;
14.                         b="test_swf";
15.                         tip.text=b;
16.                         test_mc.rotation = a;
17.                         for (i=1; i<5; i++)
18.                         {                                
19.                                 trace(i);
20.                                 fun_alp();
21.                         }
22.                 }
23. 
24.                 function fun_alp()
25.                 {

26.                         test_mc.alpha = test_mc.alpha*0.9;
27.                 }
28.         }
29. }

复制代码

现在我们用doswf进行混淆处理:


其他所有的加密都不勾选,我们只进行混淆处理。

我们用asv来查看其中的代码:


我们可以看到其中有许多奇怪的字符,如果反编译回去再进行编译是会发生错误的。

我们可以利用ASV中的一个功能帮我们处理一下其中的非ANSI字符:


修正过后我们导出文件,进行编译,会发现还是会有一些错误,我们可以根据提示修正这些代码。

修正好后,这个文件就可以编译运行了。(如果你使用的asv版本很高,有些问题将不会出现)


2013-10-29 10:55:08 上传


下载附件 (47.69 KB)

我们发现这个文件被doswf加入了水印,同时还会每间隔一段时间自动弹窗(试用版的限制)。

后面我会给大家分析doswf生成的代码的含义,以及去除试用版限制的代码。

标签:混淆,加密,doswf,代码,Flash,解密,swf,编译
From: https://blog.51cto.com/u_4387387/6174601

相关文章

  • Flash加密解密(三)——特殊混淆让asv2010解析代码失败
    1.Flash加密解密(一)——doswf混淆还原2.Flash加密解密(二)——Doswf生成代码分析3.Flash加密解密(三)——特殊混淆让asv2010解析代码失败从前面两节的分析可以看出,脆弱的swf文件极其容易被一些现成的工具反编译回可执行源代码。一旦可以进行动态调试,那么这个文件将被他人掌控,即使你使用......
  • 基于AHB_BUS的eFlash控制器的微架构设计
    eFlash微架构设计1.回顾架构设计2.Flash时序仿真2.1ahb_flashc项目目录docsrtlsimtbmodel2.2docs架构设计文档微架构设计文档集成需求文档DataSheet2.3modelmodel文件夹下放的是一些仿真模型(Flash的rtl代码)和一些文档,这里存放的模型是不可综合的,只用于仿真......
  • silverlight/Flash 跨域访问给新手的一点经验
      尝试向URI“http://www.luozhuang.com/web1/WebService.asmx”发出请求时出错。这可能是由于试图以跨域方式访问服务而又没有正确的跨域策略,或策略不适用于SOAP服务。您可能需要与该服务的所有者联系,以发布跨域策略文件并确保该文件允许发送SOAP相关......
  • flask:cbv源码分析、模板语法、请求与响应、session及源码分析、闪现(flash)、请求扩展
    目录一、cbv源码分析1.1基于类的视图写法1.2源码分析1.3分析源码,查找不传别名的时候为什么函数名会变成别名1.4flask的路由注册使用装饰器,如果写了一个登录认证装饰器,那么应该放在路由装饰器上还是下?1.5dispatch_request讲解1.6知识点总结二、模板语法2.1py2.2html三、请......
  • 加密与解密之加壳程序
    描述自己实现一个简单的加壳程序,能够对选取程序的代码段进行加密,并添加外壳部分,在运行时还原本文分为三个部分:外壳程序,加壳程序,和用户交互程序外壳程序写到Stub.dll中,方便同加壳程序共享数据,获取原程序的PE文件信息将数据段合并到代码段,方便加壳程序读取并添加到原程序中......
  • 基于AHB_BUS的eFlash控制器的架构设计
    eFlash控制器的架构设计1.架构设计思路分析1.1含有的模块分析eFlash控制器是一个基于AHB的slave,所以需要一个AHB_slave_if处理AHB的信号。AHB_slave_if与AHB总线进行交互,对主设备的请求进行处理,还可以设置一些内部的寄存器,对AHB发送过来的信号进行解析。AHB_slave_if除了处......
  • 加密与解密之二次开发
    描述二次开发的含义:通过直接编辑二进制,来修改已编译好的程序,实现目标功能本文的原程序模拟一个windows是最常见的采用事件循环机制的窗口程序,通过二次开发,给这个程序上锁,加上一个验证身份框,只有输对用户名密码,才能正常使用程序功能原程序创建一个窗口,加入事件循环,响应窗口......
  • STM32 FSMC的 NOR FLASH B模式模拟LCD 8080时序
    STM32 FSMC:FSMC(FlexibleStaticMemoryController):翻译为:灵活的静态存储管理器。可管理的存储类型包括:NORFLASH 和 SRAMNANDFLASHPC Card(PC卡,不知道是什么东西)具体功能是将外部的存储设备映射为内部地址,可以用程序访问这些地址,间接地,由FSMC 自动产生相应时序,......
  • 【Flask】cbv源码分析 flask模板使用 flask请求与响应 session及源码分析 闪现flash
    目录上节回顾今日内容1cbv分析1.1源码分析2模板2.1app.py2.2index.html3请求与响应4session及源码分析4.1session的使用4.2源码分析4.3session执行原理5闪现6请求扩展练习上节回顾#1web框架 -django大而全-flask小而精-sanic-fastapi-同......
  • C# DES AES 加密解密
    ///<summary>///加密解密帮助类///</summary>publicstaticclassEncryptHelper{#regiondes实现///<summary>///Des默认密钥向量///</summary>publicstaticbyte[]DesIv={0x12,0x34,0x56,0x78,0x90,0xAB,0xCD,0xEF......