当前位置:  开发笔记 > 编程语言 > 正文

如果我只允许来自特定列表的单词,我是否有SQL注入的危险?

如何解决《如果我只允许来自特定列表的单词,我是否有SQL注入的危险?》经验,为你挑选了1个好方法。

我有一些代码访问SQL Server数据库中的表:

...
if (GetViewNames(connection).Contains(name))
{
    query = "SELECT * FROM [" + name + "]";
}
...

这是"GetViewNames":

private List GetViewNames(SqlConnection connection)
{
    List viewNames = new List();

    foreach (DataRow row in connection.GetSchema("Views").Rows)
    {
        // The third element in the "rows" array is the name of the view.
        viewNames.Add(row[2].ToString());
    }

    return viewNames;
}

我想知道的是这个代码是否对SQL注入开放.name是一个通过URL传递的字符串(坏,我知道),但它只会查询数据库,如果name在我的表列表中,对吧?或者我在这里遗漏了什么?

我不是安全专家,所以请善待您的回复.



1> 小智..:

没有什么能阻止你创建一个名为的视图users];DROP TABLE [users.应该清楚使用此视图名称执行代码时会发生什么.

如果您的所有观点都是由您自己命名的,那么可以保证它的安全,但我建议您使用QUOTENAME以防万一.

推荐阅读
贾志军
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有