python解释NTFS runlist的代码

简介:

代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
#!/usr/bin/python3
#http://www.frombyte.com 张宇
import  os
import  sys
import  random
import  hashlib
import  struct
import  zlib
import  re
  
def  help_exit():
     print ( "  命令格式:" )
     print ( "  python3 %s <File name> <Start bytes> <Start LCN> <Start VCN>:"  %  sys.argv[ 0 ])
     print ( "      File name:要解释的包含runlist的文件名称" )
     print ( "      Start bytes:文件中要解释runlist的起始位置" )
     print ( "      Start LCN:runlist开始的参考LCN值,如果是一段完整的runlist,这个值应为0." )
     print ( "      Start VCN:runlist开始的参考VCN值,如果是一段没有0x20的runlist,这个值多数为0." )
     print ( "      *返回值:一个二维队列,打印结果。\n" )
     exit()
#通过抛出异常判断第一个参数是否是A-F
def  is_num_by_except(s):
     try :
         a = int (s, 16 )
         if  (a> 0  and  a< = 16 ):  return  True
         else return  False
     except  ValueError:
         return  False
     
if  len (sys.argv)! =  5  :
     print ( "  ***参数数量或格式错误!" )
     help_exit()
 
if  sys.argv[ 2 ].isdigit():
     spoi  =  int (sys.argv[ 2 ])
     if  spoi< 0 :
       print ( "***错误,起始字节位置不能取负值" )
       help_exit()
else :
     print ( "***错误,起始字节位置应为非负整数" )
     help_exit()
 
if  sys.argv[ 3 ].isdigit():
     slcn  =  int (sys.argv[ 3 ])
     if  slcn< 0 :
       print ( "***错误,起始LCN不能取负值" )
       help_exit()
else :
     print ( "***错误,起始LCN应为非负整数" )
     help_exit()
 
if  sys.argv[ 4 ].isdigit():
     svcn  =  int (sys.argv[ 4 ])
     if  svcn< 0 :
       print ( "***错误,起始VCN不能取负值" )
       help_exit()
else :
     print ( "***错误,起始VCN应为非负整数" )
     help_exit()
 
def  get_i(vl,ilen):
     q = 0
     for  in  range ( 0 ,ilen):
         =  q | ( vl[ 0 ][i] << i * 8  )
     
     #若为负数
     if  vl[ 0 ][ilen - 1 ] >  0x80 :
         =  -  ( 1  << ilen * 8  )
     return  q
 
=  open ( "%s" % sys.argv[ 1 ], 'rb' )
f.seek(spoi)
data  =  f.read( 1024 )
v1  =  1
=  0
lists  =  [[ 0  for  in  range ( 2 )] ]
del  lists[ 0 ]
 
while  True :
   =  struct.unpack_from( 'B' ,data,i)
   v1  =  t[ 0 ]
   if  v1  = =  0 :
     break
 
   v1_p  =  (v1 &  0xF0 ) >>  4
   v1_l  =  (v1 & 0xF )
   if  (v1_l > = 8 or  (v1_p > = 8 or  (v1_l  = =  0 ):
     print ( "***偏移%d:run list长度和位置字节有错误!***" % (i + spoi))
     break
 
   =  i + 1
   if  (i + 8 ) > =  1024 :
     break
   =  struct.unpack_from( '8s' ,data,i)
   v1_dl  =  get_i(t,v1_l)
   if  v1_dl <  0 :
     print ( "***偏移%d:run片断长度不能为负!***" % (i + spoi))
     break 
   
   =  i +  v1_l
   if  (i + 8 ) > =  1024 :
     break
   =  struct.unpack_from( '8s' ,data,i)
   v1_dp  =  get_i(t,v1_p)
   slcn  =  slcn  +  v1_dp
   lists.append([slcn,v1_dl])
 
   =  +  v1_p
   #print("%x,%x:%x,%x"%(v1_l,v1_p,v1_dl,slcn))
 
print ( "Runlist(共%d个片断):" % len (lists))
print ( "%20s%20s%20s" % ( "VCN" , "LCN" , "LEN" ))
for  in  lists:
   print ( "%20d%20d%20d" % (svcn,i[ 0 ],i[ 1 ]))
   svcn  + =  i[ 1 ]
 
f.close()


执行效果如下:

root@zhangyu-VirtualBox:~/NTFS-5# python3 read_runlist.py mft_source.img

  ***参数数量或格式错误!

  命令格式:

  python3 read_runlist.py <File name> <Start bytes> <Start LCN> <Start VCN>:

      File name:要解释的包含runlist的文件名称

      Start bytes:文件中要解释runlist的起始位置

      Start LCN:runlist开始的参考LCN值,如果是一段完整的runlist,这个值应为0.

      Start VCN:runlist开始的参考VCN值,如果是一段没有0x20的runlist,这个值多数为0.

      *返回值:一个二维队列,打印结果。


root@zhangyu-VirtualBox:~/NTFS-5# python3 read_runlist.py mft_source.img 5688 0 0

Runlist(共18个片断):

                 VCN                 LCN                 LEN

                   0               32212                   1

                   1              157952                   2

                   3              207115                   3

                   6              244046                   3

                   9              122523                   1

                  10              157991                   1

                  11              170296                   3

                  14               40552                   5

                  19              149853                   2

                  21              122721                   2

                  23              141674                   1

                  24              145783                   3

                  27              158109                   3

                  30              145820                   1

                  31              240236                   1

                  32              154081                   1

                  33              166379                   3

                  36              178711                   3






本文转自 张宇 51CTO博客,原文链接:http://blog.51cto.com/zhangyu/1943606,如需转载请自行联系原作者
目录
相关文章
|
2天前
|
存储 缓存 算法
Python性能优化:让你的代码更快更流畅
本文介绍了优化 Python 代码性能的十二个技巧,包括使用内置数据类型和函数、避免不必要的循环和递归、使用局部变量、利用生成器节省内存、选择合适的数据结构、并行和并发处理、使用第三方库、缓存减少重复计算、代码剖析和性能分析、优化算法和数据结构以及减少 I/O 操作。通过这些方法,开发者可以编写出运行更快、效率更高的 Python 程序。
|
3天前
|
算法 程序员 开发工具
GitHub上新!14个Python项目详细教程(附完整代码)
Python作为程序员的宠儿,越来越得到人们的关注,使用Python进行应用程序开发的也越来越多。 今天给小伙伴们分享的这份项目教程完整代码已上传至GitHub,你可以选择跟着这份教程一段一段的手敲出来这几个项目,也可以直接从GitHub上copy下来。
|
5天前
|
开发工具 Python
【分享Python代码】图片转化为素描画
【分享Python代码】图片转化为素描画
19 2
|
5天前
|
数据库连接 Python
如何提高python程序代码的健壮性
在编程的时候,我们难免会遇到一些不可靠的情况,比如网络请求失败,数据库连接超时等等。这些不确定性会让我们的程序容易出现各种错误和异常。那么如何来增加程序的容错性和健壮性呢? 可能大多数人会想到使用try except来进行异常捕捉进行失败重试(Retry)。虽然try-escept一个非常常见和有效的方式来增强程序稳定性,但是可能一不小心就会造成栈溢出。 所以接下来我就来介绍一个另外的一个专门用于失败重试的库:retrying。
|
5天前
|
机器学习/深度学习 缓存 人工智能
令你膛目结舌的代码技巧 —— Python编程代码技巧
令你膛目结舌的代码技巧 —— Python编程代码技巧
17 2
|
5天前
|
存储 Python
10个小技巧,让你的 Python 代码更加优雅~
10个小技巧,让你的 Python 代码更加优雅~
10个小技巧,让你的 Python 代码更加优雅~
|
5天前
|
数据采集 XML 程序员
最新用Python做垃圾分类_python垃圾分类代码用key和format,5年经验Python程序员面试27天
最新用Python做垃圾分类_python垃圾分类代码用key和format,5年经验Python程序员面试27天
最新用Python做垃圾分类_python垃圾分类代码用key和format,5年经验Python程序员面试27天
|
5天前
|
数据采集 机器学习/深度学习 人工智能
最新用python代码画爱心,来自程序猿的浪漫~_python画爱心代码(1),2024年最新面试简历模板免费
最新用python代码画爱心,来自程序猿的浪漫~_python画爱心代码(1),2024年最新面试简历模板免费
最新用python代码画爱心,来自程序猿的浪漫~_python画爱心代码(1),2024年最新面试简历模板免费
|
5天前
|
测试技术 开发工具 iOS开发
Python如何快速定位最慢的代码?_pycharm找到执行时间长的代码(2)
Python如何快速定位最慢的代码?_pycharm找到执行时间长的代码(2)
Python如何快速定位最慢的代码?_pycharm找到执行时间长的代码(2)
|
5天前
|
数据采集 数据挖掘 测试技术
Python如何快速定位最慢的代码?_pycharm找到执行时间长的代码(1)
Python如何快速定位最慢的代码?_pycharm找到执行时间长的代码(1)
Python如何快速定位最慢的代码?_pycharm找到执行时间长的代码(1)