voldem_rt 2015-11-09 06:28 采纳率: 100%
浏览 1787
已采纳

Thinkphp框架下验证码问题

public function myses(){
import("ORG.Util.Date");
$Setime=session('time');
$Date=new Date;
if($Setime!=NULL){
$diff=$Date->dateDiff("$Setime","s");
if($diff>=10){//判断是否过期
$Setime=$Date->dateAdd($number = 10, $interval = "s");//设置过期时间
session('time',$Setime);//将过期时间存在session里面
session('rand',rand(11111,99999));
echo session('rand');
echo 1111;//session存在,但是时间超过3分钟,重新生成验证码
}
else{
echo $diff;echo "
";
echo session('time'); echo "
";
echo session('rand'); echo "
";

echo 2222;//3分钟内再次获取输出该标示
}
}
else {
$Setime=$Date->dateAdd($number = 10, $interval = "s");//设置过期时间
session('time',$Setime);//将过期时间存在session里面
session('rand',rand(11111,99999));
echo session('rand'); echo "
";
echo session('time'); echo "
";
echo 3333;//session值没有被设置,生成新的验证码
}
}


逻辑应该没有错误,不知道是哪个用法不对,由于对session不熟悉,想这样通过在session中存一个过期时间,如果过期则重新生成。1、帮忙把以上代码改通,2、有更好实现该功能的方法也可以

  • 写回答

4条回答 默认 最新

  • voldem_rt 2015-11-10 05:12
    关注

    终于找到问题了
    1、对session理解不够,
    2、上面代码中的问题是:
    条件if($Setime!=NULL),其中$Settime是通过dateAdd得来的,是一个**Date对象**

    所有if不会判空,但是作为$diff=$Date->dateDiff("$Setime","s"); dateDiff返回的是**字符串**
    在代码中应该 session('time',$Setime->format());//将过期时间存在session里面

    完整修改后的代码应该是:
    function myses(){
    import("ORG.Util.Date");
    $Setime=session('time');
    $Date=new Date;
    if($Setime!=NULL){
    $diff=$Date->dateDiff("$Setime","s");
    if($diff<=0){//判断是否过期
    $Setime=$Date->dateAdd($number = 60, $interval = "s");//设置过期时间
    session('time',$Setime->format());//将过期时间存在session里面
    session('rand',rand(11111,99999));
    return session('rand');//session存在,但是时间超过1分钟,重新生成验证码
    }
    else{
    return session('rand');//1分钟内再次获取输
    }
    }
    else {
    $Setime=$Date->dateAdd($number = 60, $interval = "s");//设置过期时间
    session('time',$Setime->format());//将过期时间存在session里面
    session('rand',rand(11111,99999));
    return session('rand');//session值没有被设置,生成新的验证码
    }
    }

    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
  • z376347932 2015-11-09 06:38
    关注

    阿罗一群破坏某嘻嘻全心全意

    评论
  • 暖枫无敌 博客专家认证 2015-11-09 06:43
    关注

    PHP Session过期时间设定

    PHP中主要通过设置session.gc_maxlifetime来设定Session的生存周期。例如:
    <?php
    ini_set('session.gc_maxlifetime', 3600); //设置时间
    ini_get('session.gc_maxlifetime');//得到ini中设定值
    ?>

    封装好的函数,供参考:
    <?php
    function start_session($expire = 0)
    {
    if ($expire == 0) {
    $expire = ini_get('session.gc_maxlifetime');
    } else {
    ini_set('session.gc_maxlifetime', $expire);
    }

    if (empty($_COOKIE['PHPSESSID'])) {
        session_set_cookie_params($expire);
        session_start();
    } else {
        session_start();
        setcookie('PHPSESSID', session_id(), time() + $expire);
    }
    

    }
    ?>

    使用方法:
    加入start_session(600);//600秒以后过期。

    评论
  • 暖枫无敌 博客专家认证 2015-11-09 06:44
    关注

    PHP Session过期时间设定

    PHP中主要通过设置session.gc_maxlifetime来设定Session的生存周期。例如:
    <?php
    ini_set('session.gc_maxlifetime', 3600); //设置时间
    ini_get('session.gc_maxlifetime');//得到ini中设定值
    ?>

    封装好的函数,供参考:
    <?php
    function start_session($expire = 0)
    {
    if ($expire == 0) {
    $expire = ini_get('session.gc_maxlifetime');
    } else {
    ini_set('session.gc_maxlifetime', $expire);
    }

    if (empty($_COOKIE['PHPSESSID'])) {
        session_set_cookie_params($expire);
        session_start();
    } else {
        session_start();
        setcookie('PHPSESSID', session_id(), time() + $expire);
    }
    

    }
    ?>

    使用方法:
    加入start_session(600);//600秒以后过期。

    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥15 docker无法进入容器内部
  • ¥15 qt https 依赖openssl 静态库
  • ¥15 python flask 报错
  • ¥15 改个密码引发的项目启动问题
  • ¥100 CentOS7单线多拨
  • ¥15 debian安装过程中老是出现无法将g21dr复制到g21dr怎么解决呀?
  • ¥15 如何用python实现跨工作簿的指定区域批量复制粘贴
  • ¥15 基于CH573f的雷迪安CR1400m通讯代码
  • ¥15 matlab m文件如何与matla app designer 数据交互?
  • ¥15 根据控制框图,传递函数求解