• iis7+的虚拟目录:未能加载程序集“**”。请确保在访问该页之前已经编译了此程序集


    在使用win8系统后,突然想运行iis,于是在windows组件中启用iis,并aspnet_regiis.exe -i注册iis后,于是开始发布了一个站点,一切正常

    继而,在该站点下添加虚拟目录,然后预览虚拟目录的网页,就会立刻报类似“未能加载程序集“App_Web_utohcdb4”。请确保在访问该页之前已经编译了此程序集。”的错误

    我纳闷了,我记得在以前版本的iis上建立一个虚拟目录是何其的简单并且不会出错,搜索后发现,原来右击网站,有了两个选下个“添加应用程序”和“添加虚拟目录”

    继续搜了下两者异同  (源自:http://blog.csdn.net/xiaoqijun/article/details/16523811

    A.虚拟目录
        虚拟目录是指在站点下建立一个虚拟子目录,指定一个固定的物理路径做为站点的应用路径。
        1. 虚拟目录与父级站点共用一个应用程序池
        例如:站点TestWeb(c:Inetpubwwwroot TestWeb)下建立了SubTestA(D:SubTestA)的虚拟目录
            若TestWeb为设定了Framework V2.0,则SubTestA也必须是Framework V2.0的应用程序,否则将给带来Framework不匹配的各种错误。
        2. 虚拟目录必须将可执行文件(dll等)放置在父级站点的bin目录下。
        3. 虚拟目录中的web.config文件继承父级站点的web.config.
            就是说如果父级站点声明过的引用,在虚拟目录下的web.config中不应重复声明
        4. 虚拟目录中的应用其根目录为父级站点的根目录    
        5. 虚拟目录中的AppSetting.config设置应使用相对路径来进行引用。
    B. 应用程序
        应用程序是指在父级目录下建立了一个单独的应用程序,独享应用程序池
        1. 应用程序可以与父级站点拥有不同的应用程序池
            即可以达到TestWeb为Framework V2.0,而SubTestA可以是Framework V4.0,二者互不影响
        2. SubTestA的可执行文件独立的放置在根目录下的bin中,不能放置在WebTest的bin目录中
        3. SubTestA的web.config独立于WebTest的web.config(之前说SubTestA的web.config独立于WebTest的web.config其实是不对的,测试发现就算添加应用程序也会继承站点下的web.config,除非配置禁止继承)
        4. SubTestA中的应用其根目录为父级站点的根目录
        5. 虚拟目录中的AppSetting.config设置应使用相对路径来进行引用。
     
    应用程序是建立在虚拟目录的基础之上,而应用程序独立于父级站点拥有独立的程序运行机制,这让同一站点拥有了运行不同框架集而不相互影响的能力
    实际运用中需要根据不同的情况来选择虚拟目录或应用程序
     
     
    考虑到我只是需要某网站的一个映射网址,两个发布文件没有任何关系,也不想公用任何config或者dll文件
    于是还是老实的“添加应用程序”来解决问题吧
    于是,我还是不甘心,去iis网站配置文件applicationHost.config(C:WindowsSystem32inetsrvconfig)中查看到部分内容
    (publish和test2.0是添加的虚拟目录,test2.0_是添加的应用程序)对应配置如下:
    <sites>
                <site name="Default Web Site" id="1">
                    <application path="/">
                        <virtualDirectory path="/" physicalPath="%SystemDrive%inetpubwwwroot" />
                    </application>
                    <bindings>
                        <binding protocol="http" bindingInformation="*:80:" />
                    </bindings>
                </site>
                <site name="test1.0" id="2" serverAutoStart="true">
                    <application path="/" applicationPool="test1.0">
                        <virtualDirectory path="/test2.0" physicalPath="F:asp.net est 2.0publish2.0" />
                        <virtualDirectory path="/publish" physicalPath="F:asp.nethtml5拖拽上传 estpublish" />
                    </application>
                    <application path="/test2.0_" applicationPool="test1.0">
                        <virtualDirectory path="/" physicalPath="F:asp.net est 2.0publish2.0" />
                    </application>
                    <bindings>
                        <binding protocol="http" bindingInformation="192.168.1.107:8080:" />
                    </bindings>
                </site>
                <siteDefaults>
                    <logFile logFormat="W3C" directory="%SystemDrive%inetpublogsLogFiles" />
                    <traceFailedRequestsLogging directory="%SystemDrive%inetpublogsFailedReqLogFiles" />
                </siteDefaults>
                <applicationDefaults applicationPool="DefaultAppPool" />
                <virtualDirectoryDefaults allowSubDirConfig="true" />
            </sites>
     很清楚的看到,site(站点),application(应用程序),virtualDirectory(虚拟目录)的层次关系,并可以说明为:
    一个site中可以有一个或者多个application,一个application中可以有一个或者多个virtual directory,而一个virtual directory则对应着一个物理路径。一个site默认会至少有一个application,称为根应用程序(root application)或者默认应用程序(default application),而一个application至少有一个vitual director,称为根虚拟目录(root virtual directory)
     
    也许在早版本的iis中,例如iis6,应用程序和虚拟目录是没有太大严格区分的,在IIS7以上,这三者则被规范化起来,在IIS架构层面上明确了三者的层次关系。具体可以参考:
    所以添加应用程序,本质上还是为其配置一个虚拟目录,根据path和 physicalPath很清楚的知道,iis是如何帮我们映射物理路径的
     
     
     
     
     
     
     
  • 相关阅读:
    第二阶段站立会议第十天
    第二阶段站立会议第九天
    第二阶段站立会议第八天
    第二阶段站立会议第七天
    第二阶段站立会议第六天
    第二阶段站立会议第五天
    第二阶段站立会议第四天
    第二冲刺阶段个人进度10
    第二冲刺阶段个人进度09
    第二冲刺阶段个人进度08
  • 原文地址:https://www.cnblogs.com/yinhaichao/p/4052500.html
Copyright © 2020-2023  润新知