设为首页收藏本站官方微博

[简单教程]解包器的分析与制作动画教程 动画A+B部分

 关闭 [复制链接]
查看: 15556|回复: 95
打印 上一主题 下一主题

[简单教程]解包器的分析与制作动画教程 动画A+B部分

跳转到指定楼层
楼主
发表于 2009-4-21 04:58 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

[简单教程]解包器的分析与制作动画教程 动画A+B部分

分析教程内有QQ邮件    已经过期: W  h: V6 P3 _3 X: i' i9 X
等FTP好了我再上传8 F0 S) ?8 j6 D" `8 Y% B. E# n

: K- v* F( _  E# Q' ^
3 X6 x; N. {1 O4 l, R- h2 ^上传完毕
4 E3 t1 S! x% }) oftp好像上传了看不到下载目录..或许我的账号有误吧& p5 M8 z' u( p' q! h: h

" q' X7 i. R3 \' I# }& B6 k, q$ k" \写了那么久,值得鼓励一下吧~回帖吧~! p' |# Y" `; i1 A

* J! \$ r0 Z7 x刚刚发完就给下载了...不回帖支持~不厚道么~内附解包代码
  v7 D% w& y1 [* K4 G: F$ t3 E; F
/ O5 P% T: x6 m1 S# x0 W; S
游客,如果您要查看本帖隐藏内容请回复

& y+ R  X7 r( D9 i) Q1 D6 @: S4 I# ^- O: C% Q6 C

( V" N( Y' Q) y0 `& i* ]' X/ ?2 ^! J6 V, C5 X' t; N
[strike]QQmail上传ing...[/strike]
( @* O! b3 T% M- o1 t2 N* u5 `
! X4 y( g3 H1 E) K7 {教程分上下,A是准备工作和废话
, |* ^$ J8 O- N7 v            B是废话+操作4 |3 Y9 q" s$ p' U# w1 F' Y: j2 {

4 E3 Q; N2 T( }6 e. g5 @9 c8 G3 D水品有限...所以东西自然也有限,高手自觉略过吧.....
5 M9 m9 M. k9 o3 q; t  t5 A3 y. X7 u' O: ]+ d* T/ C
主要代码拷贝到这里了,那个俺学习的时候,给我踩踩blog...
# ]- F  ^0 f4 ]; a% B( L
& B! l1 a, ?  J  s教程补充:    # l/ m* _+ [) d( J
这个只是一个demo而已..还有太多地方该去改进,这个活交给聪明的你了。   
+ T* h% f* [: }本来还有一个小工具的,可是呢,受限于信用问题,已经投稿便不能发了。。。
5 E( L5 N& S  _$ u4 w操作文件C是王道,但是使用其他工具也没有问题的,甚至是轻量脚本php9 _  t+ R- T" _9 e
如果你也用VB6或者VBNET可以考虑FSO,[其实和GET PUT一样的]5 l; c  N- l+ Z! {
例子中没有告诉大家要注意资源的使用,比如初始化[虽然我有做]和; Q) i1 q' A3 `* o
注销使用了的变量,我放到程序结束的时候了。
, v6 H& L1 K1 M  q) T' ^5 t程序中没有检验传入数据,请注意,那个提取我检验过了,所以就删除掉了,
8 S% Q; d( ]% S/ d 那个indexB,的范围改成图片的数量就可以了,估计是手误吧...
! a+ S  T- q1 E0 J 前面几个字符的处理其实也简单,不停的更换前面的那个头部结构声明,然后读取
4 I& L6 ?. u4 u. d6 |  |看看能和什么匹配就好,或者你就跟踪程序操作文件吧,在读取文件的API处下断
# k/ v2 Q  u, H" t; q( |5 H3 m我去学习了,所以去踩博客吧~呵呵~  k. x. }" m: ?. y5 @
  1. Private Sub FirUnPack2()
  2.     Dim strPathLen    As Integer
  3.     Dim strPathChar() As String * 1
  4.     Dim strResPath    As String
  5.     Dim intSize       As Integer
  6.     Dim bData()       As Byte
  7.     Dim lngSize       As Long
  8.     Dim strFilePath   As String
  9.     Dim tmpStep       As Single, lngIndex As Long, lngFileNumA As Long, lngFileNumB As Long
  10.     strFilePath = App.Path & "\test.adv"
  11.     lngFileNumA = FreeFile
  12.     tmpStep = &HC + 1
  13.     Dim lngIndexB As Long
  14.     Open strFilePath For Binary As #lngFileNumA
  15.    
  16.     For lngIndexB = 0 To 1064
  17.         Get #lngFileNumA, tmpStep, strPathLen
  18.         ReDim strPathChar(1 To strPathLen)
  19.         tmpStep = tmpStep + 4
  20.         Get #lngFileNumA, tmpStep, strPathChar()
  21.         strResPath = ""
  22.         For lngIndex = 1 To strPathLen
  23.             strResPath = strResPath & strPathChar(lngIndex)
  24.         Next
  25.    
  26.         tmpStep = tmpStep + Len(strResPath) + 2
  27.         Get #lngFileNumA, tmpStep, intSize
  28.        
  29.         If intSize = 0 Then
  30.             tmpStep = tmpStep - 2
  31.             Get #lngFileNumA, tmpStep, intSize
  32.    
  33.             If intSize < 0 Then
  34.                 lngSize = 65536 + intSize
  35.                 ReDim bData(1 To lngSize)
  36.                 tmpStep = tmpStep + 4
  37.                 Get #lngFileNumA, tmpStep, bData()
  38.    
  39.                 tmpStep = tmpStep + lngSize
  40.    
  41.             Else
  42.    
  43.                 ReDim bData(1 To intSize)
  44.                 tmpStep = tmpStep + 4
  45.                 Get #lngFileNumA, tmpStep, bData()
  46.    
  47.                 tmpStep = tmpStep + intSize
  48.    
  49.             End If
  50.         Else
  51.             tmpStep = tmpStep - 2
  52.             Get #lngFileNumA, tmpStep, lngSize
  53.             ReDim bData(1 To lngSize)
  54.             tmpStep = tmpStep + 4
  55.             Get #lngFileNumA, tmpStep, bData()
  56.             tmpStep = tmpStep + lngSize
  57.         End If
  58.    
  59.         lngFileNumB = FreeFile
  60.         CreateNewDirectory (Mid$(strResPath, 1, InStrRev(strResPath, "\")))
  61.         strFilePath = strResPath
  62.         Open strFilePath For Binary As #lngFileNumB
  63.         Put #lngFileNumB, 1, bData()
  64.         Close #lngFileNumB
  65.     Next lngIndexB
  66.     Close #lngFileNumA
  67. End Sub
复制代码
[/hide]
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 很美好很美好 很差劲很差劲
回复

使用道具 举报

沙发
 楼主| 发表于 2009-4-21 04:59 | 只看该作者
自己的沙发自己占~
回复 支持 反对

使用道具 举报

板凳
发表于 2009-4-21 06:09 | 只看该作者
强烈支持
回复 支持 反对

使用道具 举报

地板
发表于 2009-5-3 13:03 | 只看该作者
支持了 [s:2]
回复 支持 反对

使用道具 举报

5#
发表于 2009-5-5 20:23 | 只看该作者
支持一下,下来学习看看,谢谢
回复 支持 反对

使用道具 举报

6#
发表于 2009-5-6 13:32 | 只看该作者
这个是什么东西啊?
回复 支持 反对

使用道具 举报

7#
发表于 2009-5-6 20:32 | 只看该作者
强烈支持楼主
回复 支持 反对

使用道具 举报

8#
发表于 2009-5-6 20:37 | 只看该作者
楼主更新下下载地址吧
回复 支持 反对

使用道具 举报

9#
发表于 2009-5-26 00:11 | 只看该作者
有點興趣...下看看
回复 支持 反对

使用道具 举报

10#
发表于 2009-5-26 10:44 | 只看该作者
十分感谢!
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

冒险解谜游戏中文网 ChinaAVG

官方微博官方微信号小黑屋 微信玩家群  

(C) ChinaAVG 2004 - 2019 All Right Reserved. Powered by Discuz! X3.2
辽ICP备11008827号 | 桂公网安备 45010702000051号

冒险,与你同在。 冒险解谜游戏中文网ChinaAVG诞生于2004年9月9日,是全球华人共同的冒险解谜类游戏家园。我们致力于提供各类冒险游戏资讯供大家学习交流。本站所有资源均不用于商业用途。

快速回复 返回顶部 返回列表