メインコンテンツまでスキップ
バージョン: 4.x

SM4_DECRYPT

説明

SM4は国家標準対称鍵暗号化アルゴリズムであり、金融、通信、電子商取引などの分野で広く使用されています。SM4_DECRYPT関数はSM4を使用してデータを復号化するために使用されます。デフォルトのアルゴリズムはSM4_128_ECBです。

警告

3.0.2まで、2つの引数を持つ関数はセッション変数block_encryption_modeを無視し、常にSM4_128_ECBを使用して復号化を行います。そのため、使用は推奨されません。

3.0.3以降、期待通りに動作します。

構文

SM4_DECRYPT( <str>, <key_str>[, <init_vector>][, <encryption_mode>])

パラメータ

parameterdescription
<str>復号化されるテキスト
<key_str>キーです。このキーは16進数エンコーディングではなく、エンコードされた文字列表現であることに注意してください。例えば、128ビットキー暗号化の場合、key_strの長さは16である必要があります。キーの長さが不足している場合は、ゼロパディングを使用して完全にします。長さが超過している場合は、循環XORを使用して最終キーを求めます。例えば、アルゴリズムで使用される128ビットキーがkeyの場合、key[i] = key_str[i] ^ key_str[i+128] ^ key_str[i+256] ^ ...となります
<init_vector>アルゴリズムで使用される初期ベクトルです。特定のアルゴリズムでのみ有効です。指定されていない場合、Dorisは組み込みベクトルを使用します
<encryption_mode>暗号化アルゴリズムについて、オプション値は変数で与えられます

Return Value

復号化が成功した場合:復号化されたデータを返します。通常は平文のバイナリ表現です。

復号化が失敗した場合:NULLを返します。

Examples

復号化成功

デフォルトアルゴリズムを使用

set block_encryption_mode='';
select SM4_DECRYPT(FROM_BASE64('aDjwRflBrDjhBZIOFNw3Tg=='),'F3229A0B371ED2D9441B830D21A390C3');
+--------------------------------------------------------------------------------+
| sm4_decrypt(from_base64('aDjwRflBrDjhBZIOFNw3Tg=='), '***', '', 'SM4_128_ECB') |
+--------------------------------------------------------------------------------+
| text |
+--------------------------------------------------------------------------------+

SM4_128_CBC アルゴリズムの使用

set block_encryption_mode="SM4_128_CBC";
select SM4_DECRYPT(FROM_BASE64('FSYstvOmH2cXy7B/072Mug=='),'F3229A0B371ED2D9441B830D21A390C3');
+--------------------------------------------------------------------------------+
| sm4_decrypt(from_base64('FSYstvOmH2cXy7B/072Mug=='), '***', '', 'SM4_128_CBC') |
+--------------------------------------------------------------------------------+
| text |
+--------------------------------------------------------------------------------+

SM4_128_CBC アルゴリズムと初期ベクトルを使用します

select SM4_DECRYPT(FROM_BASE64('1Y4NGIukSbv9OrkZnRD1bQ=='),'F3229A0B371ED2D9441B830D21A390C3', '0123456789');
+------------------------------------------------------------------------------------------+
| sm4_decrypt(from_base64('1Y4NGIukSbv9OrkZnRD1bQ=='), '***', '0123456789', 'SM4_128_CBC') |
+------------------------------------------------------------------------------------------+
| text |
+------------------------------------------------------------------------------------------+

復号化に失敗しました

set block_encryption_mode='';
select SM4_DECRYPT(FROM_BASE64('aDjwRflBrDjhBZIdOFNw3Tg=='),'F3229A0B371ED2D9441B830D21A390C3');
+---------------------------------------------------------------------------------+
| sm4_decrypt(from_base64('aDjwRflBrDjhBZIdOFNw3Tg=='), '***', '', 'SM4_128_ECB') |
+---------------------------------------------------------------------------------+
| NULL |
+---------------------------------------------------------------------------------+