php 通过基类和构造函数统一验证程序访问权限

背景:写了一个任务的处理逻辑代码,准备用crontab的http访问形式触发。但是考虑到这个任务的不对外性,需要对访问进行验证。因为任务里的方法很多,只验证被访问的方法的话,其他的方法还是存在被访问的可能性。想到了构造函数的优先级问题,于是在构造函数里写了参数验证。实验后,发现是可行的。
有了上面的实验结论后,考虑到php做接口的概念。推演下的话,让所有接口处理类继承一个基类,在基类的构造函数里写上参数的验证。验证不通过的话,通过die()或者exit()函数终止访问流程;验证通过可以记录被访问的接口次数,调用人员信息等。没做过接口的秘钥验证,不知道是不是这个样子的,但是感觉按照这个思路写的话,可以达到接口访问权限的控制。以下是具体的代码

/**
 * 
 * 定时任务管理控制器
 * @author cdy102688
 *
 */
class TaskController extends Controller {
    
    /**
     * 
     * 任务控制器初始化验证
     */
    //public function _initialize () {
    public function __construct(){
        if ($_REQUEST['username'] == "admin" && $_REQUEST['pwd'] == "123456" ){
            echo "参数正确任务可以运行!";
        }else{
            die("需要正确的参数才可以运行任务");
        }
    }
    
    public function deal(){
        //写方法内容
    }
}
补充:代码里用到的_initialize()方法是基于thinkphp框架里的(效果是一样的,只是构造函数的话更普遍些)。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值