SQL Server数据库对连接字符串的安全性处理

本文我们主要介绍了关于SQL Server数据库连接字符串的定义以及它的安全性问题的一些知识,接下来就让我们一起来了解一下这一过程吧。

一、数据库安全性

1)尽量使用Windows身份验证而不是SQL Server 验证。

安全容易管理:使用Windows身份验证:连接时需要写一个Windows集成的安全性,连接时使用的是本机正在使用的用户,或者是IIS正在连接到SQL Server的用户。使用集成的用户连接到SQL Server。在Web应用程序,我们需要了解是哪个用户连接到了SQL Server,默认下,放在IIS的虚拟目录应用程序,用集成的身份验证访问SQL Server,会通过IIS里的aspnet虚拟用户访问后台的SQL数据库。就需要指定它的权限来访问数据库。 如果通过希望客户端,集成Windows身份验证,需要在IIS里面对这个用户指定权限。Asp.net仍然后使用aspnet用户,需要通过web.config模拟<identity>结点来配置,就可以将IE传过来的用户传到后台,但是注意连接过多的话,因为每个人连接集成不一样,不会使用连接池。

使用SQL Server 验证:连接到后台的SQL Server要知道哪个用户,连接时需要输入用户名和密码。

不需要在连接字符串中设置用户名和密码:在登录时输入用户名和密码,更加安全,由Windows控制。用户名和密码放在本机的数据库里面,放在与环境里面。

可以通过密码策略保证安全:比如:在域环境里面,指定密码策略,保证密码的复杂度,密码不重复。

密码不会通过明文在网络中传递,集成Windows 身份验证:

 

  1. SqlClient : Integrated Security = true   or  Integrated Security = SSPI 
  2.  
  3. OleDb   :Integrated Security = true 
  4.  
  5. Odbc    :Trusted_Connection = yes ;  
  6.  
  7. OracleClient :Integrated Security = true 

二、定义连接字符串

1)Persist Security Info的默认设置为 false。

2)如果将其设置为TRUE 或FALSE,则允许再打开连接后通过获取安全敏感信息(包括用户ID和密码)确保的连接之后不会返回到应用程序。

3)保持将Persist Security Info显示的设置为false ,以确保不受信任的来源不能访问连接字符串。

DEMO1: 修改Persist Security Info

 

  1. using System;  
  2.  
  3. using System.Data.SqlClient;  
  4.  
  5. namespace 修改Persist_Security_Info  
  6.  
  7. {  
  8.  
  9. class Program  
  10.  
  11. {  
  12.  
  13. static void Main(string[] args)  
  14.  
  15. {   
  16.  
  17. //persist Security Info = false 
  18.  
  19. SqlConnection conn2 = new SqlConnection("server=.;database=Test;uid =sa;pwd=sa; Persist Security Info = false");     
  20.  
  21. conn2.Open();  
  22.  
  23. if (!string.IsNullOrEmpty(conn2.ConnectionString))  
  24.  
  25. {  
  26.  
  27. Console.WriteLine(conn2.ConnectionString);  
  28.  
  29. }  
  30.  
  31. conn2.Close();  
  32.  
  33. //persist Security Info = true 
  34.  
  35. SqlConnection conn1 = new SqlConnection("server=.;database=Test;uid=sa;pwd=sa;Persist Security Info = true;");  
  36.  
  37. conn1.Open();  
  38.  
  39. if (!string.IsNullOrEmpty(conn1.ConnectionString))  
  40.  
  41. {  
  42.  
  43. Console.WriteLine(conn1.ConnectionString);  
  44.  
  45. }  
  46.  
  47. conn1.Close();  
  48.  
  49. }  
  50.  
  51. }  
  52.  

 

三、连接字符串的注入式攻击 

有些连接是通过SQL Server身份验证连接的,比如:企业里面的Windows应用程序,输入用户名密码就是登录(SQL Server的用户名和密码),权限(能看哪些数据,不能看哪些数据)是通过SQL Server来控制的。

1)类似于SQl 注入式攻击。

2)在连接字符串中通过封号来加入其他的参数。

3)例如: str = constr =”server= .; database=Test;uid =sa ;pwd=”+password ;输入的是: password= “sa; Pooling = true ;Min Pool Size = 999999 ; Max Pool Szzie = 999999;”

解决方法——>使用连接字符串生成器

1)ADO.NET2.0 为不同数据库提供程序引入了新的连接字符串生成器

2)从DbConnectionStringBuilder继承:

提供程序

ConnectionStringBuilder类

System.Data.SqlClient

SqlConnectionStringBuilder

System.Data.OleDb

OleDbConnectionStringBuilder

System.Data.Odbc

OdbcConnectionStringBuilder

System.Data.OracleClient

OracleConnectionStringBuilder

便于不同数据库提供程序连接字符串的编写。

可以避免连接字符串注入式攻击(还可以用 ‘.’ 运算符赋值)

DEMO2:连接字符串生成器。

 

  1. private void button1_Click(object sender, EventArgs e)  
  2.  
  3. {  
  4.  
  5. SqlConnectionStringBuilder builder = new SqlConnectionStringBuilder();  
  6.  
  7. builder.DataSource = txtServer.Text.Trim();  
  8.  
  9. builder.InitialCatalog = txtDb.Text.Trim();  
  10.  
  11. builder.UserID = txtDb.Text.Trim();  
  12.  
  13. builder.Password = txtPwd.Text.Trim();  
  14.  
  15. this.txtConStr.Text = builder.ConnectionString;   
  16.  

 

四、存储连接字符串

将整个连接字符串存储,不希望被查看连接字符串。

方法一:放在一个不知道的地方

方法二:加密

连接字符串存储在:

1)配置文件(不隐蔽)。

2)COM+Catalog。

3)Windows注册表里面。

4)自定义文件结构。

DEOM3:在配置文件中存储连接字符串。

Load事件:

 

  1. private void Form1_Load(object sender, EventArgs e)  
  2.  
  3. {  
  4.  
  5. //连接字符串直接保存在 App.config里面  
  6.  
  7. ConnectionStringSettings settings =  ConfigurationManager.ConnectionStrings["strCon"];  
  8.  
  9. this.textBox1.Text = settings.ConnectionString;  
  10.  
  11. //连接通过configSource保存在 connectionString.config  
  12.  
  13. this.txtCon.Text = ConfigurationManager.AppSettings["conn"].ToString();  
  14.  
  15. }  
  16.  
  17. App.config:  
  18.  
  19. <?xml version="1.0" encoding="utf-8" ?> 
  20.  
  21. <configuration> 
  22.  
  23. <connectionStrings > 
  24.  
  25. <add name="strCon" connectionString="server=.;database=Test;uid=sa;pwd=sa"/> 
  26.  
  27. </connectionStrings> 
  28.  
  29. <!--在connectionString.config文件里面指定 appSettings 节点的配置  
  30.  
  31. 便于单独对这个节点进行加密 [需要将connectionString.confi复制到输出目录下,否则    
  32.  
  33. App.config找不到]--> 
  34.  
  35. <appSettings configSource="connectionString.config"/> 
  36.  
  37. </configuration> 
  38.  
  39. connectionString.config:  
  40.  
  41. <appSettings> 
  42.  
  43. <add key="conn" value="server=.;database=Test;uid=sa;pwd=sa"/> 
  44.  
  45. </appSettings> 

 

五、加密连接字符串

.NET当中的加密算法:

1)对称算法(3DES)  :保存密钥。

2)非对称算法(RSA) :通过公钥(保存在XML里面)控制加密解密。

3)数据保护(DPAPI)   :不是加密算法,而是使用DPAPI(一个WindowsAPI,数据保护的API,使用Windows本机用户的安全性)。

六、受保护的配置

1)使用受保护配置对连接字符串值进行加密的配置文件不以明文形式显示连接字符串, 而是以加密形式存储它们。

2)在对页进行请求时在对页进行请求时,.NET Framework 对连接字符串信息进行解密,并使其可供应用程序使用。

创建配置

1)ASP.NET IIS 注册工具(Aspnet_regiis.exe) 

–  对Web.config文件(其他的文件也是一样的)的节进行加密和解密、创建或删除密钥容器、导出和导入密钥容器信息以及管理对密钥容器的访问。

2)System.Configuratiion 命名空间中的受保护配置命名空间中的类。

– DPAPIProtectedConfigurationProvider。使用Windows 数据保护API (DPAPI) 对数据进行加密和解密。

– RsaProtectedConfigurationProvider 。使用RSA 加密算法对数据进行加密和解密。

关于SQL Server数据库连接字符串的安全性问题就介绍到这里了,希望本次的介绍能够对您有所帮助。

【编辑推荐】

  1. Oracle数据库如何创建DATABASE LINK?
  2. 简单介绍一下线程池和数据库连接池的原理
  3. 网站设计的注意事项:数据库集群和库表散列
  4. 管理员不能删除其他用户建立的DB Link的解决
  5. Oracle数据库对DDL语句和DML语句的事务管理

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/255078.html<

(0)
运维的头像运维
上一篇2025-04-30 16:21
下一篇 2025-04-30 16:23

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注