Como limpar a sessão sobre a log
-
19-08-2019 - |
Pergunta
eu redirecionar o usuário para a página de login quando o usuário clique log out no entanto eu não acho que ele limpa qualquer aplicação ou sessão, porque todos os dados persistiu quando o usuário fizer logon novamente.
Atualmente, a página de login tem um controle de login e o código por trás da página só é ligado até o login Authenticate.
Alguém pode me indicar um bom tutorial ou artigo sobre a manipulação de log dentro e fora de web sites ASP.NET?
Solução
Session.Abandon()
http://msdn.microsoft.com/en-us/library/ ms524310.aspx
Aqui está um pouco mais detalhadamente sobre o objeto HttpSessionState
:
http://msdn.microsoft.com/ en-us / library / system.web.sessionstate.httpsessionstate_members.aspx
Outras dicas
Eu uso a seguir para sessão clara e aspnet_sessionID
claro:
HttpContext.Current.Session.Clear();
HttpContext.Current.Session.Abandon();
HttpContext.Current.Response.Cookies.Add(new HttpCookie("ASP.NET_SessionId", ""));
Eu preferiria Session.Abandon()
Session.Clear()
não irá causar End de fogo e outras solicitações do cliente não vai aumentar o evento Sessão Iniciar.
Session.Abandon()
destrói a sessão eo evento Session_OnEnd
é acionado.
Session.Clear()
apenas remove todos os valores (conteúdo) do objeto. O session with the same key
ainda é alive
.
Então, se você usar Session.Abandon()
, você perde essa sessão específica e o usuário receberá um new session key
. Você poderia usá-lo, por exemplo, quando o usuário logs out
.
Use Session.Clear()
, se você quiser que o usuário permanecer na mesma sessão (se você não quer que ele relogin por exemplo) e redefinir todos os dados de sua específica sessão.
Vá para arquivo Global.asax.cs em seu projeto e adicione o seguinte código.
protected void Application_BeginRequest()
{
Response.Cache.SetCacheability(HttpCacheability.NoCache);
Response.Cache.SetExpires(DateTime.Now.AddHours(-1));
Response.Cache.SetNoStore();
}
Ela trabalhou para mim ..! link de referência Limpar sessão ao sair MVC 4
<script runat="server">
protected void Page_Load(object sender, System.EventArgs e) {
Session["FavoriteSoftware"] = "Adobe ColdFusion";
Label1.Text = "Session read...<br />";
Label1.Text += "Favorite Software : " + Session["FavoriteSoftware"];
Label1.Text += "<br />SessionID : " + Session.SessionID;
Label1.Text += "<br> Now clear the current session data.";
Session.Clear();
Label1.Text += "<br /><br />SessionID : " + Session.SessionID;
Label1.Text += "<br />Favorite Software[after clear]: " + Session["FavoriteSoftware"];
}
</script>
<html xmlns="http://www.w3.org/1999/xhtml">
<head id="Head1" runat="server">
<title>asp.net session Clear example: how to clear the current session data (remove all the session items)</title>
</head>
<body>
<form id="form1" runat="server">
<div>
<h2 style="color:Teal">asp.net session example: Session Clear</h2>
<asp:Label
ID="Label1"
runat="server"
Font-Size="Large"
ForeColor="DarkMagenta"
>
</asp:Label>
</div>
</form>
</body>
</html>
A maneira de limpar a sessão é um pouco diferente para .NET núcleo. Não há nenhuma função Abandon()
.
ASP.NET núcleo 1.0 ou posterior
//Removes all entries from the current session, if any. The session cookie is not removed.
HttpContext.Session.Clear()
.NET Framework 4.5 ou posterior
//Removes all keys and values from the session-state collection.
HttpContext.Current.Session.Clear();
//Cancels the current session.
HttpContext.Current.Session.Abandon();
Session.clear ();
Session.Abandon () não irá remover o cookie sessionID do browser. Portanto, quaisquer novas solicitações após isso vai levar o mesmo ID da sessão. Por isso, use Response.Cookies.Add (novo HttpCookie ( "ASP.NET_SessionId", "")); após Session.Abandon ().