Asp.Net中用户NT AUTHORITY\NETWORK SERVICE 登录失败(SQL2005/2008设置的解决方法)

用户 NT AUTHORITY\NETWORK SERVICE 登录失败 解决方法 (MS SQL 2005)

Windows server 2003,2008 Web.Config 配置连接sql 使用 win身份验证时:

当连接sql server使用信任连接(参看Web.Config文件)时就会出这个错误,在Windows XP当中,ASP.NET的运行帐号是ASPNET,而在Windows server 2003,2008号则改为了Network Service,直接把这个用户加到sql server的登陆帐号里面就好了 当然添加ASPNET用户时也是如此

具体的解决方法:

第一步:把'NT AUTHORITY\NETWORK SERVICE' 添加到Administrator组中
我的电脑-->右键-->管理-->本地用户和组
选择“组”-->双击Administrators-->单击“添加”-->单击“高级”-->单击“立即查找”-->在下面的列表中选择Network Service用户-->两次单击“确定”-->加入。

第二步 在企业管理器中加入NetWord Service用户
打开Sql Server企业管理器-->选择数据库实例-->打开“安全性”节点-->选择“登录”-->在右边的列表中单击右键-->选择“新建登录”-->常规---->搜索---->高级----->立即查找----->找到:NETWORK SERVICE--->点击确定,此时返回到新建上面 登录名 文本中已有:NT AUTHORITY\NETWORK SERVICE

接着------->左边导航:服务器角色勾选sysadmin-----> 左边导航:用户映射---->勾选要连接的数据库或者所有数据库

到此为止: 测试一下 是不是成功了! 呵呵

下面为连接配置:

<connectionStrings>
<!--sql验证-->
<!--<add name="ConnectionString" connectionString="Server=.;Database=GA_GaGaHjt;Uid=sa;Pwd=sa" providerName="System.Data.SqlClient" />-->
<!--win验证-->
<add name="ConnectionString" connectionString="Database=GA_GaGaHjt;Server=.;Integrated Security=SSPI" providerName="System.Data.SqlClient" />
</connectionStrings>

注:使用win 身份验证时(本人使用微软企业库5.0) 必须写上:providerName="System.Data.SqlClient否则会报错:

“The type Database cannot be constructed. You must configure the container to supply this value.”


=========================================================================================


用户 NT AUTHORITY\NETWORK SERVICE 登录失败解决方法Sql2008

首次使用SQL Server 2008在Vista旗舰版下进行ASP.NET开发就遇到了不少令人困惑的问题,其中之一就是“用户 NT AUTHORITY\NETWORK SERVICE登陆失败”的问题。开始,我以为是数据库连接字符串写错了,反复检查后发现这并非症结所在。经过查阅资料,发现原因是Vista下ASP.NET的运行账户改成了Network Service(Windows Server 2003中也一样),而XP中ASP.NET的运行账户是ASPNET,难怪那么多人不喜欢用Vista

<wbr><wbr><wbr>再查查解决方案,网上的一致的解决方案均是以老版的SQL Server 2000写的,不适用于SQL Server 2005/2008。以下是我反复试验后得出的在SQL Server 2008中的正确解决方案:</wbr></wbr></wbr>

<wbr><wbr><wbr>(1)配置Vista系统。[桌面]-&gt;[计算机]-&gt;右键-&gt;[管理]-&gt;展开“本地用户与组”-&gt;选“组”-&gt;在右边的名称中双击“Administrators”-&gt;在弹出的窗口中单击“添加...”按钮-&gt;在弹出的“选择用户”窗口中单击“高级...”按钮-&gt;单击“立即查找”按钮-&gt;在下面的“搜索结果”中选中“Network Service”并点“确认”-&gt;“确定”按钮-&gt;“确定”按钮-&gt;“应用”按钮。至此,Vista系统用户配置完毕。</wbr></wbr></wbr>

<wbr><wbr><wbr><wbr>(2)配置SQL Server 2008。打开“Microsoft SQL Server Management Studio”,找到想要配置的数据库实例并展开-&gt;展开“安全性”-&gt;在“用户”文件夹上点右键,选“新建用户”-&gt;点击“登录名”文本框后面的“...”按钮-&gt;在“选择登录名”窗口中点“浏览”按钮-&gt;在“查找对象”窗口中选中[NT AUTHORITY\NETWORK SERVICE](前面打钩)-&gt;“确定”按钮-&gt;“确定”按钮-&gt;在“登录名”文本框上面的“用户名”文本框中输入一个名字(这个可以随便写)-&gt;“确定”按钮。至此,数据库配置完毕。</wbr></wbr></wbr></wbr>

<wbr><wbr><wbr>(3)重新运行ASP.NET程序,此处必须保证数据库的身份验证类型为“Windows验证”和“允许访问”,问题解决。</wbr></wbr></wbr>

<wbr><wbr><wbr><wbr>PS:SQL Server 2008和SQL Server 2000的一个重要区别就是:前者在“安全性”文件夹下没有“登录”子文件夹,所以不少以SQL Server 2000为例子的文章在2008下不适用。</wbr></wbr></wbr></wbr>

转自:http://www.cnblogs.com/hendy/archive/2009/12/11/1622131.html
http://hi.baidu.com/gagahjt/item/058f4217d3af8f36b931801b


你可能感兴趣的:(asp.net)