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,如需转载请自行联系原作者
目录
相关文章
|
5天前
|
算法 Python
请解释Python中的关联规则挖掘以及如何使用Sklearn库实现它。
使用Python的mlxtend库,可以通过Apriori算法进行关联规则挖掘。首先导入TransactionEncoder和apriori等模块,然后准备数据集(如购买行为列表)。对数据集编码并转换后,应用Apriori算法找到频繁项集(设置最小支持度)。最后,生成关联规则并计算置信度(设定最小置信度阈值)。通过调整这些参数可以优化结果。
25 9
|
6天前
|
并行计算 C语言 开发者
优化Python代码的五大技巧
Python作为一种流行的编程语言,在各种应用场景中广泛使用。然而,随着项目规模的增长和需求的变化,Python代码的性能和可维护性也成为了关键问题。本文将介绍优化Python代码的五大技巧,帮助开发者提升代码效率和质量。
|
1天前
|
机器学习/深度学习 人工智能 算法
机械视觉:原理、应用及Python代码示例
机械视觉:原理、应用及Python代码示例
|
1天前
|
存储 缓存 算法
优化Python代码性能的7个技巧
在日常的Python开发中,优化代码性能是一个重要的课题。本文介绍了7个实用的技巧,帮助开发者提高Python代码的执行效率,包括利用生成器表达式、使用适量的缓存、避免不必要的循环等。通过本文的指导,读者可以更好地理解Python代码性能优化的方法,提升自身的编程水平。
|
3天前
|
人工智能 Python
【Python实用技能】建议收藏:自动化实现网页内容转PDF并保存的方法探索(含代码,亲测可用)
【Python实用技能】建议收藏:自动化实现网页内容转PDF并保存的方法探索(含代码,亲测可用)
21 0
|
3天前
|
人工智能 Python
【AI大模型应用开发】【LangChain系列】实战案例1:用LangChain写Python代码并执行来生成答案
【AI大模型应用开发】【LangChain系列】实战案例1:用LangChain写Python代码并执行来生成答案
7 0
|
3天前
|
Linux 网络安全 开发工具
【超详细!超多图!】【代码管理】Python微信公众号开发(3)- 服务器代码上传Github
【超详细!超多图!】【代码管理】Python微信公众号开发(3)- 服务器代码上传Github
10 0
|
3天前
|
数据安全/隐私保护 Python
Python中的装饰器:提升代码可读性和灵活性
Python中的装饰器是一种强大的编程工具,能够提升代码的可读性和灵活性。本文将深入探讨装饰器的原理和用法,以及如何利用装饰器来简化代码、实现日志记录、权限控制等功能,从而让你的Python代码更加优雅和高效。
|
7天前
|
机器学习/深度学习 数据采集 算法
请解释Python中的Sklearn库以及它的主要用途。
Sklearn是Python的机器学习库,提供数据预处理、特征选择、分类回归、聚类、模型评估和参数调优等工具。包含监督和无监督学习算法,如SVM、决策树、K-means等,并提供样例数据集便于实践。它是进行机器学习项目的重要资源。
14 1
|
7天前
|
XML 数据采集 自然语言处理
请解释Python中的BeautifulSoup库以及它的主要用途。
BeautifulSoup是Python的HTML/XML解析库,用于数据提取和网页抓取。它提供树形结构解析文档,支持查找、访问和修改元素。主要用途包括网页抓取、数据清洗、自动化测试、内容生成、网站开发及与其他库集成,如Requests和Scrapy。适用于各种数据处理场景。
9 1