一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - 淺談mybatis中的#和$的區(qū)別

淺談mybatis中的#和$的區(qū)別

2020-05-20 12:05jingxian JAVA教程

下面小編就為大家?guī)硪黄獪\談mybatis中的#和$的區(qū)別。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

1. #將傳入的數(shù)據(jù)都當成一個字符串,會對自動傳入的數(shù)據(jù)加一個雙引號。如:order by #user_id#,如果傳入的值是111,那么解析成sql時的值為order by "111", 如果傳入的值是id,則解析成的sql為order by "id".   

2. $將傳入的數(shù)據(jù)直接顯示生成在sql中。如:order by $user_id$,如果傳入的值是111,那么解析成sql時的值為order by user_id, 如果傳入的值是id,則解析成的sql為order by id.   

3. #方式能夠很大程度防止sql注入。  

4.$方式無法防止Sql注入。

5.$方式一般用于傳入數(shù)據(jù)庫對象,例如傳入表名.   

6.一般能用#的就別用$.

MyBatis排序時使用order by 動態(tài)參數(shù)時需要注意,用$而不是#

字符串替換

默認情況下,使用#{}格式的語法會導致MyBatis創(chuàng)建預處理語句屬性并以它為背景設置安全的值(比如?)。這樣做很安全,很迅速也是首選做法,有時你只是想直接在SQL語句中插入一個不改變的字符串。比如,像ORDER BY,你可以這樣來使用: ORDER BY ${columnName}

這里MyBatis不會修改或轉(zhuǎn)義字符串。

重要:接受從用戶輸出的內(nèi)容并提供給語句中不變的字符串,這樣做是不安全的。這會導致潛在的SQL注入攻擊,因此你不應該允許用戶輸入這些字段,或者通常自行轉(zhuǎn)義并檢查。

以上就是小編為大家?guī)淼臏\談mybatis中的#和$的區(qū)別全部內(nèi)容了,希望大家多多支持服務器之家~

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲天堂成人在线观看 | 72张让男人一看就硬的图片 | 精品国产乱码久久久久久免费 | 国产精品欧美亚洲韩国日本99 | 美女牲交毛片一级视频 | nhdta系列媚药系列 | 麻豆网 | 欧美一区二区日韩一区二区 | 亚洲人成网站在线观看青青 | 免费一级黄 | 好涨好爽乱岳 | 欧美综合在线 | 小兰被扒开内裤露出p | 2021国产麻豆剧传媒剧情最新 | 色综合网天天综合色中文男男 | 好爽好紧小雪别夹小说 | 探花 在线 | 秋霞在线观看成人高清视频51 | 成全视频在线观看免费 | 欧美男同video | 九九99亚洲精品久久久久 | 饭冈加奈子黑人解禁在线播放 | 欧美三级不卡在线观线看高清 | 美女扒开屁股让我桶免费 | 操小女人| 成人做视频免费 | 欧美性野久久久久久久久 | 日本老妇乱子伦中文视频 | 天天性综合 | 久久精品AV一区二区无码 | 欧美x×x | 国产精品啪啪 | 午夜性色一区二区三区不卡视频 | 亚洲AV久久无码精品九九软件 | 久久99国产视频 | 欧美成人免费一区在线播放 | 国产福利一区二区精品视频 | 沉香如屑西瓜视频免费观看完整版 | 亚洲天堂中文 | 亚洲国产精品自在自线观看 | 按摩椅play啊太快了h |