> 백엔드 개발 > PHP 튜토리얼 > segmentfault无登陆进入 在一个界面登陆后 其他界面提示 已经登陆 需要重新加载

segmentfault无登陆进入 在一个界面登陆后 其他界面提示 已经登陆 需要重新加载

WBOY
풀어 주다: 2016-06-06 20:34:14
원래의
1044명이 탐색했습니다.

这个怎么实现的
求技术关键词

回复内容:

这个怎么实现的
求技术关键词

http://static.segmentfault.com/build/qa/js/question.2613f2a2.js

因为文件是经过压缩过的, 所以我只说一下主要的部分:
根据不同的浏览器对于当窗口获得焦点时的事件名称不同, 绑定相应的窗口获得焦点的事件,
然后在事件触发的时候 发 ajax 检测当前的登陆状态, 如果是由 未登陆 变为 登陆状态, 则显示你所看到的那句话. 如果是登陆状态, 还是会发 ajax 检测当前的登陆状态, 并执行相应的js, 并且设置计时器setInterval 每隔60秒检测一次登陆状态.

在进入页面的时候, 后端会在页面中会输出

<code>//登陆状态时输出的内容
<meta name="userId" value="1030000000334890" id="SFUserId">

//未登陆状态时输出的内容
<meta name="userId" value="" id="SFUserId">
</code>
로그인 후 복사

相关的JS代码:

<code>    function a() {
        $.getJSON("/api/user/stat", function(e) {
            if (0 === e.status) {
                var t = $("title");
                e.data.events > 0 ? 
                    (e.data.events > 99 && (e.data.events = "99+"), 
                        $("#messageCount").siblings(".has-unread__count").remove(),
                        $("#messageCount").after('<span class="has-unread__count">' + e.data.events + "</span>"),
                        $("#m-messageCount").text(e.data.events),
                    $(".mobile-menu__unreadpoint").show(),
                    t.text(/^\(\d+[\+]?\)/.test(t.text()) ? t.text().replace(/^\(\d+[\+]?\)/, "(" + e.data.events + ")") : "(" + e.data.events + ")" + $("title").text())
                    ) : 0 === e.data.events && ($(".has-unread__count").remove(), t.text(t.text().replace(/^\(\d+[\+]?\)/, ""))), 0 !== e.data.drafts && ($("#draftCount .badge").remove(), $("#draftCount").append('<span class="badge">' + e.data.drafts + "</span>")), 0 !== e.data.invites && ($("#inviteCount .badge").remove(), $("#inviteCount").append('<span class="badge">' + e.data.invites + "</span>"))
            }
        })
    }


    var r = {_: window.SF.token,staticUrl: window.SF.staticUrl,userId: $("#SFUserId").attr("value"),userRank: $("#SFUserRank").attr("value"),getMessage: a,login: t.login || i};

    var s, l;

    "undefined" != typeof document.hidden ? (s = "hidden", l = "visibilitychange") : "undefined" != typeof document.mozHidden ? (s = "mozHidden", l = "mozvisibilitychange") : "undefined" != typeof document.msHidden ? (s = "msHidden", l = "msvisibilitychange") : "undefined" != typeof document.webkitHidden && (s = "webkitHidden", l = "webkitvisibilitychange"), $("body").prepend('<div class="alert alert-warning topframe js-alert">
<span class="content"></span><button type="button" class="close" data-dismiss="alert"><span aria-hidden="true">×</span><span class="sr-only">Close</span></button>
</div>'),

    $(document).on(l, function() {
        document[s] ? clearInterval(o) : r.userId ? (a(), o = setInterval(a, 6e4)) : $.getJSON("/api/user/stat", function(e) {
            0 == e.status && ($("body").addClass("have-notify"), $(".js-alert").find(".content").html('您已登录,请 <button class="btn btn-warning btn-xs" type="button" onclick="location.reload()">重新加载</button>').parent().show())
        })
    })
</code>
로그인 후 복사

cookie、localStorge 都可以实现啊;

判断登录的应该是统一的方法吧,登录后把一个标识写入 cookie或localStorge就可以了。

tab 页激活时检测是否已经有 session 的数据,如果没有,就发一条消息的接口请求看看是不是需要登陆的提示,没有则显示重新加载的提示。

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