| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1539 人关注过本帖
标题:动态SQL查询条件安全问题!
只看楼主 加入收藏
C心情
Rank: 2
等 级:论坛游民
帖 子:90
专家分:74
注 册:2008-1-19
结帖率:60%
收藏
已结贴  问题点数:8 回复次数:4 
动态SQL查询条件安全问题!
在多表多条件查询时如果查询条件是动态生成就容易造成sql语句拼接后被注入攻击,
不拼接又实现不了动态组合查询功能,不知道各位是怎么处理这个问题的,请指点一下,谢谢!
搜索更多相关主题的帖子: SQL 动态 条件 查询 
2010-06-19 15:06
cnfarer
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:179
帖 子:3330
专家分:21157
注 册:2010-1-19
收藏
得分:2 
拼接SQL这种方法,个人觉得不值得使用!!!一是容易出现你说的注入问题,二个这种语句效率低下,三个拼接的时候还容易出错!
推荐使用参数化查询。

★★★★★为人民服务★★★★★
2010-06-19 16:28
weilongzhou7
Rank: 1
等 级:新手上路
帖 子:1
专家分:3
注 册:2010-6-20
收藏
得分:2 
楼上正解,同意这个方法
2010-06-20 19:08
C心情
Rank: 2
等 级:论坛游民
帖 子:90
专家分:74
注 册:2008-1-19
收藏
得分:0 
多谢版主,可是要怎么用使用参数化来实现组合查询?

    DECLARE @Goods_ID int
    SELECT @Goods_ID=1001
    SELECT [Goods_ID]
          ,[Customer_ID]
          ,[sGoods_Name]
          ,[sGoods_Code]
          ,[sGoods_Barcode]
         ......还有很多的字段
      FROM [Goods] M
      LEFT JOIN Customer C ON Customer_ID=C.Customer_ID
      LEFT JOIN GoodsType T ON M.GoodsType_ID=T.GoodsType_ID
      WHERE Goods_ID=@Goods_ID -- ......
上面的WHERE 子句是无法确定的,只有在使用的时候用户根据自己的需要组合生成查询条件!

2010-06-21 15:25
cnfarer
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:179
帖 子:3330
专家分:21157
注 册:2010-1-19
收藏
得分:0 
回复 4楼 C心情
这就要靠你的智慧了!

★★★★★为人民服务★★★★★
2010-06-21 16:56
快速回复:动态SQL查询条件安全问题!
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.014377 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved