您好,登錄后才能下訂單哦!
這篇文章給大家介紹MySQL中實現加密解密的方法有哪些,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
雙向加密有三種方法:
傳入兩個值,一個是要加密的記錄,一個是加密和解密的key.加密之后的二進制字符長度和原始長度是一樣的,以blob類型存儲
BLOB 類型的字段用于存儲二進制數據 MySQL 中,BLOB 是個類型系列,包括:TinyBlob、Blob、MediumBlob、LongBlob,這幾個類型之間的唯一區別是在存儲文件的最大大小上不同。 MySQL 的四種 BLOB 類型 類型 大小 (單位:字節) TinyBlob 最大 255 Blob 最大 65K Medium。
加密:
SELECT ENCODE('mytext','mykeystring');
結果:
mysql> SELECT ENCODE('mytext','mykeystring'); +--------------------------------+ | ENCODE('mytext','mykeystring') | +--------------------------------+ | ">¿¡È | +--------------------------------+ 1 row in set (0.00 sec)
解密:
SELECT DECODE(ENCODE('mytext','mykeystring'),'mykeystring');
結果:
mysql> SELECT DECODE(ENCODE('mytext','mykeystring'),'mykeystring'); +------------------------------------------------------+ | DECODE(ENCODE('mytext','mykeystring'),'mykeystring') | +------------------------------------------------------+ | mytext | +------------------------------------------------------+ 1 row in set (0.00 sec)
這種加密算法使用AES(高級加密標準,Advanced Encryption Standard),使用key_str加密,key_str的長度可以達到256位,加密的結果是一個二進制的字符串,以blob類型存儲
加密:
SELECT AES_ENCRYPT('mytext', 'mykeystring');
結果:
mysql> SELECT AES_ENCRYPT('mytext', 'mykeystring'); +--------------------------------------+ | AES_ENCRYPT('mytext', 'mykeystring') | +--------------------------------------+ | ­??¨í ?ðbáÒ9?j | +--------------------------------------+ 1 row in set (0.00 sec)
解密:
SELECT AES_DECRYPT(AES_ENCRYPT('mytext','mykeystring'), 'mykeystring');
這種加密方法使用了3DES(三重加密數據算法,聽著就知道加密等級比較gap),加密時可以選擇使用key_num還是key_str
例如:
SELECT DES_ENCRYPT('mytext',5),DES_ENCRYPT('mytext','mypassward');
輸出為:
mysql> SELECT DES_ENCRYPT('mytext',5),DES_ENCRYPT('mytext','mypassward'); +-------------------------+------------------------------------+ | DES_ENCRYPT('mytext',5) | DES_ENCRYPT('mytext','mypassward') | +-------------------------+------------------------------------+ | …?ÿc}æ¤~ | ÿ]ï×ñ”Å | +-------------------------+------------------------------------+ 1 row in set (0.00 sec)
解密時使用DES_DECRYPT
但是w3resource中有一句:This function works only with Secure Sockets Layer (SSL) if support for SSL is available in MySql configuration.我個人的理解是如果使用這種加密方法,就必須使用SSL安全連接的方式連接數據庫,否則就浪費了較高的加密等級了
其實關于單向加密是不是加密的爭論網上一直有,比如MD5 到底是不是加密?,我這里就把它當成加密算法了,不抬杠
MD5加密的結果是32位十六進制數的二進制字符串
SELECT MD5('w3resource');
結果為:
mysql> SELECT MD5('w3resource'); +----------------------------------+ | MD5('w3resource') | +----------------------------------+ | b273cb2263eb88f61f7133cd308b4064 | +----------------------------------+ 1 row in set (0.04 sec)
ENCRYPT使用Unix的crypt()系統調用實現,,返回一個二進制字符串。因為它是基于Unix系統調用的,所以在Windows中會返回NULL
加密:
SELECT ENCRYPT('w3resource', 'encode'); mysql> SELECT ENCRYPT('w3resource', 'encode'); +---------------------------------+ | ENCRYPT('w3resource', 'encode') | +---------------------------------+ | NULL | +---------------------------------+ 1 row in set (0.00 sec)
SHA1返回的是40位的十六進制數字的二進制字符串,輸入是NULL的時候輸出也是NULL
SELECT SHA1('w3resource');
mysql> SELECT SHA1('w3resource'); +------------------------------------------+ | SHA1('w3resource') | +------------------------------------------+ | d228359c41174cede6b3c401eb8d11746a4ad1eb | +------------------------------------------+ 1 row in set (0.00 sec)
這個一般是用來加密密碼的
輸入為NULL時輸出也是NULL
mysql> SELECT PASSWORD('w3resource'); +-------------------------------------------+ | PASSWORD('w3resource') | +-------------------------------------------+ | *EE0804DDC2CC3E85A47191ECCCBA29B775DFFA77 | +-------------------------------------------+ 1 row in set (0.00 sec)
關于MySQL中實現加密解密的方法有哪些就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。