AJAX 在 IE 中运行良好,但在 Firefox\Chrome 中运行良好(奇怪 :))[重复]

Posted

技术标签:

【中文标题】AJAX 在 IE 中运行良好,但在 Firefox\\Chrome 中运行良好(奇怪 :))[重复]【英文标题】:AJAX works fine in IE but not in Firefox\Chrome (Bizarre :) ) [duplicate]AJAX 在 IE 中运行良好,但在 Firefox\Chrome 中运行良好(奇怪 :))[重复] 【发布时间】:2013-09-27 20:36:21 【问题描述】:

我使用的是 IE 10、Firefox 24、Chrome 29。

我有一个在 ASP.NET MVC 4 (IIS 8) 上运行的服务器,控制器中有一个简单的功能:

[HttpPost]
public ActionResult Register(string PhoneNumber, string DisplayName)

    // Some commented code here ...
    ViewBag.Message = "Working!";
    return View();

视图如下:

@
    ViewBag.Title = "Register";

@ViewBag.Message

Ajax 调用如下所示:

$.ajax(
    type: "POST",
    url: "http://localhost:1283/home/Register",
    data: 
        phoneNumber: "123",
        displayname: "Miko"
    ,
    success: function (response) 
        alert("In success: " + response);
    ,
    error: function (result) 
        alert('In error: '+ result);
    
)

在所有浏览器中,都会进行 AJAX 调用,服务器中的 Register() 会被触发,但完成后,此代码在 Internet Explorer 中运行良好,但使用 Firefox\Chrome 时总是会出现“error()”。

如何使这些功能也适用于 Firefox 和 Chrome?

谢谢。

【问题讨论】:

你知道错误是什么吗?也尝试在 ajax 设置中给出dataType:"html"contentType:"application/json" url: "localhost:1283/home/Register" ,可能是跨站请求造成的,看看chrome中的console吧。我觉得你应该把前端和服务设置在同一个主机上。跨度> (PSL) 我不知道是什么错误。我已经在 AJAX 调用中添加了这两行,但仍然无法正常工作。 (Mithril) 在 Chrome 的控制台中我收到此消息:XMLHttpRequest cannot load localhost:1283/home/Register。 Access-Control-Allow-Origin 不允许 Origin null。 @MikoDiko 您的问题是域不匹配。因此尝试将请求标头中的来源设置为响应标头中的来源或将其设置为 *. 【参考方案1】:

首先,我认为你必须看看Access_control_CORS。

在 MVC.NET 中有一个简单的方法可以解决这个问题。 将以下代码添加到 Global.asax

    protected void Application_BeginRequest(object sender, EventArgs e)
    
        if (!string.IsNullOrWhiteSpace(Request.Headers["Origin"]))
        
            if (IsOriginInCrossDomainWhiteList(Request.Headers["Origin"]))
            
                Response.AddHeader("Access-Control-Allow-Origin", Request.Headers["Origin"]);
            
            else
            
                Response.End();
            
        
    

    internal static bool IsOriginInCrossDomainWhiteList(string origin)
    
        Uri uri;
        if (Uri.TryCreate(origin, UriKind.Absolute, out uri))
        
            foreach (var whiteDomain in Properties.Settings.Default.CrossDomainWhiteList)
            
                if (string.Compare(uri.Host, whiteDomain, true) == 0)
                
                    return true;
                
            
        
        return false;
    

并向 Web.config 添加一些域,例如:

  <applicationSettings>
     <YourProject.Properties.Settings>
      <setting name="CrossDomainWhiteList" serializeAs="Xml">
        <value>
          <ArrayOfString xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
            xmlns:xsd="http://www.w3.org/2001/XMLSchema">
            <string>www.youhost.com</string>
          </ArrayOfString>
        </value>
      </setting>
     </YourProject.Properties.Settings>
  </applicationSettings>

那么就可以在CrossDomainWhiteList中添加的域使用ajax调用了。

【讨论】:

以上是关于AJAX 在 IE 中运行良好,但在 Firefox\Chrome 中运行良好(奇怪 :))[重复]的主要内容,如果未能解决你的问题,请参考以下文章

javascript 在 mozilla 中运行良好,但在 IE6 中出现未知的运行时错误,为啥?

我的 Javascript 代码在 IE 中无法运行,但在其他浏览器中运行良好

Font Face Gotham 无法在我的 IE 8、9、10 上运行,但在我朋友的 IE 中运行良好?

无法在 Firefox 和 IE9 中获取数据,但在 Chrome 和 Safari 中运行良好

Ajax Call 无法在 android 上运行,但在 ios Cordova 上运行良好

IE中未定义的outerHTML