欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2021年03月18日 11:27:55   作者:別再鬧了  
這篇文章主要介紹了MySQL的加密解密的幾種方式(小結(jié)),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

寫在前面

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

雙向加密

雙向加密有三種方法:

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ù)算法,聽著就知道加密等級(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ù)庫,否則就浪費(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è)一般是用來加密密碼的

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

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

Reference
https://www.w3resource.com/mysql/encryption-and-compression-functions/decode().php
https://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)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • centOS7安裝MySQL數(shù)據(jù)庫

    centOS7安裝MySQL數(shù)據(jù)庫

    本文給大家簡(jiǎn)單介紹了如何在centOS7下安裝MySQL5.6數(shù)據(jù)庫的方法,以及一些注意事項(xiàng),希望對(duì)大家實(shí)用mysql能夠有所幫助
    2016-12-12
  • Mysql數(shù)據(jù)庫命令大全

    Mysql數(shù)據(jù)庫命令大全

    mysql命令大家經(jīng)常會(huì)用到,但是很少有朋友整理吧,最近項(xiàng)目不多,抽個(gè)時(shí)間把mysql數(shù)據(jù)庫命令總結(jié)給大家,需要的朋友可以參考下
    2015-09-09
  • mysql分頁的limit參數(shù)簡(jiǎn)單示例

    mysql分頁的limit參數(shù)簡(jiǎn)單示例

    這篇文章主要給大家介紹了關(guān)于mysql分頁的limit參數(shù)的相關(guān)資料,文中通過示例代碼以及圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • window10下mysql 8.0.20 安裝配置方法圖文教程

    window10下mysql 8.0.20 安裝配置方法圖文教程

    這篇文章主要為大家詳細(xì)介紹了window10下mysql 8.0.20 安裝配置方法圖文教程,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • MYSQL刪除重復(fù)數(shù)據(jù)的簡(jiǎn)單方法

    MYSQL刪除重復(fù)數(shù)據(jù)的簡(jiǎn)單方法

    業(yè)務(wù)中遇到要從表里刪除重復(fù)數(shù)據(jù)的需求,使用了下面的方法,執(zhí)行成功,大家可以參考使用
    2013-11-11
  • 詳解Linux終端 MySQL常用操作指令

    詳解Linux終端 MySQL常用操作指令

    這篇文章主要介紹了Linux終端 MySQL常用操作指令的相關(guān)知識(shí),非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2018-02-02
  • sql索引的介紹以及使用規(guī)則詳析

    sql索引的介紹以及使用規(guī)則詳析

    索引是一種數(shù)據(jù)結(jié)構(gòu),可以加快我們查詢的效率,但是創(chuàng)建索引需要復(fù)制數(shù)據(jù),會(huì)占用資源,下面這篇文章主要給大家介紹了關(guān)于sql索引的介紹以及使用規(guī)則的相關(guān)資料,需要的朋友可以參考下
    2023-04-04
  • mysql 5.7.17 安裝配置方法圖文教程(CentOS7)

    mysql 5.7.17 安裝配置方法圖文教程(CentOS7)

    這篇文章主要為大家詳細(xì)介紹了CentOS7下mysql 5.7.17 安裝配置方法圖文教程,感興趣的小伙伴們可以參考一下
    2016-12-12
  • MySQL的InnoDB擴(kuò)容及ibdata1文件瘦身方案完全解析

    MySQL的InnoDB擴(kuò)容及ibdata1文件瘦身方案完全解析

    在使用InnoDB存儲(chǔ)引擎后,MySQL的ibdata1文件常常會(huì)占據(jù)大量存儲(chǔ)空間,這里我們就為大家?guī)鞰ySQL的InnoDB擴(kuò)容及ibdata1文件瘦身方案完全解析:
    2016-06-06
  • mysql壓縮包版安裝配置方法圖文教程

    mysql壓縮包版安裝配置方法圖文教程

    這篇文章主要為大家詳細(xì)介紹了mysql壓縮包版安裝配置方法圖文教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-10-10

最新評(píng)論