php ras256,PHP 你用证书实现 XML 数字签名和验签( SHA256 with RSA)

/** * generateXMLSignFields XML生成签名域 * Use sha256withrsa algorithm to generate XML internal signature * @param $xml * @return string * @throws \Exception * @author liuml * @DateTime 2018/12/21 16:37 */ protected function generateXMLSignFields($xml) { // 加载要签名的XML $doc = new \DOMDocument(); $doc->loadXML($xml); // 创建一个新的安全对象 $objDSig = new XMLSecurityDSig(); // 使用c14n专属规范化 $objDSig->setCanonicalMethod(XMLSecurityDSig::C14N); // 签名使用 SHA-256 $objDSig->addReference( $doc, XMLSecurityDSig::SHA1, array('http://www.w3.org/2000/09/xmldsig#enveloped-signature') ); // 创建一个新的(私有)安全密钥 $objKey = new XMLSecurityKey(XMLSecurityKey::RSA_SHA256, array('type' => 'private')); // 如果密钥有密码,则使用它进行设置 // $objKey->passphrase = ''; // 加载私钥 $objKey->loadKey("-----BEGIN RSA PRIVATE KEY-----\n" . $this->privateKey . "\n-----END RSA PRIVATE KEY-----\n"); // 对XML文件签名 $objDSig->sign($objKey); // 将关联的公钥添加到签名 $objDSig->add509Cert("-----BEGIN PUBLIC KEY-----\n" . $this->publicKey . "\n-----END PUBLIC KEY-----\n"); // 将签名附加到XML $objDSig->appendSignature($doc->documentElement); return $doc->saveXML(); } /** * checkResponseSign 验证签名 * Validate signatures in XML * @param $xml * @return bool * @throws \Exception * @author liuml * @DateTime 2018/12/21 17:51 */ protected function checkResponseSign($xml) { $doc = new \DOMDocument(); $doc->loadXML($xml); $objXMLSecDSig = new XMLSecurityDSig(); $objDSig = $objXMLSecDSig->locateSignature($doc); if (!$objDSig) { throw new \Exception("Cannot locate Signature Node"); } $objXMLSecDSig->canonicalizeSignedInfo(); $objXMLSecDSig->idKeys = array('wsu:Id'); $objXMLSecDSig->idNS = array('wsu' => 'http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd'); $retVal = $objXMLSecDSig->validateReference(); if (!$retVal) { throw new \Exception("Reference Validation Failed"); } $objKey = $objXMLSecDSig->locateKey(); if (!$objKey) { throw new \Exception("We have no idea about the key"); } $key = NULL; $objKeyInfo = XMLSecEnc::staticLocateKeyInfo($objKey, $objDSig); if (!$objKeyInfo->key && empty($key)) { $objKey->loadKey("-----BEGIN PUBLIC KEY-----\n" . $this->myBankPublicKey . "\n-----END PUBLIC KEY-----\n"); } if ($objXMLSecDSig->verify($objKey) === 1) { return true; } else { return false; } }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值