kouinkouin/xmlseclibs

用于XML安全性的PHP库

3.0.2 2018-09-27 13:24 UTC

README

#xmlseclibs

xmlseclibs 是一个用 PHP 编写的库,用于处理 XML 加密和签名。

xmlseclibs 的作者是 Rob Richards。

分支

master 和 2.0 分支都得到积极维护。

  • master:移除 mcrypt 使用,需要 5.4+(出于安全原因建议使用 5.6.24+)
  • 2.0:包含命名空间支持,需要 5.3+
  • 1.4:包含自动加载支持,同时保持与使用 xmlseclibs.php 文件的老版本 1.3 的向后兼容性。支持 PHP 5.2+

要求

xmlseclibs 需要 PHP 版本 5.4 或更高版本。出于安全原因建议使用 5.6.24+

如何安装

使用 composer.phar 安装。

php composer.phar require "robrichards/xmlseclibs"

使用案例

xmlseclibs 在许多不同的软件中被使用。

基本用法

以下示例展示了 xmlseclibs 的基本用法,包含 SHA-256 签名。

use RobRichards\XMLSecLibs\XMLSecurityDSig;
use RobRichards\XMLSecLibs\XMLSecurityKey;

// Load the XML to be signed
$doc = new DOMDocument();
$doc->load('./path/to/file/tobesigned.xml');

// Create a new Security object 
$objDSig = new XMLSecurityDSig();
// Use the c14n exclusive canonicalization
$objDSig->setCanonicalMethod(XMLSecurityDSig::EXC_C14N);
// Sign using SHA-256
$objDSig->addReference(
    $doc, 
    XMLSecurityDSig::SHA256, 
    array('http://www.w3.org/2000/09/xmldsig#enveloped-signature')
);

// Create a new (private) Security key
$objKey = new XMLSecurityKey(XMLSecurityKey::RSA_SHA256, array('type'=>'private'));
/*
If key has a passphrase, set it using
$objKey->passphrase = '<passphrase>';
*/
// Load the private key
$objKey->loadKey('./path/to/privatekey.pem', TRUE);

// Sign the XML file
$objDSig->sign($objKey);

// Add the associated public key to the signature
$objDSig->add509Cert(file_get_contents('./path/to/file/mycert.pem'));

// Append the signature to the XML
$objDSig->appendSignature($doc->documentElement);
// Save the signed XML
$doc->save('./path/to/signed.xml');

如何贡献

邮件列表:https://groups.google.com/forum/#!forum/xmlseclibs