某些服务器上的HttpContext.Current.Session为null

时间:2015-01-12 22:33:33

标签: c# asp.net-mvc asp.net-membership

我希望这是一个简单的问题。我从来没有处理过这个问题,也不知道如何开始。

我开发了一个Web应用程序,我的用户可以在自己的Web服务器上安装和运行。

我实现了一项功能,允许用户更改默认pw中的pw。这几乎适用于所有服务器。但是,我有一个新客户无法使用它。

目前的方法遵循以下步骤:

  1. 用户使用默认的pw
  2. 登录
  3. 用户被带到他们必须创建新pw的视图(否则他们的帐户被暂停)
  4. 更改成功后,用户将进入主屏幕。
  5. 对于大多数公司来说,这可以按预期工作。但是,在此服务器上Membership.GetUser(System.Web.HttpContext.Current.User.Identity.Name)始终为空,因为Current为空。如果我在本地运行应用程序并连接到他们的数据库,它将按预期工作。但是,如果我在他们的服务器上运行它(它们的服务器上的相同代码连接到完全相同的数据库),则为空并且pw更改失败。

    我需要提供哪些其他信息才能帮助解决此问题?

    更新:这是我正在调用的代码: 按下按钮时调用脚本:

    var $account = {
    changePw: function (homeUrl, reset) {
        $(".ui-widget").css("display", "none");
        var newPw1 = $("#newPw1").val();
        var newPw2 = $("#newPw2").val()
        if (newPw1 != newPw2) {
            $("#pwDontMatch").css("display", "block");
        }
        else {
            var url = rootUrl + "Account/ChangePassword";
            var data = {
                oldPassword: $("#currPw").val(),
                newPassword: $("#newPw1").val(),
                reset: "false"
            };
            if (reset) {
                data = { newPassword: $("#newPw1").val(), reset: "true", userId: $("#userIdTxt").val() };
            }
    
            $.ajax({
                url: url,
                data: data,
                success: function (data) {
                    if (data.success != null && data.success == "true") {
                        $("#changeSuccess").css("display", "block");
                        setTimeout(function () { document.location.href = homeUrl; }, 3000);
                    }
                    else {
                        $("#error").css("display", "block");
                        if (data.error != null) {
                            $("#errMsg").html(data.error);
                        }
                    }
                },
                failure: function () {
                    $("#error").css("display", "block");
                },
                type: "POST"
            });
        }
    }
    };
    

    脚本调用控制器:

        /// <summary>
        /// This can be called from the change password page or the reset password page
        /// </summary>
        /// <param name="form"></param>
        /// <returns></returns>
        [HttpPost]
        public JsonResult ChangePassword(FormCollection form)
        {
            JsonResult jr;
    
            // ChangePassword will throw an exception rather
            // than return false in certain failure scenarios.
            try
            {
                bool changePasswordSucceeded;
                    MembershipUser currentUser = Membership.GetUser(System.Web.HttpContext.Current.User.Identity.Name, true /* userIsOnline */) ??
                        Membership.GetUser(System.Web.HttpContext.Current.User.Identity.Name);
                    if (currentUser != null)
                    {
                        try
                        {
                            changePasswordSucceeded = urrentUser.ChangePassword(form["oldPassword"], form["newPassword"]);
                            if (changePasswordSucceeded)
                            {
                                currentUser.IsApproved = true;
                                Membership.UpdateUser(currentUser);
    
                                if (currentUser.ProviderUserKey != null)
                                {
                                    var mxUser = new MxUser(currentUser.ProviderUserKey.ToString());
                                    Session["User"] = mxUser;
                                    jr = Json(new {success = "true"});
                                }
                                else jr = Json(new {success = "false",error = "Cannot find ProviderUserKey."});
    
                            }
                            else jr = Json(new{success = "false",error = "Cannot update the user password."});
                        }
                        catch
                        { jr = Json(new{success = "false",error = "Unexpected error in updating the user password."}); }
                    }
                    else jr = Json(new {success = "false", error = "Cannot find the user"});
            }
            catch (Exception ex)
            { jr = Json(new {success = "false", error = ex.Message}); }
            return jr;
        }
    

    如果没有,他们需要更改什么设置,配置等才能使其正常工作?

1 个答案:

答案 0 :(得分:0)

<system.webServer>     

<remove name="Session"/>     
<add name="Session" type="System.Web.SessionState.SessionStateModule" preCondition=""/>     


添加此配置并确保会话设置具有InProc或SQL或ASP.NET状态服务