电子数据取证与python方法第三章

import os
import csv
import hashlib
import time
import logging

def getinfo1(dirfile):   
    m = hashlib.sha256()
    f=open(dirfile,'rb')
    m.update(f.read())
    ha=m.hexdigest()
    return ha       

def getinfo2(dirfile):
    ctime=os.path.getctime(dirfile)
    ctime=time.localtime(ctime)
    ctime=time.strftime('%Y-%m-%d %H:%M:%S',ctime)
   
    atime=os.path.getatime(dirfile)
    atime=time.localtime(atime)
    atime=time.strftime('%Y-%m-%d %H:%M:%S',atime)
   
    mtime=os.path.getmtime(dirfile)
    mtime=time.localtime(mtime)
    mtime=time.strftime('%Y-%m-%d %H:%M:%S',mtime)

    read_acc=os.access(dirfile,os.R_OK)
    write_acc=os.access(dirfile,os.W_OK)
    exe_acc=os.access(dirfile, os.X_OK)
   
    return ctime,atime,mtime,read_acc,write_acc,exe_acc
    
def allpath(path):
    dirs=os.listdir(path)
    for i in dirs:
        if os.path.isfile(path+'\\'+i) :
            name=i
            path2=path+'\\'+i
            size=os.path.getsize(path2)
            try:
                ctime,atime,mtime,read_acc,write_acc,exe_acc=getinfo2(path2)
            except:
                logger.error(path2+'时间记录及读写运行权限不对!')                   

            try:
                ha=getinfo1(path2)
            except:
                logger.error(path2+'文件哈希运算有误!')

            try:
                writer.writerow([name,path2,size,ctime,atime,mtime,read_acc,write_acc,exe_acc,ha])
            except:
                logger.error(path2+'信息写入失败!')
        else:
            allpath(path+'\\'+i)
    

fileopen=open('记录文件.csv','w',newline='')
writer=csv.writer(fileopen)
writer.writerow(['文件名称','文件路径','文件大小','创建时间','访问时间','修改时间','读取权限','写入权限','执行权限','哈希值'])

logger = logging.getLogger()
logger.setLevel(logging.INFO)  # Log等级总开关
fh = logging.FileHandler('文件错误日志.log', mode='w')
fh.setLevel(logging.DEBUG)  # 输出到file的log等级的开关
formatter = logging.Formatter("%(asctime)s - %(filename)s[line:%(lineno)d] - %(levelname)s: %(message)s")
fh.setFormatter(formatter)
logger.addHandler(fh)

first_path=os.getcwd()
print('初始目录为:',first_path)

try:
    allpath(first_path)
except:
    logger.error(first_path+'路径写入有误!')

fileopen.close()
print('结束!')

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值