早上好。我们目前在asp.net 4.5.1上有一个MVC 5应用程序,我们的目标是在移动浏览器上使用。
我们正在使用一些ajax调用来填充View上的一些下拉菜单,但是由于这些API调用正在使用登录用户,因此服务器拒绝来自safari的调用。 这在iphone safari上很明显,但在iphone chrome上却没有。 控制器端看起来像这样
[HttpGet]
[Route("API/Account/Dependents/{idPlusType}")]
public IHttpActionResult GetUserOrDependantInfo(string idPlusType)
{
...
string loggedOnUser = User.Identity.Name;
}
这部分是作为string.empty回来的。
我的客户端是.get
的简单ajax$.ajax({
url: path,
dataType: "json",
type: "GET",
contentType: 'application/json; charset=utf-8',
success: function (d) {
-- Rest
}
}
现在提琴手表现出非常相似的要求。铬合金中的一个正确维修。来自safari的那个不是。
Fiddler要求从iphone进行野生动物园
Cookie:.ASPXAUTH=0530DF01D09167C311032C3A6A258D24C20A9189FC8ACE76239016815047D4FEB5FCDDAED04E7FBCA41763388B1C655987732203CFD77D4B76C1EC3200ACCC26F61151BA77F4B6C3745C20D1D70369677814BB2A;__RequestVerificationToken_L2V6VmVyaWZ5MTIzTUhB0=Vb_TYkr-Begl4fv4JulkokhM24VFZjXjt_gHdsmz3ckfkKbBJu8YmNJcghafJ8_0Edn0Lb9SopXA7Di4fKZm6uV1AOM1;__RequestVerificationToken_L2V6VmVyaWZ5MTIzTUhBVGVzdA2=_sxROjMA7jW8PbluEKtzEOAbdJfpBDpYRWJLhwR6SDlX10UA7m7FU-6xezerP73HyqeLqrmqdYfwQfLftIhwqr5Fs0w1; ASP.NET_SessionId=dbh0kje3unlap545zeuvld31
现在Chrome来自同一部iPhone。
Cookie:ASP.NET_SessionId=qgbcybtzvw2sxaa3w1yphu1z;__RequestVerificationToken_L2V6VmVyaWZ5MTIzTUhBVGVzdA2=v7ZBYrFtmg1GuuETKlIubWKr7T4Rddt1I40f9i56LzmQDI1svaw6qpk4hpuZqm_12ltrEkak9GewyhXU1rX0gQCiMvg1;__RequestVerificationToken_L2V6VmVyaWZ5MTIzTUhB0=NkM3pLoBJeYd2MTMKXwrh7dFY7uQYLGbzVN9nPy-ai7oNdmPXoxbI8Z6Xc0SGkVS3IxY-gmTTzD6m_eu2tKNjOA46jU1;.ASPXAUTH=2CBEC21CF8A3EDD3A4C6870FF4D68F16536C4CA9D87634CA4EB817589140EC85B8967C8A2F4ACAD8CF52FAAD5E4488F2210C6B75CCF55412CFA6F6ADD66323DB5072CD3622092865B214AE3626EE7A4F6BD8494B
答案 0 :(得分:0)
我们最终从.ajax切换到.getJson函数,这有助于解决这个问题。 我们不确定原因,但之后服务器端开始看到用户进行了身份验证。