自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

解析ADO.NET連接字符串注入式攻擊

開發(fā) 后端
這里就了ADO.NET連接字符串生成器、連接字符串注入式攻擊,文章都有詳細(xì)的介紹,希望對大家有幫助。

ADO.NET連接字符串還是比較常用的,于是我研究了一下ADO.NET連接字符串生成器,在這里拿出來和大家分享一下,希望對大家有用。在 ADO.NET 的早期版本中,不會對具有串聯(lián)字符串值的連接字符串進(jìn)行編譯時檢查,因此在運(yùn)行時,不正確的關(guān)鍵字會產(chǎn)生 ArgumentException。每個 .NET Framework 數(shù)據(jù)提供程序支持的連接字符串關(guān)鍵字的語法不同,這使得手動構(gòu)造有效連接字符串變得很困難。為了解決這個問題,ADO.NET 2.0 為每個 .NET Framework 數(shù)據(jù)提供程序引入了新的連接字符串生成器。每個數(shù)據(jù)提供程序包括一個從 DbConnectionStringBuilder 繼承的強(qiáng)類型連接字符串生成器類。下表列出了 .NET Framework 數(shù)據(jù)提供程序及其關(guān)聯(lián)的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#當(dāng)使用動態(tài)字符串串聯(lián)根據(jù)用戶輸入生成連接字符串時,可能發(fā)生連接字符串注入式攻擊。如果未驗(yàn)證字符串并且未轉(zhuǎn)義惡意文本或字符,則攻擊者可能會訪問服務(wù)器上的敏感數(shù)據(jù)或其他資源。例如,攻擊者可以通過提供分號并追加其他值來發(fā)起攻擊。連接字符串通過“l(fā)ast one wins”算法分析,惡意的輸入被替換為合法的值。連接字符串生成器類旨在排除推測,防止出現(xiàn)語法錯誤和安全漏洞。它們提供與每個數(shù)據(jù)提供程序允許的已知鍵/值對相對應(yīng)的方法和屬性。每個類都保持一個固定的同義詞集合,可以將同義詞轉(zhuǎn)換為相應(yīng)的已知鍵名。將執(zhí)行鍵/值對的有效性檢查,無效對會引發(fā)異常。此外,還會以一種安全方式處理插入的值。

下面的示例演示 SqlConnectionStringBuilder 如何處理為 Initial Catalog 設(shè)置插入的額外值。
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); 

輸出結(jié)果表明,通過用雙引號轉(zhuǎn)義該額外值而不作為新的鍵/值對將其追加到連接字符串,SqlConnectionStringBuilder 可以正確處理此額外值。

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

 

責(zé)任編輯:田樹 來源: 博客
相關(guān)推薦

2009-12-24 10:06:30

ADO.NET字符串

2009-11-12 11:09:56

ADO.NET連接字符

2009-12-24 09:49:02

ADO.Net連接池

2009-11-04 15:33:05

ADO.NET連接字符

2009-11-13 16:29:11

ADO.NET連接字符

2009-12-23 14:59:32

ADO.NET 2.0

2009-09-09 10:23:59

ADO.NET連接

2009-11-12 10:53:57

ADO.NET連接My

2011-05-20 16:18:23

ADO.NET

2009-10-29 10:57:28

ADO.NET Dat

2009-11-12 10:45:45

ADO.NET連接測試

2009-11-12 11:38:03

ADO.NET連接事件

2009-12-25 10:25:59

2009-12-21 17:02:19

ADO.NET Sql

2010-01-04 09:03:57

ADO.NET連接對象

2009-12-21 14:14:08

ADO.NET類文件

2009-11-04 13:08:29

ADO.NET Dat

2009-12-18 16:39:59

ADO.NET基礎(chǔ)類

2009-11-12 11:17:13

2009-12-25 16:56:36

ADO.NET建立連接
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號