BytedifferencebetweenpythoncryptographyandJSForgewhenmakingpkcs#7signing
创始人
2025-01-12 22:00:32
0

问题的解决方案是,在使用Python cryptography库和JS Forge库进行pkcs #7签名时,需要注意两个库在编码方式上的差异。具体来说,Python cryptography库默认使用DER编码格式,而JS Forge库默认使用PEM编码格式。因此,在数据传输和处理过程中,需要将数据在两种编码格式之间进行相互转换。

以下是Python cryptography库中进行pkcs #7签名的示例代码:

from cryptography.hazmat.primitives import serialization, hashes
from cryptography.hazmat.primitives.asymmetric import padding, utils

def pkcs7_sign(private_key, cert, data):
    builder = cert.signature_builder(padding.PKCS1v15(), hashes.SHA256())
    signature = private_key.sign(data, padding.PKCS1v15(), hashes.SHA256())
    signed = builder.build(signature)
    return signed

# Usage:
# private_key and cert should be loaded from file
data = b'test data'
signed_data = pkcs7_sign(private_key, cert, data)

以下是JS Forge库中进行pkcs #7签名的示例代码:

const forge = require('node-forge');

function pkcs7_sign(privateKeyPem, certPem, data) {
  const privateKey = forge.pki.privateKeyFromPem(privateKeyPem);
  const cert = forge.pki.certificateFromPem(certPem);

  const p7 = forge.pkcs7.createSignedData();
  p7.content = forge.util.createBuffer(data);
  p7.addCertificate(cert);
  p7.addSigner({
    key: privateKey,
    certificate: cert,
    digestAlgorithm: forge.pki.oids.sha256,
    authenticatedAttributes: [{
      type: forge.pki.oids.contentType,
      value: forge.pki.oids.data,
    }, {
      type: forge.pki.oids.messageDigest,
      value: forge.util.encode64(forge.md.sha256.create().update(data).digest().getBytes()),
    }, {
      type: forge.pki.oids.signingTime,
      value: new Date(),
    }],
  });
  p7.sign();

  return forge.asn1.toDer(p7.toAsn1()).getBytes();
}

// Usage:
// privateKeyPem and certPem should be loaded from file
const data = 'test data';
const signedData = pkcs7_sign(privateKeyPem, certPem, data);

在两种编码格式之间进行转换,可以使用以下代码:

from cryptography.hazmat.primitives import serialization

def der_to_pem(der_data):
    pem_data = serialization.load_der_public_key(der_data).public_bytes(
        encoding=serialization.Encoding.PEM,
        format=serialization.PublicFormat.SubjectPublicKeyInfo,
    )
    return pem_data

def pem_to_der(pem_data):
    der_data = serialization.load_pem_public_key(pem_data).public_bytes(
        encoding=serialization.Encoding.DER,
        format=serialization.PublicFormat.SubjectPublicKeyInfo,
    )
    return der_data
const forge = require('node-forge');

function derToPem(derData) {
  const pemData = forge.pki.publicKeyToPem(forge.pki.publicKeyFromAsn1(forge.asn1.fromDer(derData)));
  return pemData;
}

function pemToDer(pemData) {
  const derData = forge.asn1.toDer(forge.pki.publicKeyToAsn1(forge.pki.publicKeyFromPem(pemData))).getBytes();
  return derData;
}

相关内容

热门资讯

5分钟揭幕!拱趴大菠萝技巧,汇... 5分钟揭幕!拱趴大菠萝技巧,汇友游戏辅助软件(原来是真的挂)-哔哩哔哩1、操作简单,无需注册,只需要...
第一分钟外挂!人皇辅助软件下载... 第一分钟外挂!人皇辅助软件下载,悟空大厅辅助助手下载安装,可靠教程(有挂讲解)-哔哩哔哩1、悟空大厅...
第7分钟普及!多乐找刺激技巧辅... 第7分钟普及!多乐找刺激技巧辅助,传送屋有没有挂(切实是真的挂)-哔哩哔哩亲,关键说明,多乐找刺激技...
第3分钟外挂!中至吉安祈福有用... 第3分钟外挂!中至吉安祈福有用吗,丽水都莱脚本辅助视频,实用技巧(果真有挂)-哔哩哔哩;1、操作简单...
第9分钟解密!福建开心辅助,微... 第9分钟解密!福建开心辅助,微乐陕西三代自建房挂(好像有挂)-哔哩哔哩1、下载好微乐陕西三代自建房挂...
第三分钟外挂!爱来大菠萝的辅助... 第三分钟外挂!爱来大菠萝的辅助七,玖天乐游辅助,透牌教程(有挂教程)-哔哩哔哩1、爱来大菠萝的辅助七...
第1分钟专业!中至鹰潭辅助器,... 第1分钟专业!中至鹰潭辅助器,新天道破解版(都是真的是有挂)-哔哩哔哩1、中至鹰潭辅助器系统规律教程...
第6分钟外挂!福建兄弟水挂,新... 第6分钟外挂!福建兄弟水挂,新道游修改器,AI教程(新版有挂)-哔哩哔哩;一、新道游修改器AI软件牌...
第7分钟揭幕!广东雀神智能插件... 第7分钟揭幕!广东雀神智能插件安装辅助器,兴动互娱辅助工具(一直真的有挂)-哔哩哔哩1、让任何用户在...
一分钟外挂!微信小程序牵手跑得... 一分钟外挂!微信小程序牵手跑得快辅助,四川熊猫辅助软件视频,必赢方法(讲解有挂)-哔哩哔哩运微信小程...