色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

MySQL的加密解密的幾種方式(小結(jié))

瀏覽:3日期:2023-10-05 07:18:11
寫(xiě)在前面

之前遇到一個(gè)問(wèn)題,就是MySQL的信息如何加密。其實(shí)加密的思路有兩種,一種是在數(shù)據(jù)庫(kù)外部加密后存入數(shù)據(jù)庫(kù),第二種是在數(shù)據(jù)庫(kù)內(nèi)部對(duì)數(shù)據(jù)進(jìn)行加密。這兩種的區(qū)別就是第二種比第一種在使用上要更加方便,因?yàn)樵谕獠考用艿脑捗恳淮蔚牟檎胰绻前凑毡患用艿捻?xiàng)來(lái)的話,都需要先算出加密后的數(shù)據(jù)再放入sql中,同時(shí)返回的也是加密的數(shù)據(jù),需要在外部進(jìn)行解密;而第二種的話可以直接在sql中傳原值和加密的key即可,解密也可以在sql中完成。這使得部分組合sql查詢使用第一種辦法就無(wú)法完成了,比如查詢的字段是另一場(chǎng)查詢的結(jié)果這種,因?yàn)楸仨毥?jīng)過(guò)一個(gè)外部加密的過(guò)程

雙向加密

雙向加密有三種方法:

ENCODE/DECODE

傳入兩個(gè)值,一個(gè)是要加密的記錄,一個(gè)是加密和解密的key.加密之后的二進(jìn)制字符長(zhǎng)度和原始長(zhǎng)度是一樣的,以blob類型存儲(chǔ)

BLOB 類型的字段用于存儲(chǔ)二進(jìn)制數(shù)據(jù) MySQL 中,BLOB 是個(gè)類型系列,包括:TinyBlob、Blob、MediumBlob、LongBlob,這幾個(gè)類型之間的唯一區(qū)別是在存儲(chǔ)文件的最大大小上不同。 MySQL 的四種 BLOB 類型 類型 大小 (單位:字節(jié)) TinyBlob 最大 255 Blob 最大 65K Medium。

加密:

SELECT ENCODE(’mytext’,’mykeystring’);

結(jié)果:

mysql> SELECT ENCODE(’mytext’,’mykeystring’);+--------------------------------+| ENCODE(’mytext’,’mykeystring’) |+--------------------------------+| '>¿¡È | +--------------------------------+1 row in set (0.00 sec)

解密:

SELECT DECODE(ENCODE(’mytext’,’mykeystring’),’mykeystring’);

結(jié)果:

mysql> SELECT DECODE(ENCODE(’mytext’,’mykeystring’),’mykeystring’);+------------------------------------------------------+| DECODE(ENCODE(’mytext’,’mykeystring’),’mykeystring’) |+------------------------------------------------------+| mytext | +------------------------------------------------------+1 row in set (0.00 sec)AES_ENCRYPT/AES_DECRYPT

這種加密算法使用AES(高級(jí)加密標(biāo)準(zhǔn),Advanced Encryption Standard),使用key_str加密,key_str的長(zhǎng)度可以達(dá)到256位,加密的結(jié)果是一個(gè)二進(jìn)制的字符串,以blob類型存儲(chǔ)

加密:

SELECT AES_ENCRYPT(’mytext’, ’mykeystring’);

結(jié)果:

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’);DES_ENCRYPT/DES_DECRYPT

這種加密方法使用了3DES(三重加密數(shù)據(jù)算法,聽(tīng)著就知道加密等級(jí)比較gap),加密時(shí)可以選擇使用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)

解密時(shí)使用DES_DECRYPT

但是w3resource中有一句:This function works only with Secure Sockets Layer (SSL) if support for SSL is available in MySql configuration.我個(gè)人的理解是如果使用這種加密方法,就必須使用SSL安全連接的方式連接數(shù)據(jù)庫(kù),否則就浪費(fèi)了較高的加密等級(jí)了

單向加密

其實(shí)關(guān)于單向加密是不是加密的爭(zhēng)論網(wǎng)上一直有,比如MD5 到底是不是加密?,我這里就把它當(dāng)成加密算法了,不抬杠

MD5加密

MD5加密的結(jié)果是32位十六進(jìn)制數(shù)的二進(jìn)制字符串

SELECT MD5(’w3resource’);

結(jié)果為:

mysql> SELECT MD5(’w3resource’); +----------------------------------+| MD5(’w3resource’) |+----------------------------------+| b273cb2263eb88f61f7133cd308b4064 | +----------------------------------+1 row in set (0.04 sec)ENCRYPT加密

ENCRYPT使用Unix的crypt()系統(tǒng)調(diào)用實(shí)現(xiàn),,返回一個(gè)二進(jìn)制字符串。因?yàn)樗腔赨nix系統(tǒng)調(diào)用的,所以在Windows中會(huì)返回NULL

加密:

SELECT ENCRYPT(’w3resource’, ’encode’);mysql> SELECT ENCRYPT(’w3resource’, ’encode’);+---------------------------------+| ENCRYPT(’w3resource’, ’encode’) |+---------------------------------+| NULL | +---------------------------------+1 row in set (0.00 sec)SHA1加密

SHA1返回的是40位的十六進(jìn)制數(shù)字的二進(jìn)制字符串,輸入是NULL的時(shí)候輸出也是NULL

SELECT SHA1(’w3resource’);

mysql> SELECT SHA1(’w3resource’);+------------------------------------------+| SHA1(’w3resource’) |+------------------------------------------+| d228359c41174cede6b3c401eb8d11746a4ad1eb | +------------------------------------------+1 row in set (0.00 sec)PASSWORD

這個(gè)一般是用來(lái)加密密碼的

輸入為NULL時(shí)輸出也是NULL

mysql> SELECT PASSWORD(’w3resource’);+-------------------------------------------+| PASSWORD(’w3resource’) |+-------------------------------------------+| *EE0804DDC2CC3E85A47191ECCCBA29B775DFFA77 | +-------------------------------------------+1 row in set (0.00 sec)

Referencehttps://www.w3resource.com/mysql/encryption-and-compression-functions/decode().phphttps://blog.csdn.net/Gpwner/article/details/51598344?depth_1-utm_source=distribute.pc_relevant.none-task&utm_source=distribute.pc_relevant.none-task

到此這篇關(guān)于MySQL的加密解密的幾種方式(小結(jié))的文章就介紹到這了,更多相關(guān)MySQL 加密解密內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: MySQL 數(shù)據(jù)庫(kù)
相關(guān)文章:
主站蜘蛛池模板: 亚洲第一区视频在线观看 | 长腿嫩模打开双腿呻吟 | 一级一级毛片免费播放 | 亚洲精品久久久久久久777 | 亚洲视频免费观看 | 波多野结衣一级片 | 97干干干 | 国产呦在线观看视频 | 美女舒服好紧太爽了视频 | 亚洲一区在线免费观看 | 国产男女免费视频 | 华人色| 亚洲视频网站在线观看 | 日本亚洲欧美高清专区vr专区 | 日韩黄色片在线观看 | 大伊香蕉精品视频在线观看 | 福利视频美女国产精品 | 色精品视频 | 久久亚洲精品国产精品777777 | 台湾香港澳门三级在线 | 国产精品亚洲欧美一级久久精品 | 久久福利资源国产精品999 | 亚洲精品国产高清不卡在线 | 91av小视频| 久久久久久国产视频 | 一级特黄aa大片欧美 | 久久久久久久久久久久久久久久久久 | 国产高清厕所盗摄视频 | 日本在线理论片 | 日本不卡一区视频 | 亚洲精品乱无伦码 | 欧美成人三级网站在线观看 | 国产亚洲精品yxsp | 日韩在线视频中文字幕 | 中文字幕欧美日韩一 | 国产 magnet | 怡红院成人永久免费看 | 国产精品视频男人的天堂 | 黄色在线网站 | 欧美一区二区三区国产精品 | 99视频网站 |