登录服务器信息怎么删除,服务器端删除了用户,怎么通知客户端浏览器删除cookie...

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

回复内容:

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

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

函数:session_id

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

生成名称为:sess + 自定义的session_id

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

//代码

session_name("demo");

session_id("123");

session_start();

$_SESSION['one'] = 11;

服务端生成文件

bVrZnr

客户端生成的cookie

bVrZne

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

你这个需求有点类似“黑名单用户”?

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值