【问题标题】: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 您的问题是域不匹配。因此尝试将请求标头中的来源设置为响应标头中的来源或将其设置为 *.

标签: jquery ajax asp.net-mvc internet-explorer firefox


【解决方案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调用了。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2014-12-25
    • 1970-01-01
    • 2018-09-25
    • 1970-01-01
    • 2014-04-17
    • 1970-01-01
    • 2017-02-17
    • 2013-03-29
    相关资源
    最近更新 更多