SQL连接语句中的Integrated Security=SSPI/true/false的使用

301 篇文章 ¥59.90 ¥99.00
本文探讨SQL数据库连接中的Integrated Security选项,包括SSPI、True和False的含义及用法。 Integrated Security用于指定身份验证方式,SSPI使用Windows凭据,True与SSPI效果相同,False则使用SQL Server身份验证。示例代码展示了不同设置下的连接方法。

在SQL数据库连接过程中,Integrated Security是一个重要的连接字符串选项,它用于指定身份验证的方式。在MySQL中,Integrated Security并不是一个可用的选项,但我们可以通过其他方式实现相似的功能。本文将详细介绍Integrated Security的作用和用法,并提供相应的源代码示例。

Integrated Security选项用于指定连接数据库时所使用的身份验证方式。在SQL Server中,这个选项有三个可能的取值:SSPI、True和False。下面将分别介绍这三种取值的含义和用法。

  1. Integrated Security=SSPI

SSPI(Security Support Provider Interface)是Microsoft Windows 提供的一种安全支持接口,它允许应用程序使用当前用户的Windows凭据进行身份验证。当我们将Integrated Security设置为SSPI时,连接将使用当前Windows登录用户的凭据进行身份验证。

下面是一个使用SSPI进行身份验证的示例代码:

string connectionString = "Data Source=ServerName; Initial Catalog=DatabaseName; Integrated Security=SSPI";

using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Data; using System.Data.SqlClient; using Models; using System.Configuration; using System.Xml; namespace DAL { public class DBConfig { /// <summary> /// 禁止实例化 /// </summary> private DBConfig() { } public static List<Databases> GetDatabaseName(string connStr) { SqlConnection conn = new SqlConnection(connStr); SqlCommand cmd = new SqlCommand("select name from sys.databases where name like '%Training%'", conn); List<Databases> list = new List<Databases>(); try { conn.Open(); SqlDataReader reader = cmd.ExecuteReader(); while (reader.Read()) { list.Add(new Databases() { DatabaseName=reader[0].ToString() }); } return list; } catch (Exception ex) { throw ex; } finally { conn.Close(); } } /// 获取ConnectionStrings public static string GetConnectionStringsConfig(string connectionName) { string connectionString = ConfigurationManager.ConnectionStrings[connectionName].ConnectionString; return connectionString; } /// /// 更新连接字符串 public static void UpdateConnectionStringsConfig(string key, string conString) { bool isModified = false; //记录该连接串是否已经存在 if (ConfigurationManager.ConnectionStrings[key] != null) { isModified = true; } //新建一个连接字符串实例 ConnectionStringSettings mySettings = new ConnectionStringSettings(key, conString); // 打开可执行的配置文件*.exe.config Configuration config = ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None); // 如果连接串已存在,首先删除它 if (isModified) { config.ConnectionStrings.ConnectionStrings.Remove(key); } // 将新的连接串添加到配置文件中. config.ConnectionStrings.ConnectionStrings.Add(mySettings); // 保存对配置文件所作的更改 config.Save(ConfigurationSaveMode.Modified); // 强制重新载入配置文件的ConnectionStrings配置节 ConfigurationManager.RefreshSection("connectionStrings"); } /// <summary> /// 修改AppSettings中配置 /// </summary> /// <param name="key">key值</param> /// <param name="value">相应值</param> public static bool SetConfigValue(string key, string value) { try { Configuration config = ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None); if (config.AppSettings.Settings[key] != null) config.AppSettings.Settings[key].Value = value; else config.AppSettings.Settings.Add(key, value); config.Save(ConfigurationSaveMode.Modified); ConfigurationManager.RefreshSection("appSettings"); return true; } catch { return false; } } /// <summary> /// 获取AppSettings中某一节点值 /// </summary> /// <param name="key"></param> public static string GetConfigValue(string key) { Configuration config = ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None); if (config.AppSettings.Settings[key] != null) return config.AppSettings.Settings[key].Value; else return string.Empty; } /// <summary> /// 测试连接数据库是否成功 /// </summary> /// <returns></returns> public static bool ConnectionTest(string ConnectionString) { //创建连接对象 SqlConnection mySqlConnection = new SqlConnection(ConnectionString); bool IsConnectionInfo = true; //ConnectionTimeout 在.net 1.x 可以设置 在.net 2.0后是只读属性,则需要在连接字符串设置 //如:server=.;uid=sa;pwd=;database=PMIS;Integrated Security=SSPI; Connection Timeout=30 //mySqlConnection.ConnectionTimeout = 1;//设置连接超时的时间 try { //Open DataBase //打开数据库 mySqlConnection.Open(); IsConnectionInfo = true; } catch { //Can not Open DataBase //打开不成功 则连接不成功 IsConnectionInfo = false; } finally { //Close DataBase //关闭数据库连接 mySqlConnection.Close(); } //mySqlConnection is a SqlConnection object if (mySqlConnection.State == ConnectionState.Closed || mySqlConnection.State == ConnectionState.Broken) { //Connection is not available return IsConnectionInfo; } else { //Connection is available return IsConnectionInfo; } } } }
最新发布
07-10
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值