亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

防SQL注入:生成參數化的通用分頁查詢語句

系統 1658 0
原文: 防SQL注入:生成參數化的通用分頁查詢語句

????? 前些時間看了玉開兄的“ 如此高效通用的分頁存儲過程是帶有sql注入漏洞的 ”這篇文章,才突然想起某個項目也是使用了累似的通用分頁存儲過程。使用這種通用的存儲過程進行分頁查詢,想要防SQL注入,只能對輸入的參數進行過濾,例如將一個單引號“'”轉換成兩個單引號“''”,但這種做法是不安全的,厲害的黑客可以通過編碼的方式繞過單引號的過濾,要想有效防SQL注入,只有參數化查詢才是最終的解決方案。但問題就出在這種通用分頁存儲過程是在存儲過程內部進行SQL語句拼接,根本無法修改為參數化的查詢語句,因此這種通用分頁存儲過程是不可取的。但是如果不用通用的分頁存儲過程,則意味著必須為每個具體的分頁查詢寫一個分頁存儲過程,這會增加不少的工作量。

????? 經過幾天的時間考慮之后,想到了一個用代碼來生成參數化的通用分頁查詢語句的解決方案。代碼如下:

Code

?

使用方法:

?

PagerQuery query = new PagerQuery();
query.PageIndex = 1;
??? query.PageSize = 20;
??? query.PK = "ID";
??? query.SelectClause = "*";
??? query.FromClause = "TestTable";
??? query.SortClause = "ID DESC";

??? if (!string.IsNullOrEmpty(code))
??? {
??? ?query.WhereClause.Append(" and ID= @ID");
??? }

a)?GenerateCountSql ()方法生成的語句為:
Select count(0) from TestTable Where 1=1 and ID= @ID

b)?GenerateSql()方法生成的語句為:
WITH t AS (SELECT ROW_NUMBER() OVER(ORDER BY ECID DESC) as row_number, * from TestTable where 1=1 and ID= @ID) Select * from t where row_number BETWEEN 1 and 20

c)?GenerateSqlIncludetTotalRecords()方法生成的語句為:
WITH t AS (SELECT ROW_NUMBER() OVER(ORDER BY E.ECID DESC) as row_number,* from TestTable where 1=1 and ID= @ID) Select * from t where row_number BETWEEN 1 and 20;Select count(0) from ECBasicInfo where 1=1 and ID= @ID;

注意:以上代碼生成的SQL語句是曾對SQL SERVER 2005以上版本的,希望這些代碼對大家有用

防SQL注入:生成參數化的通用分頁查詢語句


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 久久九九有精品国产23百花影院 | 亚洲一区国产 | 成人国产欧美精品一区二区 | 精品国产综合成人亚洲区 | 精品午夜寂寞影院在线观看 | 国产在线视频福利 | 伊人久久综在合线亚洲91 | 99国产成人精品2021 | 91免费国产在线观看尤物 | 日韩美女视频一区 | 四虎国产精品永久地址99新强 | 一级毛片免费观看不收费 | 中文字幕亚洲综合久久 | 国产成人午夜精品影院游乐网 | 4虎影院永久地址www | 99精品中文字幕 | 最新国产中文字幕 | 欧美另类亚洲一区二区 | 精品欧美一区手机在线观看 | 久久99亚洲精品久久频 | 精品美女在线观看 | 国产成人精品福利色多多 | 国产成人精品.一二区 | 国内精品哆啪啪 | 久草视频在线网 | 久久亚洲精品国产亚洲老地址 | 国产精品乱码免费一区二区 | 欧美精选在线 | 日韩中文字幕在线不卡 | 亚洲精品中文一区不卡 | 91精品国产闺蜜国产在线 | 青青热久久久久综合精品 | 一区二区三区四区产品乱码伦 | 国产午夜爽爽窝窝在线观看 | 真实国产乱子伦精品免费 | 久久国产精品吴梦梦 | 亚洲精品大片 | 免费看一级a一片毛片 | 欧美体内she精视频毛片 | 日韩毛片欧美一级国产毛片 | 亚洲国产精品一区二区首页 |