12

在我们的ASP.Net 4.0项目中,我们注意到IE 11仅在(onWindows 7 SP1Windows 8.1)中,有些JavaScript没有被ASP.Net.

例如在IE 10和下面,我们看到这个:

<select name="ctl00$ctl00$cpHeading$cpHeading$ucWebStoreHeader$lshSubjectHeader$ddlVersionList" onchange="javascript:setTimeout(&#39;__doPostBack(\&#39;ctl00$ctl00$cpHeading$cpHeading$ucWebStoreHeader$lshSubjectHeader$ddlVersionList\&#39;,\&#39;\&#39;)&#39;, 0)" id="ctl00_ctl00_cpHeading_cpHeading_ucWebStoreHeader_lshSubjectHeader_ddlVersionList">

IE 11

<select name="ctl00$ctl00$cpHeading$cpHeading$ucWebStoreHeader$lshSubjectHeader$ddlVersionList" id="ctl00_ctl00_cpHeading_cpHeading_ucWebStoreHeader_lshSubjectHeader_ddlVersionList">

我们使用以下方法设置此脚本:

Page.ClientScript.RegisterClientScriptBlock(GetType(), null, script, true);

这可能是因为.Net 4.0没有更新浏览器定义文件来识别IE 11其非“MSIE”用户代理字符串吗?

我接受了这个假设,并尝试了Scott Hanselman 的建议,即在托管 Web 应用程序的计算机上同时在 Win 7 SP1 和 Win Server 2008 R2 上安装 KB2836939,但我没有注意到C 中任何 .browser 文件的更新: \Windows\Microsoft.NET\Framework64\v4.0.30319\Config\BrowsersC:\Windows\Microsoft.NET\Framework\v4.0.30319\Config\Browsers

因此,我最终创建了自己的 .browser 文件,将其放在上面的文件夹中,而 AppBrowsers 没有运气(运行aspnet_regbrowsers –i and iisreset)。这是我放在文件夹中的IE11.browser文件的内容:

<browsers>
<browser id="IE11" parentID="Mozilla">
<identification>
    <userAgent match="Trident/(?'layoutVersion'[7-9]|0*[1-9]\d+)(\.\d+)?;(.*;)?\s*rv:(?'version'(?'major'\d+)(\.(?'minor'\d+)))" />
    <userAgent nonMatch="IEMobile" />
    <userAgent nonMatch="MSIE" />
</identification>    
<capabilities>
    <capability name="browser"              value="IE" />
    <capability name="layoutEngine"         value="Trident" />
    <capability name="layoutEngineVersion"  value="${layoutVersion}" />
    <capability name="extra"                value="${extra}" />
    <capability name="isColor"              value="true" />
    <capability name="majorversion"         value="${major}" />
    <capability name="minorversion"         value="${minor}" />
    <capability name="screenBitDepth"       value="8" />
    <capability name="type"                 value="IE${major}" />
    <capability name="version"              value="${version}" />
    <capability name="ecmascriptversion"    value="3.0" />
    <capability name="jscriptversion"                       value="6.0" />
    <capability name="javascript"           value="true" />
    <capability name="javascriptversion"    value="1.5" />
    <capability name="msdomversion"         value="${majorversion}.${minorversion}" />
    <capability name="w3cdomversion"        value="1.0" />
    <capability name="ExchangeOmaSupported" value="true" />
    <capability name="activexcontrols"      value="true" />
    <capability name="backgroundsounds"     value="true" />
    <capability name="cookies"              value="true" />
    <capability name="frames"               value="true" />
    <capability name="javaapplets"          value="true" />
    <capability name="supportsCallback"     value="true" />
    <capability name="supportsFileUpload"   value="true" />
    <capability name="supportsMultilineTextBoxDisplay" value="true" />
    <capability name="supportsMaintainScrollPositionOnPostback" value="true" />
    <capability name="supportsVCard"        value="true" />
    <capability name="supportsXmlHttp"      value="true" />
    <capability name="tables"               value="true" />
    <capability name="supportsAccessKeyAttribute"    value="true" />
    <capability name="tagwriter"            value="System.Web.UI.HtmlTextWriter" />
    <capability name="vbscript"             value="true" />
</capabilities>
</browser>
</browsers>

我是否在正确的轨道上认为缺少 JavaScript 是因为 .Net 4.0 无法识别 IE 11?如果是,为什么我的 .browser 没有生效?

非常感谢每个人的时间和帮助。

4

3 回答 3

12

在 Web 服务器上安装 .Net 4.5 解决了该问题(无需使用 4.5 的 Web 应用程序)。这就是为什么我相信 4.5 能成功的原因。

与所有以前的 IE 版本不同,IE 11 有一个不包含“MSIE”的用户代理 (UA) 字符串。IE 11 有 UA 字符串:

Mozilla/5.0 (Windows NT 6.3; WOW64; Trident/7.0; rv:11.0) like Gecko

IE 10(及以下)具有 UA 字符串,例如:

Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.1; WOW64; Trident/6.0)

用于识别各种版本 IE 的浏览器定义(即 c:\Windows\Microsoft.NET\Framework64\v4.0.30319\Config\Browsers 下的浏览器)专门针对 UA 字符串中的“MSIE”,添加了基于 JavaScript 的功能在 IE 版本上匹配。在 IE 11 中,在 ie.browser 中找不到匹配项,而是在 generic.browser() 中找到匹配项。在 .Net 4.0 中,generic.browser 禁用了 JavaScript,而在 4.5 中,它被启用,解决了我们的问题。

我不知道为什么手动编辑任何 .browser 文件然后运行aspnet_regbrowsers –i and iisreset不会完成相同的操作。

于 2013-09-30T17:55:31.380 回答
3

@Adhooo 说 .Net 4.5 对 Windows 2003 Server 不可用是正确的,因此如果您正在运行 Windows 2003 Server 来托管您的网站,那么更改为 2008 Server 并不是一朝一夕的选择。

老实说,对我们来说,在我们的 2008 服务器上升级到 .Net 4.5 并不是一朝一夕的选择,事实上也不是我们可以在接下来的几个月里做的事情,因为在能够使用之前需要完成各种测试4.5 在我们的生产服务器上。

但是我们仍然需要为我们网站的访问者解决这个问题。

以下是我们发现我们需要采取的措施来解决这个问题并为我们争取一些时间,然后我们才能按照微软关于推出 4.5 的建议最终解决这个问题:

  1. 浏览器文件 - 我们也修改了浏览器文件以指示 .Net 框架如何响应 IE11 的使用。
  2. Microsoft 补丁 - 然后我们安装了补丁 ( http://support.microsoft.com/kb/2836939/en-us ) 并重新启动。
  3. 注册新的浏览器修改 - 从命令行,运行以下行:

    c:\windows\Microsoft.NET\Framework\v4.0.30319\aspnet_regbrowsers.exe -i

  4. 重置 IIS - 这需要确保 IIS 然后拾取对文件的更改:

    iis重置

然后,我们的网站可以在 IE11 中使用,并且经过急需的 QA 测试,我们就可以让我们的访问者在生产环境中使用该网站。

但请注意,如果您使用该过程并需要将浏览器文件重新应用到服务器,那么您必须使用“aspnet_regbrowsers.exe –u”卸载标志来取消注册文件,然后再重新-应用它们。此外,在我们的案例中,我们还需要重新应用 MS 补丁,因为在我们这样做之前没有任何东西可以再次正常工作。

是的,有点乱——但这应该被视为一个填充过程。

希望这可以帮助。

于 2013-12-02T12:40:30.977 回答
2

.NET Framework 4.5.1 更新添加了新的浏览器定义文件:http ://www.microsoft.com/en-us/download/details.aspx?id=40773

于 2013-11-21T16:35:48.247 回答