我可以使用内置帐户访问IIS 7中的不同网络驱动程序吗?

时间:2014-11-20 11:55:09

标签: windows iis nas

我必须使用一个奇怪的IIS7网络应用程序,需要访问三个网络驱动程序:第一个在NAS上,另外两个是不同Windows服务器上的共享文件夹。但是这个奇怪的IIS Web应用程序需要使用相同的帐户来访问所有这三个文件夹。到目前为止,我已尝试过这些组合:

  1. 使用NAS帐户访问NAS是IIS7:是
  2. 使用pass through帐户访问IIS7中的NAS:是
  3. 使用Windows帐户访问IIS7中的网络驱动程序:是
  4. 使用pass through帐户访问IIS7中的网络驱动程序:否
  5. NAS帐户有一个Windows不支持的ip前缀,这就是我无法强制所有网络驱动器使用同一帐户的原因。

    我不知道为什么IIS7不能使用传递帐户(LocalService,LocalSystem,NetworService或ApplicationPoolIdentify)来访问Windows的网络共享文件夹,而IIS7可以使用内置帐户访问NAS。这没有意义。

    请帮忙!


    当NAS和同一域中的所有三台服务器一起使用时,本文可以解决此问题ApplicationPoolIdentity user cannot modify files in shared folder in Windows Server 2008

    转到共享文件夹 - >右键单击 - >属性 - >安全性 - >编辑 - >添加(通常) - >选择对象类型 - >检查计算机 - >现在输入您的应用程序所在的计算机名称,即发布IIS应用程序的位置。

    但我的情况没有域名。

1 个答案:

答案 0 :(得分:0)

有三种方法可以解决这个问题:

1,在所有三个网络驱动程序服务器中添加相同的Windows帐户/相同密码。

在IIS7中,将此Windows帐户用作标识。

但是NAS帐户需要ip前缀,而Windows帐户不允许使用ip前缀。所以我不能用这个。

2,将服务器添加到同一域,允许IIS7服务器访问所有网络驱动程序服务器中的网络驱动程序。

但是,最终用户不允许我这样做。

3,最后我写了另一个IIS7网络应用程序,它可以帮助奇怪的IIS7网络应用程序登录所有网络驱动程序。

最终用户必须先访问我的网络应用,然后才能使用奇怪的IIS7网络应用。

在我的网络应用中,我经常使用这个API:WNetAddConnection2。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Runtime.InteropServices;

namespace IISReadDiskTest
{
    public class NetworkDrive
    {
        public enum ResourceScope
        {
            RESOURCE_CONNECTED = 1,
            RESOURCE_GLOBALNET,
            RESOURCE_REMEMBERED,
            RESOURCE_RECENT,
            RESOURCE_CONTEXT
        }

        public enum ResourceType
        {
            RESOURCETYPE_ANY,
            RESOURCETYPE_DISK,
            RESOURCETYPE_PRINT,
            RESOURCETYPE_RESERVED
        }

        public enum ResourceUsage
        {
            RESOURCEUSAGE_CONNECTABLE = 0x00000001,
            RESOURCEUSAGE_CONTAINER = 0x00000002,
            RESOURCEUSAGE_NOLOCALDEVICE = 0x00000004,
            RESOURCEUSAGE_SIBLING = 0x00000008,
            RESOURCEUSAGE_ATTACHED = 0x00000010,
            RESOURCEUSAGE_ALL = (RESOURCEUSAGE_CONNECTABLE | RESOURCEUSAGE_CONTAINER | RESOURCEUSAGE_ATTACHED),
        }

        public enum ResourceDisplayType
        {
            RESOURCEDISPLAYTYPE_GENERIC,
            RESOURCEDISPLAYTYPE_DOMAIN,
            RESOURCEDISPLAYTYPE_SERVER,
            RESOURCEDISPLAYTYPE_SHARE,
            RESOURCEDISPLAYTYPE_FILE,
            RESOURCEDISPLAYTYPE_GROUP,
            RESOURCEDISPLAYTYPE_NETWORK,
            RESOURCEDISPLAYTYPE_ROOT,
            RESOURCEDISPLAYTYPE_SHAREADMIN,
            RESOURCEDISPLAYTYPE_DIRECTORY,
            RESOURCEDISPLAYTYPE_TREE,
            RESOURCEDISPLAYTYPE_NDSCONTAINER
        }

        [StructLayout(LayoutKind.Sequential)]
        private class NETRESOURCE
        {
            public ResourceScope dwScope = 0;
            public ResourceType dwType = 0;
            public ResourceDisplayType dwDisplayType = 0;
            public ResourceUsage dwUsage = 0;
            public string lpLocalName = null;
            public string lpRemoteName = null;
            public string lpComment = null;
            public string lpProvider = null;
        }

        [DllImport("mpr.dll")]
        private static extern int WNetAddConnection2(NETRESOURCE lpNetResource, string lpPassword, string lpUsername, int dwFlags);

        public static int MapNetworkDrive(string remotePath, string localDrive, string userName, string passWord)
        {
            NETRESOURCE myNetResource = new NETRESOURCE();
            myNetResource.lpLocalName = localDrive;
            myNetResource.lpRemoteName = remotePath;
            myNetResource.lpProvider = null;
            int result = WNetAddConnection2(myNetResource, passWord, userName, 0);
            return result;
        }
    }
}