尝试使用有效的C#代码使用Python生成RSA签名 - c#

我正在使用其他人的代码来生成用于在xbox 360保存文件中进行验证的RSA签名。该代码从文件中读取所需的值,并正确生成签名。

代码是:

    byte[] xHash=null;
    RSAParameters xParams = new RSAParameters();
    br.BaseStream.Position = 0x1A8;
    xParams.D = br.ReadBytes(0x80);
    xParams.Exponent = br.ReadBytes(0x4);
    xParams.Modulus = br.ReadBytes(0x80);
    xParams.P = br.ReadBytes(0x40);
    xParams.Q = br.ReadBytes(0x40);
    xParams.DP = br.ReadBytes(0x40);
    xParams.DQ = br.ReadBytes(0x40);
    xParams.InverseQ = br.ReadBytes(0x40);
    br.close();

    br=new BinaryReader(File.OpenRead(f));
    br.BaseStream.Position=0x22c;
    xHash = new SHA1CryptoServiceProvider().ComputeHash(br.ReadBytes(0x118));
    byte[] xrsa=SignatureGenerate(xParams, xHash);

public static byte[] SignatureGenerate(RSAParameters xParam, byte[] xHash)
        {
            RSACryptoServiceProvider xRSACrypto = new RSACryptoServiceProvider();
            RSAPKCS1SignatureFormatter xRSASigFormat = new RSAPKCS1SignatureFormatter();
            xRSACrypto.ImportParameters(xParam);
            xRSASigFormat.SetHashAlgorithm("SHA1");
            xRSASigFormat.SetKey(xRSACrypto);
            return xRSASigFormat.CreateSignature(xHash);

        }

我试图以xrsa中的内容结束,但是使用Python。我安装了pycrypto,正在查看文档,但仍然缺少明显的内容。首先,来自Crypto.PublicKey的RSA.construct仅采用六个参数,但不采用指数1和2(DP和DQ)。另外,输入需要多头。在C#代码中,值的长度为128和64字节,而不是4字节。

我知道这看起来很痛苦,但是我不知道该怎么做。

我正在使用Python 2.7.3

编辑:同样,要加密的“消息”是文件的0x118字节的sha1哈希,其中包含元数据和文件其他部分的哈希。

编辑:非常感谢您mata,我觉得我已经接近使其工作了。它仍然与C#签名不匹配。在C#中,签名格式被设置为SHA1。这是做什么的,可以用Python完成吗?

参考方案

好的,首先:python中的long不是4字节。在python中,long没有预定义的大小,因此使用long存储128byte数字是没有问题的。
将字节串转换为long可以使用:

long_value = long(string_value.decode('hex'), 16)
# maybe someone knows a better way?

难道文件不是DER格式吗?在这种情况下,您只需使用以下命令即可简单地读取文件:

from Crypto.PublicKey import RSA
with open("keyfile", "rb") as f:
    key = RSA.importKey(f.read())

如果不是,最好将其转换为PEM或DER,因此您不必自己读取参数。
无论如何,RSA.construct中的最后三个参数是可选的,特别是u可以计算为1/p % q (where p > q)
至少从我的尝试来看,即使您仅指定前三个参数,它也可以工作。

Python GPU资源利用 - python

我有一个Python脚本在某些深度学习模型上运行推理。有什么办法可以找出GPU资源的利用率水平?例如,使用着色器,float16乘法器等。我似乎在网上找不到太多有关这些GPU资源的文档。谢谢! 参考方案 您可以尝试在像Renderdoc这样的GPU分析器中运行pyxthon应用程序。它将分析您的跑步情况。您将能够获得有关已使用资源,已用缓冲区,不同渲染状态上…

Python sqlite3数据库已锁定 - python

我在Windows上使用Python 3和sqlite3。我正在开发一个使用数据库存储联系人的小型应用程序。我注意到,如果应用程序被强制关闭(通过错误或通过任务管理器结束),则会收到sqlite3错误(sqlite3.OperationalError:数据库已锁定)。我想这是因为在应用程序关闭之前,我没有正确关闭数据库连接。我已经试过了: connectio…

python-docx应该在空单元格已满时返回空单元格 - python

我试图遍历文档中的所有表并从中提取文本。作为中间步骤,我只是尝试将文本打印到控制台。我在类似的帖子中已经看过scanny提供的其他代码,但是由于某种原因,它并没有提供我正在解析的文档的预期输出可以在https://www.ontario.ca/laws/regulation/140300中找到该文档from docx import Document from…

Python ThreadPoolExecutor抑制异常 - python

from concurrent.futures import ThreadPoolExecutor, wait, ALL_COMPLETED def div_zero(x): print('In div_zero') return x / 0 with ThreadPoolExecutor(max_workers=4) as execut…

Python:集群作业管理 - python

我在具有两个阶段的计算群集(Slurm)上运行python脚本,它们是顺序的。我编写了两个python脚本,一个用于阶段1,另一个用于阶段2。每天早上,我检查所有第1阶段的工作是否都以视觉方式完成。只有这样,我才开始第二阶段。通过在单个python脚本中组合所有阶段和作业管理,是否有一种更优雅/自动化的方法?我如何知道工作是否完成?工作流程类似于以下内容:w…