您的位置:

php防止重复登录,php如何防止重复提交

本文目录一览:

Thinkphp5防止某个IP多次登录的方法

//昨天写的思路不对,重新写....

/**

*检查IP是否重复登录多次

*/

public function check_ip(){

//获取ip

$login_ip=$_SERVER["REMOTE_ADDR"];

$login_time=date("Y-m-d",time());

if(Cache::get('cache_login_data')==false){

//如果ip换成为false,那么创建一个缓存,并赋值第一个

$login_data[0]=['login_ip'=$login_ip,'login_time'=$login_time];

Cache::set('cache_login_data',$login_data);

}else{

//如果有cache,那么将这条数据加入到缓存中最后一条去

$cache_login_data=Cache::get('cache_login_data');

$count=0;

foreach($cache_login_dataas$k=$v){

//如果当前缓存中的值含有当前ip和时间,那么计算当前时间内登录次数

if($v['login_time']==$login_time$v['login_ip']==$login_ip){

$count++;

if($count10){

//当前ip登录超过10次

$this-error("你登录超过了10次,请不要再来登了...","Login/index");

}else{

//当前时间内有该IP登陆过,但是没有超过10次

$cache_login_data[count($cache_login_data)+1]=['login_ip'=$login_ip,'login_time'=$login_time];

Cache::set('cache_login_data',$cache_login_data);

}

}else{

//当前时间内,该IP没有登陆过

$cache_login_data[count($cache_login_data)+1]=['login_ip'=$login_ip,'login_time'=$login_time];

Cache::set('cache_login_data',$cache_login_data);

}

}

}

}

php如何防止程序重复执行

在用户表中加四个字段,一个记录是否登录,一个记录登录随机码(每次登录不一样),一个记录最后登录时间,一个记录登录ip,登录后保存user_id及登录随机码的session,在全局的配置文件中写一个方法.每次访问一个页面都去查询用户表的登录随机码及ip,如果发现ip或随机码不一致(因为同一局域网获取的ip可能一样,所以不能单纯的判断ip,加上验证随机码),则弹出提示消息,并清空session,强迫下线.

php中如何防止重复登录?php中有没有类似struts2中application的东西?

application php 中没有

我常用的方法是这个:

1、登陆状态通过 session 来记录

2、将 session 数据记录到数据库里面

3、登陆时候,检查session 库中是否已经登陆.这个地方你自己考虑如何判定

4、退出是清掉 session 库中对应的数据