解析ADO.NET连接字符串注入式攻击
创始人
2024-06-11 11:31:47
0

ADO.NET连接字符串还是比较常用的,于是我研究了一下ADO.NET连接字符串生成器,在这里拿出来和大家分享一下,希望对大家有用。在 ADO.NET 的早期版本中,不会对具有串联字符串值的连接字符串进行编译时检查,因此在运行时,不正确的关键字会产生 ArgumentException。每个 .NET Framework 数据提供程序支持的连接字符串关键字的语法不同,这使得手动构造有效连接字符串变得很困难。为了解决这个问题,ADO.NET 2.0 为每个 .NET Framework 数据提供程序引入了新的连接字符串生成器。每个数据提供程序包括一个从 DbConnectionStringBuilder 继承的强类型连接字符串生成器类。下表列出了 .NET Framework 数据提供程序及其关联的ADO.NET连接字符串生成器类。

  1. ConnectionStringBuilder 类  
  2. System.Data.SqlClient  
  3. SqlConnectionStringBuilder  
  4. System.Data.OleDb  
  5. OleDbConnectionStringBuilder  
  6. System.Data.Odbc  
  7. OdbcConnectionStringBuilder  
  8. System.Data.OracleClient  
  9. OracleConnectionStringBuilder 

连接字符串注入式攻击

#T#当使用动态字符串串联根据用户输入生成连接字符串时,可能发生连接字符串注入式攻击。如果未验证字符串并且未转义恶意文本或字符,则攻击者可能会访问服务器上的敏感数据或其他资源。例如,攻击者可以通过提供分号并追加其他值来发起攻击。连接字符串通过“last one wins”算法分析,恶意的输入被替换为合法的值。连接字符串生成器类旨在排除推测,防止出现语法错误和安全漏洞。它们提供与每个数据提供程序允许的已知键/值对相对应的方法和属性。每个类都保持一个固定的同义词集合,可以将同义词转换为相应的已知键名。将执行键/值对的有效性检查,无效对会引发异常。此外,还会以一种安全方式处理插入的值。

下面的示例演示 SqlConnectionStringBuilder 如何处理为 Initial Catalog 设置插入的额外值。
Visual Basic

  1. Dim builder As New System.Data.SqlClient.SqlConnectionStringBuilder  
  2. builder("Data Source") = "(local)"  
  3. builder("Integrated Security") = True  
  4. builder("Initial Catalog") = "AdventureWorks;NewValue=Bad"  
  5. Console.WriteLine(builder.ConnectionString) 

C#

  1. System.Data.SqlClient.SqlConnectionStringBuilder builder =  
  2. new System.Data.SqlClient.SqlConnectionStringBuilder();  
  3. builder["Data Source"] = "(local)";  
  4. builder["integrated Security"] = true;  
  5. builder["Initial Catalog"] = "AdventureWorks;NewValue=Bad";  
  6. Console.WriteLine(builder.ConnectionString); 

输出结果表明,通过用双引号转义该额外值而不作为新的键/值对将其追加到连接字符串,SqlConnectionStringBuilder 可以正确处理此额外值。

  1. data source=(local);Integrated Security=True;  
  2. initial catalog="AdventureWorks;NewValue=Bad" 

 

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...