Setelah menginisialisasi SDK client instance KMS, Anda dapat menggunakannya untuk memanggil API Sign dan Verify dalam melakukan penandatanganan dan verifikasi. Topik ini menyediakan contoh kode terkait.
Penjelasan contoh
Inisialisasi client
<?php
use AlibabaCloud\Dkms\Gcs\Sdk\Client as AlibabaCloudDkmsGcsSdkClient;
use AlibabaCloud\Dkms\Gcs\OpenApi\Models\Config as AlibabaCloudDkmsGcsOpenApiConfig;
function getDkmsGcsSdkClient()
{
global $clientKeyContent, $password, $endpoint;
// Bangun konfigurasi SDK client instance KMS.
$config = new AlibabaCloudDkmsGcsOpenApiConfig();
// Protokol koneksi. Setel nilainya ke https. Layanan instance KMS hanya mengizinkan akses melalui protokol HTTPS.
$config->protocol = 'https';
// Client Key.
$config->clientKeyContent = $clientKeyContent;
// Token keamanan Client Key.
$config->password = $password;
// Endpoint instance KMS Anda. Setel nilainya dalam format berikut: <ID instance KMS Anda>.cryptoservice.kms.aliyuncs.com.
$config->endpoint = $endpoint;
// Sertifikat CA instance.
$config->caFilePath = 'path/to/caCert.pem';
// Bangun objek SDK client instance KMS.
return new AlibabaCloudDkmsGcsSdkClient($config);
}Panggil Sign API untuk melakukan penandatanganan digital menggunakan kunci asimetris
/**
* Contoh penandatanganan.
* @param AlibabaCloudDkmsGcsSdkClient $client
* @param string $keyId
* @param string $message
* @param string $messageType
* @param string $algorithm
* @return SignatureContext
*/
function signSample($client, $keyId, $message, $messageType, $algorithm) {
// Bangun permintaan penandatanganan.
$signRequest = new SignRequest();
$signRequest->keyId = $keyId;
$signRequest->algorithm = $algorithm;
$signRequest->message = AlibabaCloudTeaUtils::toBytes($message);
$signRequest->messageType = $messageType;
$runtimeOptions = new RuntimeOptions();
// Abaikan sertifikat.
//$runtimeOptions->ignoreSSL = true;
try {
// Panggil API penandatanganan untuk melakukan penandatanganan.
$signResponse = $client->signWithOptions($signRequest, $runtimeOptions);
// ID kunci.
$keyId = $signResponse->keyId;
// Nilai tanda tangan.
$signature = $signResponse->signature;
// Jenis pesan.
$messageType = $signResponse->messageType;
// Algoritma tanda tangan.
$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;
}Panggil Verify API untuk memverifikasi tanda tangan digital menggunakan kunci asimetris
/**
* Contoh verifikasi tanda tangan.
* @param AlibabaCloudDkmsGcsSdkClient $client
* @param string $message
* @param SignatureContext $ctx
* @return bool|null
*/
function verifySample($client, $message, $ctx) {
// Bangun permintaan verifikasi tanda tangan.
$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();
// Abaikan sertifikat server.
//$runtimeOptions->ignoreSSL = true;
try {
// Panggil API verifikasi tanda tangan untuk melakukan verifikasi.
$verifyResponse = $client->verifyWithOptions($verifyRequest, $runtimeOptions);
// Hasil verifikasi.
$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;
}