本文主要是介绍数字取证技术(Digital Forensics Technology)实验课II,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
@数字取证技术(Digital Forensics Technology)实验课II
本文是我本学期的教学课题目,不包含任何博客知识分享,无关的读者可忽略;
实验练习题
(♞思考):请对工作邮件进行签名;“problem3_1.txt"里存储的是由John Doe撰写的真实的邮件,而"problem3_2.txt"里存储的是其他人恶意伪造的邮件(关键时间作了篡改);内容分别如下,请实现对邮件签名并验证的功能,并输出数字签名到文件"problem3_signature.txt”;
提示(Hint):程序将使用Python的hashlib和rsa库来完成数字签名的生成和验证过程.请确保已经通过’pip install rsa’命令安装了rsa库.你也可以自行实现,或者用其他程序实现同样的功能.
problem3_1.txt的内容:
Dear Team,Please find attached the report for the last quarter.
Ensure you review the document and provide feedback by EOD Friday.Best regards,
John Doe
problem3_2.txt的内容:
Dear Team,Please find attached the report for the last quarter.
Ensure you review the document and provide feedback by EOD Sunday.Best regards,
John Doe
(♞思考):(构造最佳关键词的摘要)在数字取证的过程中,可能需要对大量数据进行分层分类处理,如电子邮件、短信或其他通信记录.假设调查人员获得了一个嫌疑人的长期通信记录,需要归类其中特定的信息片段以帮助案件分析.调查人员具有一个由各种关键信息片段(keywords)组成的列表,每个信息片段都有相应的"重要性"评级值.考虑到有限的资源,调查人员需要优先处理那些"总重要性"评级值最高的信息组合.但是,由于信息的特殊性质,不同信息之间可能存在语义冲突,使得某些信息无法一起处理.因此,他们需要编写一个算法来找出一个最优的信息片段组合,使得该组合的总重要性评级值最大,且不包含任何冲突的信息片段.
提示(Hint):使用动态规划的思路,构造一个递归函数和最佳关键词的表格,遍历可能的组合(而不作重复计算),找到最优的组合;
程序如下,请实现函数find_optimal_keywords
(你也可以用其他编程语言实现):
def find_optimal_keywords(KEYWORDS, CONFLICT_WORDS):pass;# 题设数据
KEYWORDS = [("诈骗", 5), ("造假", 6), ("合规", 3), ("虚报", 4), ("属实", 2)]
CONFLICT_WORDS = [("诈骗", "合规"), ("造假", "属实")]
# 运行算法求解
optimal_set, max_value = find_optimal_keywords(KEYWORDS, CONFLICT_WORDS);
print("最重要的关键词:", optimal_set);
print("重要性权值 = ", max_value);
这篇关于数字取证技术(Digital Forensics Technology)实验课II的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!