> 백엔드 개발 > PHP 튜토리얼 > 服务器端删除了用户,怎么通知客户端浏览器删除cookie

服务器端删除了用户,怎么通知客户端浏览器删除cookie

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

假设一个论坛是通过cookie来记录用户是否登陆网站的,一个用户在论坛上不停狂发广告,现在我在服务器端删除了该用户,怎么通知到客户端删除登陆信息cookie?如果用户每次操作都要查询一次数据库该用户是否存在,那样效率实在太低了,有没有更好的方法?

回复内容:

假设一个论坛是通过cookie来记录用户是否登陆网站的,一个用户在论坛上不停狂发广告,现在我在服务器端删除了该用户,怎么通知到客户端删除登陆信息cookie?如果用户每次操作都要查询一次数据库该用户是否存在,那样效率实在太低了,有没有更好的方法?

1.自定义session id的生成方式。比如md5用户的uid。

<code>函数:session_id</code>
로그인 후 복사

2.建议把session放到redis中,默认是在临时目录下,在操作删除用户时,到redis或临时目录下,把存放用户信息的session删除

<code>生成名称为:sess + 自定义的session_id</code>
로그인 후 복사

3.客户端cookie带session_id来服务端查询时,便找不到信息,默认就是退出

<code>//代码
session_name("demo");
session_id("123");

session_start();
$_SESSION['one'] = 11;</code>
로그인 후 복사

服务端生成文件
服务器端删除了用户,怎么通知客户端浏览器删除cookie

客户端生成的cookie
服务器端删除了用户,怎么通知客户端浏览器删除cookie

将token缓存到redis里面就可以避免查数据库了

你这个需求有点类似“黑名单用户”?
可以试试这样:删除用户时记录该账号到文件里做一个缓存文件,每次登录时检查该账号是否为“黑名单用户”。这样不用每次查询数据库。

查询一次,没有查询到用户就直接清除Cookie

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