9

iPad/iPhone の Chrome で問題が発生しました。単純なタスクだと思っていたのですが、Chrome デスクトップ (Mac & PC) と iPad/iPhone の Safari で動作します。

私のページには次のjqueryがあります。

$("#login-login-button").click(function () { var username = $("#Username").val(); var password = $("#Password").val();

    $("#login-loading-icon").show();

    $.post("/login", { username: username, password: password }, function (data, response) {
        if (response == "success") {
            if (data.IsValid) {
                window.location.href = "/profile";
            }
            else {
                $("#login-error-message").html(data.ErrorMessage);
                $("#login-loading-icon").hide();
            }
        }
        else {
            alert("An error occurred, please try again.");
        }
    });
});

コントローラ アクションは次のようなコードです。

[HttpPost]
public JsonResult Index(string username, string password)
{
        AjaxResponseModel ajaxResponseModel = new AjaxResponseModel();

        User user = UserDAL.Select(username, Hash.MD5(password));

        if (user != null)
        {
            if (!user.IsVerified.Value)
            {
                ajaxResponseModel.AddErrorMessage("Account not verified.");
            }
            else if (!user.IsActive.Value)
            {
                ajaxResponseModel.AddErrorMessage("Your account is not active.");
            }
            else
            {
                FormsAuthentication.SetAuthCookie(username, false);
            }
        }
        else
        {
            ajaxResponseModel.AddErrorMessage("Login details incorrect.");
        }

        return Json(ajaxResponseModel);
    }

ajax 以外のリクエストで Auth Cookie を設定しようとしましたが、うまくいきません。

そして、iPad/iPhone で Chrome メニューの [デスクトップ サイトのリクエスト] を使用すると問題が解消されることを発見しましたが、この時点で私のサイトにはモバイル/デスクトップの概念がありません。つまり、Chrome が最初に取得するものはデスクトップ サイトにする...

4

1 に答える 1

6

ここですでに回答がありました:iPhone UIWebViewを使用する場合のAsp.Netフォーム認証

現在のブラウザの分布を考えると、より合理的なデフォルトの構成を使用しました。

<browsers>
  <browser refID="Default"> 
    <capabilities> 
      <capability name="cookies" value="true" /> 
    </capabilities>
  </browser>
</browsers>
于 2012-07-15T09:57:35.923 に答える