Prolonged user sessions are vital for a seamless online experience, especially when users leave browser windows open for extended periods. However, traditional methods like extending session timeouts often compromise security and performance.
This article presents a subtle solution: using timed AJAX calls to silently maintain active sessions. This involves periodically sending requests to a dedicated handler, refreshing the session without disrupting the user's workflow.
A jQuery function initiates an AJAX call to a SessionHeartbeat.ashx
handler at regular intervals (e.g., every 5 minutes):
<code class="language-javascript">function setHeartbeat() { setTimeout("heartbeat()", 5*60*1000); // Every 5 minutes } function heartbeat() { $.get( "/SessionHeartbeat.ashx", null, function(data) { // Session heartbeat logic (optional visual cue) setHeartbeat(); }, "json" ); }</code>
The SessionHeartbeatHttpHandler
(below) utilizes IRequiresSessionState
to access the session and simply updates a "Heartbeat" session variable:
<code class="language-csharp">public class SessionHeartbeatHttpHandler : IHttpHandler, IRequiresSessionState { public void ProcessRequest(HttpContext context) { context.Session["Heartbeat"] = DateTime.Now; } }</code>
Register the handler in web.config
:
<code class="language-xml"><httphandlers> <add path="SessionHeartbeat.ashx" type="SessionHeartbeatHttpHandler" validate="false" verb="GET,HEAD" /> </httphandlers></code>
For improved user experience, add a subtle visual heartbeat animation using CSS and HTML:
<code class="language-html"><div class="heartbeat">♥</div></code>
<code class="language-css">.heartbeat { position: absolute; display: none; margin: 5px; color: red; right: 0; top: 0; }</code>
The beatHeart
function (below) controls the animation's fade-in/fade-out behavior:
<code class="language-javascript">// Animate the heartbeat 'times' times function beatHeart(times) { var interval = setInterval(function () { $(".heartbeat").fadeIn(500, function () { $(".heartbeat").fadeOut(500); }); }, 1000); // Beat every second // Clear interval after 'times' beats (with 100ms buffer) setTimeout(function () { clearInterval(interval); }, (1000 * times) + 100); }</code>
This approach offers a smooth, non-intrusive way to maintain ASP.NET sessions, ensuring a positive user experience even with extended periods of inactivity.
The above is the detailed content of How Can I Keep ASP.NET Sessions Alive Without Affecting User Experience?. For more information, please follow other related articles on the PHP Chinese website!