初始化KMS实例SDK客户端后,您可以通过客户端调用Sign和Verify接口进行签名验签。本文介绍签名验签的代码示例。
完整代码示例
调用Sign接口使用非对称密钥进行数字签名,调用Verify接口使用非对称密钥验证数字签名。
源码github地址:SignVerify.php
代码示例解析
初始化客户端
关于初始化客户端的详细介绍,请参见初始化客户端。
<?php
use AlibabaCloud\Dkms\Gcs\Sdk\Client as AlibabaCloudDkmsGcsSdkClient;
use AlibabaCloud\Dkms\Gcs\OpenApi\Models\Config as AlibabaCloudDkmsGcsOpenApiConfig;
function getDkmsGcsSdkClient()
{
global $clientKeyContent, $password, $endpoint;
// 构建KMS实例SDK Client配置
$config = new AlibabaCloudDkmsGcsOpenApiConfig();
//连接协议请设置为"https"。KMS实例服务仅允许通过HTTPS协议访问。
$config->protocol = 'https';
//Client Key。
$config->clientKeyContent = $clientKeyContent;
//Client Key口令。
$config->password = $password;
//设置endpoint为<your KMS Instance Id>.cryptoservice.kms.aliyuncs.com。
$config->endpoint = $endpoint;
// 实例CA证书
$config->caFilePath = 'path/to/caCert.pem';
// 构建KMS实例SDK Client对象
return new AlibabaCloudDkmsGcsSdkClient($config);
}
调用Sign接口使用非对称密钥进行数字签名
/**
* 签名示例
* @param AlibabaCloudDkmsGcsSdkClient $client
* @param string $keyId
* @param string $message
* @param string $messageType
* @param string $algorithm
* @return SignatureContext
*/
function signSample($client, $keyId, $message, $messageType, $algorithm) {
// 构建签名请求
$signRequest = new SignRequest();
$signRequest->keyId = $keyId;
$signRequest->algorithm = $algorithm;
$signRequest->message = AlibabaCloudTeaUtils::toBytes($message);
$signRequest->messageType = $messageType;
$runtimeOptions = new RuntimeOptions();
// 忽略证书
//$runtimeOptions->ignoreSSL = true;
try {
// 调用签名接口进行签名
$signResponse = $client->signWithOptions($signRequest, $runtimeOptions);
// 密钥ID
$keyId = $signResponse->keyId;
// 签名值
$signature = $signResponse->signature;
// 消息类型
$messageType = $signResponse->messageType;
// 签名算法
$algorithm = $signResponse->algorithm;
var_dump($signResponse->toMap());
return new SignatureContext([
'keyId' => $keyId,
'signature' => $signature,
'messageType' => $messageType,
'algorithm' => $algorithm
]);
} catch (Exception $error) {
if ($error instanceof \AlibabaCloud\Tea\Exception\TeaError) {
var_dump($error->getErrorInfo());
}
var_dump($error->getMessage());
var_dump($error->getTraceAsString());
}
return null;
}
调用Verify接口使用非对称密钥验证数字签名
/**
* 验签示例
* @param AlibabaCloudDkmsGcsSdkClient $client
* @param string $message
* @param SignatureContext $ctx
* @return bool|null
*/
function verifySample($client, $message, $ctx) {
// 构建验签请求
$verifyRequest = new VerifyRequest();
$verifyRequest->keyId = $ctx->keyId;
$verifyRequest->signature = $ctx->signature;
$verifyRequest->message = AlibabaCloudTeaUtils::toBytes($message);
$verifyRequest->messageType = $ctx->messageType;
$verifyRequest->algorithm = $ctx->algorithm;
$runtimeOptions = new RuntimeOptions();
// 忽略服务端证书
//$runtimeOptions->ignoreSSL = true;
try {
// 调用验签接口进行验签
$verifyResponse = $client->verifyWithOptions($verifyRequest, $runtimeOptions);
// 验签结果
$value = $verifyResponse->value;
var_dump($verifyResponse->toMap());
return $value;
} catch (Exception $error) {
if ($error instanceof \AlibabaCloud\Tea\Exception\TeaError) {
var_dump($error->getErrorInfo());
}
var_dump($error->getMessage());
var_dump($error->getTraceAsString());
}
return null;
}
该文章对您有帮助吗?