电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

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

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

之前遇到一個問題,就是MySQL的信息如何加密。其實加密的思路有兩種,一種是在數(shù)據(jù)庫外部加密后存入數(shù)據(jù)庫,第二種是在數(shù)據(jù)庫內(nèi)部對數(shù)據(jù)進行加密。這兩種的區(qū)別就是第二種比第一種在使用上要更加方便,因為在外部加密的話每一次的查找如果是按照被加密的項來的話,都需要先算出加密后的數(shù)據(jù)再放入sql中,同時返回的也是加密的數(shù)據(jù),需要在外部進行解密;而第二種的話可以直接在sql中傳原值和加密的key即可,解密也可以在sql中完成。這使得部分組合sql查詢使用第一種辦法就無法完成了,比如查詢的字段是另一場查詢的結果這種,因為必須經(jīng)過一個外部加密的過程

雙向加密

雙向加密有三種方法:

ENCODE/DECODE

傳入兩個值,一個是要加密的記錄,一個是加密和解密的key.加密之后的二進制字符長度和原始長度是一樣的,以blob類型存儲

BLOB 類型的字段用于存儲二進制數(shù)據(jù) MySQL 中,BLOB 是個類型系列,包括:TinyBlob、Blob、MediumBlob、LongBlob,這幾個類型之間的唯一區(qū)別是在存儲文件的最大大小上不同。 MySQL 的四種 BLOB 類型 類型 大小 (單位:字節(jié)) 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_ENCRYPT/AES_DECRYPT

這種加密算法使用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’);DES_ENCRYPT/DES_DECRYPT

這種加密方法使用了3DES(三重加密數(shù)據(jù)算法,聽著就知道加密等級比較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安全連接的方式連接數(shù)據(jù)庫,否則就浪費了較高的加密等級了

單向加密

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

MD5加密

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

SELECT MD5(’w3resource’);

結果為:

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

ENCRYPT使用Unix的crypt()系統(tǒng)調用實現(xiàn),,返回一個二進制字符串。因為它是基于Unix系統(tǒng)調用的,所以在Windows中會返回NULL

加密:

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

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

SELECT SHA1(’w3resource’);

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

這個一般是用來加密密碼的

輸入為NULL時輸出也是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

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

相關文章:
主站蜘蛛池模板: 旋振筛_不锈钢旋振筛_气旋筛_旋振筛厂家—新乡市大汉振动机械有限公司 | 除湿机|工业除湿机|抽湿器|大型地下室车间仓库吊顶防爆除湿机|抽湿烘干房|新风除湿机|调温/降温除湿机|恒温恒湿机|加湿机-杭州川田电器有限公司 | 非小号行情 - 专业的区块链、数字藏品行情APP、金色财经官网 | 智能型高压核相仪-自动开口闪点测试仪-QJ41A电雷管测试仪|上海妙定 | 灌木树苗-绿化苗木-常绿乔木-价格/批发/基地 - 四川成都途美园林 | 合肥防火门窗/隔断_合肥防火卷帘门厂家_安徽耐火窗_良万消防设备有限公司 | 全自动五线打端沾锡机,全自动裁线剥皮双头沾锡机,全自动尼龙扎带机-东莞市海文能机械设备有限公司 | 达利园物流科技集团- | 河北中仪伟创试验仪器有限公司是专业生产沥青,土工,水泥,混凝土等试验仪器的厂家,咨询电话:13373070969 | 皮带输送机-大倾角皮带输送机-皮带输送机厂家-河南坤威机械 | CTAB,表面活性剂1631溴型(十六烷基三甲基溴化铵)-上海升纬化工原料有限公司 | pos机办理,智能/扫码/二维码/微信支付宝pos机-北京万汇通宝商贸有限公司 | 医疗仪器模块 健康一体机 多参数监护仪 智慧医疗仪器方案定制 血氧监护 心电监护 -朗锐慧康 | 热工多功能信号校验仪-热电阻热电偶校验仿真仪-金湖虹润仪表 | 超声波流量计_流量标准装置生产厂家 _河南盛天精密测控 | 北京环球北美考试院【官方网站】|北京托福培训班|北京托福培训 | 压缩空气检测_气体_水质找上海京工-服务专业、价格合理 | 楼承板设备-楼承板成型机-免浇筑楼承板机器厂家-捡来 | 北京公积金代办/租房发票/租房备案-北京金鼎源公积金提取服务中心 | 杭州ROHS检测仪-XRF测试仪价格-百科| 气体热式流量计-定量控制流量计(空气流量计厂家)-湖北南控仪表科技有限公司 | 杭州厂房降温,车间降温设备,车间通风降温,厂房降温方案,杭州嘉友实业爽风品牌 | ◆大型吹塑加工|吹塑加工|吹塑代加工|吹塑加工厂|吹塑设备|滚塑加工|滚塑代加工-莱力奇塑业有限公司 | 杭州荣奥家具有限公司-浙江办公家具,杭州办公家具厂 | 基本型顶空进样器-全自动热脱附解吸仪价格-AutoHS全模式-成都科林分析技术有限公司 | 尊享蟹太太美味,大闸蟹礼卡|礼券|礼盒在线预订-蟹太太官网 | Safety light curtain|Belt Sway Switches|Pull Rope Switch|ultrasonic flaw detector-Shandong Zhuoxin Machinery Co., Ltd | 上海办公室装修公司_办公室设计_直营办公装修-羚志悦装 | 对辊破碎机_四辊破碎机_双齿辊破碎机_华盛铭重工 | 河南新乡德诚生产厂家主营震动筛,振动筛设备,筛机,塑料震动筛选机 | 活动策划,舞台搭建,活动策划公司-首选美湖上海活动策划公司 | 影合社-影视人的内容合作平台 | 济南展厅设计施工_数字化展厅策划设计施工公司_山东锐尚文化传播有限公司 | 西安中国国际旅行社(西安国旅) | 合肥活动房_安徽活动板房_集成打包箱房厂家-安徽玉强钢结构集成房屋有限公司 | 高铝矾土熟料_细粉_骨料_消失模_铸造用铝矾土_铝酸钙粉—嵩峰厂家 | 电缆接头-防爆电缆接头-格兰头-金属电缆接头-防爆填料函 | 九州网址_专注于提供网址大全分享推广中文网站导航服务 | 广东燎了网络科技有限公司官网-网站建设-珠海网络推广-高端营销型外贸网站建设-珠海专业h5建站公司「了了网」 | 首页 - 张店继勇软件开发工作室| 闭端端子|弹簧螺式接线头|防水接线头|插线式接线头|端子台|电源线扣+护线套|印刷电路板型端子台|金笔电子代理商-上海拓胜电气有限公司 |