> 백엔드 개발 > C++ > AJAX 호출은 어떻게 ASP.NET 세션을 활성 상태로 유지할 수 있습니까?

AJAX 호출은 어떻게 ASP.NET 세션을 활성 상태로 유지할 수 있습니까?

Linda Hamilton
풀어 주다: 2025-01-13 07:56:46
원래의
199명이 탐색했습니다.

How Can AJAX Calls Keep ASP.NET Sessions Alive?

AJAX로 ASP.NET 세션 연장

원활한 사용자 경험을 위해서는 활성 ASP.NET 세션을 유지하는 것이 중요합니다. 강력한 방법은 AJAX 호출을 활용하여 세션을 주기적으로 새로 고치고 시간 초과를 방지합니다.

AJAX 세션 하트비트 구현

이 접근 방식은 전용 HTTP 핸들러인 "SessionHeartbeat.ashx"에 대해 반복되는(예: 5분마다) jQuery AJAX 호출을 사용합니다. 이 처리기의 유일한 목적은 세션 유지 관리입니다. 이 핸들러의 C# 코드는 다음과 같습니다.

<code class="language-csharp">public class SessionHeartbeatHttpHandler : IHttpHandler, IRequiresSessionState
{
    public bool IsReusable { get { return false; } }

    public void ProcessRequest(HttpContext context)
    {
        context.Session["Heartbeat"] = DateTime.Now;
    }
}</code>
로그인 후 복사

해당 클라이언트측 JavaScript 함수는 다음과 같습니다.

<code class="language-javascript">function setHeartbeat() {
    setTimeout("heartbeat()", 5*60*1000); // Every 5 minutes
}

function heartbeat() {
    $.get(
        "/SessionHeartbeat.ashx",
        null,
        function(data) {
            setHeartbeat();
        },
        "json"
    );
}</code>
로그인 후 복사

사용자 인터페이스 강화

시각적 피드백(및 지속적인 세션 유지 관리)을 위해 CSS와 HTML을 추가할 수 있습니다.

<code class="language-javascript">function beatHeart(times) {
    var interval = setInterval(function () {
        $(".heartbeat").fadeIn(500, function () {
            $(".heartbeat").fadeOut(500);
        });
    }, 1000); // Beat every second

    // Clear interval after 'times' iterations (with 100ms buffer)
    setTimeout(function () { clearInterval(interval); }, (1000 * times) + 100);
}

/* HEARBEAT CSS */
.heartbeat {
    position: absolute;
    display: none;
    margin: 5px;
    color: red;
    right: 0;
    top: 0;
}</code>
로그인 후 복사

AJAX 세션 하트비트의 장점

  • 신중한 운영: 세션 유지 관리는 사용자에게 투명합니다.
  • 세션 지속성: 브라우저 창이 열려 있는 동안 세션은 활성 상태로 유지됩니다.
  • 유연한 주파수: 하트비트 간격을 쉽게 조정할 수 있습니다.
  • 향상된 사용자 경험: 중단 없는 사용자 세션을 보장합니다.

위 내용은 AJAX 호출은 어떻게 ASP.NET 세션을 활성 상태로 유지할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿