web.config连接字符串的一些总结

阅读目录

  • DS01:数据库连接字符串的两种写法
  • DS02:数据库连接字符串的内容

DS01:数据库连接字符串的两种写法

1、连接字符串的两种写法:

<configuration>
   <appSettings>
      <add key="connstr1" value="Data Source=.;Initial Catalog=DBName;Integrated Security=true"/>
      <add key="connstr2" value=".........">
   </appSettings>
   <connectionStrings>
      <add name="connstr3" connectionString="........" />
      <add name="connstr4" connectionString="......" providerName="System.Data.Sqlclient"/>
   </connectionStrings>
</configuration>

如上代码所示:两种方式为<appSettings>和<connectionStrings>。

2、下面对两种写法进行分析:

appSettings:

①它是asp.net1.1的时候用的,在vs2003中用的。

②里面存的相当于键值对的形式,key和value。不仅仅可以存连接字符串,还可以存储一些配置项。

③在appSettings中,不能使用ProviderName="System.Data......."(不过如果你要用也可以,只要写在value里面就可以了,当成值传递过去)。

④在后台取值方式:string conn=System.Configuration.ConfigurationManager.AppSettings["connstr";]

connectionStrings:

①它是asp.net2.0中新增的。

②里面存的也类似于键值对的形式,使用的是name和connectionString,一般就存连接字符串。

③在connectionStrings中可以使用providerName。

④在后台取值的方式:string conn=System.Configuration.ConfigurationManager.ConnectionStrings["connstr"].ConnectionString;

3、两种方式的区别:
connectionStrings是2.0版本出来的,它比appsettings多的好处如下:

① 可将连接字符串加密,使用MS的一个加密工具即可。

② 可直接绑定数据源控件,而不必写代码读出来再赋值给控件。

③ 可方便的更换数据库平台,如换为Oracle数据库,只需修改providerName。

4、providerName的作用是什么呢?

我们先看一下providerName的参数值。

①providerName="System.Data.SqlClient"        ----说明使用的是MSSQLServer数据库
②providerName="System.Data.SqlLite"           ----说明使用的是SQLLite数据库
③providerName="System.Data.OracleClient"  ----说明使用的是Oracle数据库
或providerName="System.Data.Oracle.DataAccess.Client"  ----同上
④providerName="System.Data.OleDb"           ----说明使用的是Access数据库

注意:providerName可写可不写。

5、那我们什么时候用providerName呢?

比如,我们现在要做一个项目,以后会卖个两个企业使用:A和B。那么这就有不确定因素了,万一A使用Oracle,而B使用SQL Server呢?所以:

①数据库:我们需要建两个库,一个用Oracle,一个用SQL Server。

②程序:我们一般不去写两个系统让他们使用,我们肯定会去判断他们使用的是什么数据库,然后再在程序里执行什么样的数据库脚本。

③web.config代码如下:

<configuration>
  <connectionStrings>
    <add name="connStr" connectionString="Data Source=.;Initial Catalog=mydb;Integrated Security=true"  providerName="System.Data.SqlClient"/>
  </connectionStrings>
</configuration>

④程序代码如下:

现在进行判断,如果providerName="System.Data.SqlClient"则执行SQLServer的脚本,而如果providerName="System.Data.OracleClient"则调用Oracle的数据库脚本,代码如下:

 1 public static readonly string connStr = System.Configuration.ConfigurationManager.ConnectionStrings["connStr"].ProviderName;
 2 public static string databaseType = System.Configuration.ConfigurationManager.ConnectionStrings["connStr"].ProviderName;
 3 public static int ExecuteNonQuery(CommandType commandType, string commandText, params System.Data.OleDb.OleDbParameter[] parm)
 4 {
 5     int num = 0;
 6     if (databaseType == "System.Data.SqlClient")
 7     {
 8         //此处执行Microsoft SQLServer的数据库脚本
 9     }
10     else if (databaseType == "System.Data.OracleClient")
11     {
12         //此处执行Oracle的数据库脚本
13     }
14     return num;
15 }            

回到顶部

DS02:数据库连接字符串的内容

1、背景:我们写一个程序要访问SQL Server数据库就要用到连接字符串,连接字符串告诉程序要连接哪台数据库服务器,哪个实例,哪个数据库,以及数据库登录验证方式是什么等信息。

     这三者是最基本的,所以连接字符串最少由以上三个要素组成,其他的根据不同的情况用到什么添加什么即可。

2、虽然说最简单的数据库连接字符串仅由三个要素组成,但是有很多的写法,我们首先来看最简单的连接字符串书写格式:

@”Data Source=XL-PC; Initial Catalog=DB_Test; UID=Sa; PWD= test”

@”Data Source=XL-PC; Initial Catalog=DB_Test; Integrated Security=true”

3、以上是两个最简单的连接字符串,现在我们来具体分析一下:

(1)DataSource:指定要连接到的数据服务器名称。书写格式一般为“数据服务器名/实例名”。

DataSource也可以用Server,Address,Addr来代替。如果数据库服务器在本地,该项可以直接写“.”或者“(local)”两者都不包括引号。

如果本地安装了多个数据库实例,直接写“.”或者“(local)”会自动连接到较高版本的实例。

本地非EXPRESS版数据库服务器地址于数据库实例名称相同,可以直接写数据库服务器名称;

本地Express版本的数据库实例名一般默认为“计算机名+/SQLEXPRESS”如“XL-PC/SQLEXPRESS”或“(local)/SQLEXPRESS”或“./SQLEXPRESS”;

如果连接的是远程服务器则格式为“IP地址+/实例名”。

Data和Source之间必须有且只有一个空格。除密码外不区分大小写。所有标点符号都是英文标点。

(2)Initial Catalog:指定要连接的数据库名称。

数据规范与DataSource相同,也可以用Database代替。

(3)UID为用户名,PWD为密码,两者分别可以用Userid和Password代替。

(4)Integrated Security:属性设为true表示采用Windows身份验证,不需要指定用户名与密码。

回到顶部

2015年1月19日 13:26:59

by selonsy

时间: 2024-08-01 07:42:27

web.config连接字符串的一些总结的相关文章

Asp.Net配置Web.config连接SqlServer数据库

前言  今天下午帮同学解决了bug,一个小问题耽误了lz接近一下午的时间.写篇博客记录下在这个过程中遇到的问题. 解决过程  step1:在连接数据库的时候,提示连接失败,这种问题有80%的概率是因为web.config中连接字符串写错了.首先web.config连接Sqlserver数据库配置有两种验证方式  Windows身份验证 string connectionstring ="Server=服务器名;Integrated Security=SSPI;database=LibraryMi

加密,解密web.config数据库连接字符串

"connectionStrings" 路径是web.config所在的工程目录. 1.加密EncryptWebConfig.bat @echo offC:\Windows\Microsoft.NET\Framework\v4.0.30319\aspnet_regiis.exe -pef "connectionStrings" "D:\Web"PAUSE 2.解密DecryptWebConfig.bat @echo offC:\Windows\M

利用ASP.NET加密和解密Web.config中连接字符串

介绍 这篇文章我将介绍如何利用ASP.NET来加密和解密Web.config中连接字符串 背景描述 在以前的博客中,我写了许多关于介绍 Asp.net, Gridview, SQL Server, Ajax, JavaScript等的文章.大多数情况下,我都把数据库的连接字符串放在了web.config中.其中包含许多敏感信息,包括连接数据库的用户名密码等.然而我们在web.config和machine.config中以纯文本的方式保存密码安全吗? 如果我们的程序只是部署在内部服务器中,这应该没

ASP.NET web.config中的连接字符串

在ASP.NET的web.config中,可以用两种方式来写连接字符串的配置. 1 <configuration> 2 <appSettings> 3 <add key="connstr1" value="Data Source=.;Initial Catalog=DBName;Integrated Security=true"/> 4 <add key="connstr2" value="..

在ASP.NET项目中的web.config文件里配置数据库连接并在程序代码中获取连接字符串

  1.在<connectionStrings> 标签里添加连接 <connectionStrings> <add name="ConnectionName" connectionString="Server=.\SQLEXPRESS;Database=DatabaseName;UserID=sa;Password=abc123" providerName="System.Data.SqlClient" />

Web.config和App.config配置连接字符串

读取配置文件,获取连接字符串 <!-- 第一种 --> <connectionStrings> <add name="connString" connectionString="server=.;uid=sa; pwd=123456; database=SchoolDB;"/> </connectionStrings> <!-- string connString = System.Configuration.C

web.config connectionStrings 数据库连接字符串的解释

先来看一下默认的连接SQL Server数据库配置<connectionStrings>   <add name="LocalSqlServer" connectionString="Data Source=.\SQLExpress;Integrated Security=SSPI;AttachDBFilename=|DataDirectory|aspnetdb.mdf;User Instance=true" providerName="

web.config中配置数据库(多数据)连接的两种方式

这是我的第一篇文章,既然是第一篇了,那就从最基础的只是说起--web.config中配置数据库连接. 网上有很多这方面的资料,但发现并没有一篇从头到位很清楚明了说完的,今天就把我的整理写在这里吧. 在网站开发中,数据库操作是经常要用到的操作,ASP.NET中一般做法是在web.config中配置数据库连接代码,然后在程序中调用数据库连接代码,这样做的好处就是当数据库连接代码需要改变的时候,我们只要修改web.config中的数据库连接代码即可,而不必在修改每一个页面中的数据库连接代码. 在ASP

web.config的数据库连接字符串进行加密

连接参考:http://wenku.baidu.com/link?url=nwGug8wxz143A4pvBE_kN6vMU7aF3ojwCKJOyN-TQleZ07iAYrjx_FnFVDOtZAF8gbJ8UIwZXoPMWk7J0iZNd3IP_niggQGMLr2A6UgTcC3 旧版本的ASP.NET将连接字符串直接保存在ASPX页面中.回想一下,连接字符串包 含了数据服务器名称和用户账户等信息,有时候甚至还包含了密码.在代码中包含以上信息是非常不好的习惯,原因有二.首先,这些信息可以