#CRYPT_SIGN
CRYPT_SIGN函数以expr2为签名者需要提供的私钥、以expr3为签名私钥的算法类型、以expr4为签名者的签名ID对expr1的数据进行签名,返回一个HEX格式的VARCHAR类型的签名串。
本函数遵循如下规则:
expr1待签名的数据只支持VARCHAR/CHAR类型。
expr2是HEX格式的签名私钥,可以通过CRYPT_KEY函数创建相应的公私钥对,若不提供或非法,则函数报错。
expr3是签名的算法类型,目前仅支持SM2类型的签名和验签。
expr4支持字符形式的签名ID。
expr5为可选的签名公钥参数,在OpenSSL或GMSSL加密引擎下,可不提供;在密码卡加密引擎下,必须提供。
当expr1为null时返回null。
函数返回的签名串,遵循ASN.1 DER编码规则。
Caution:
CRYPT_SIGN函数中的密钥由用户管理,请勿将包含CRYPT_SIGN函数的SQL写入OUTLINE或者SQLMAP视图中,以避免潜在的密钥泄露风险。
在OpenSSL或GMSSL加密引擎下,若提供了公钥参数,则需要保证公钥的合法性,并且与签名的私钥匹配。
示例
SELECT CRYPT_KEY('sm2') FROM dual;
CRYPT_KEY('SM2')
----------------------------------------------------------------
PUBLIC:7CB4E274EC64D0AC2BBEC9641731E3A88BF1959572BCDB19C7A3574FC0A6C0DEF3F12B4273F1085EFA96E22415869358EA04DC49590E3464DF6DC85898E38271;PRIVATE:7048688F3345C89E90F5B1E99DED97B5901A01F1C650A99CA752088E1CE22CAA
SELECT CRYPT_SIGN('how are you? I am fine, thank you', '7048688F3345C89E90F5B1E99DED97B5901A01F1C650A99CA752088E1CE22CAA', 'sm2', 'lilei') signature FROM dual;
SIGNATURE
----------------------------------------------------------------
3046022100B8D8BF5A2E44575BE2B02AC0BE904867D61A605981E5AE324FF79A47C68C55DA022100B6F690EC9DBC64C68AEBF46D0A4383D99D12B516BF297E7A248AD2B9624709D7