万能的用户名

1、万能的用户名: a' or '1     密码: a' or '1
    2、原理:
        在将用户名和密码的表单值传入where条件中时,sql语句为: SELECT * FROM adminuser WHERE username='a' or '1' AND password= 'a' or '1'; 这样的话 这个WHERE条件恒成立 一直为true 就能直接登录进去。
    3、解决方案:
        为了防止出现这种情况,需要对这个用户名密码进行预处理。
        在处理页面中,加上一个名为params的数组的参数,WHERE条件中的参数用占位符代替,params数组 各个下标为占位符名称,值则为表单传入的值。

        $re = $adminuser->findAll(array('where'=>"username=:u AND password=:p",'params'=>array(":u"=>$username,":p"=>$password)));
        ...

        在Model基类中的findAll方法里,不再直接执行sql语句。而是用pdo类的准备语句
        $params = isset($arr['params'])?$arr['params']:array();
                $pdoS=$this->pdo->prepare($sql);
                if(is_object($pdoS)){
                    $i=1;                    //这里设置$i的原因 是为了构建不同的变量,
                    if($params){
                        foreach($params as $k => $v){
                            $name = 'p_'.$i;    //由构建出来的这个$name来作为参数名,保存遍历出来的每一个$v的值
                            $i++;
                            $$name=$v;            //如果不采取这种办法 而直接绑定$v的值的话,会导致每个$k都被绑定上
                            $pdoS->bindParam($k,$$name);    //最后一个$v的值,这样在验证的时候基本不可能通过
                        }
                    }
                    $re = $pdoS->execute();
                    ...
        除了以上代码外,还有一种更简便的办法:
            $re = $pdoS->execute($params);
            ...
        直接将$params传入execute方法里,节省了绑定参数的过程。

4、动态变量
        在以上的内容中,用到了一个概念:动态变量。
            $a='abc';
            $$a =  '123';
            echo $abc;
        按理来说,我并没有声明$abc变量,但是在$$a中,$a被解析成了abc ,然后就得到了$abc这个变量。
        这种用一个变量值去声明另一个变量,这样得到的变量被称为动态变量。基于动态变量,我可以在foreach中,得到不同的变量名来存储每一个$v的值。

转载于:https://my.oschina.net/u/2965359/blog/760282

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Navicat是一款功能强大的数据库管理工具,支持多种数据库类型,其中包括Oracle数据库。OCI(Oracle Call Interface)是Oracle提供的一个通信接口,用于与Oracle数据库进行通信和交互。 Navicat万能OCI文件是指Navicat提供的OCI插件或组件,通过导入和使用OCI文件可以实现对Oracle数据库的连接和操作。OCI文件包含了连接Oracle数据库所需要的信息和参数,比如数据库地址、用户名、密码等。 使用Navicat万能OCI文件可以帮助用户快速建立与Oracle数据库的连接,简化了配置过程。只需将OCI文件导入到Navicat中,并填写相应的数据库信息,就可以轻松地连接到Oracle数据库。之后,用户可以通过Navicat提供的图形化界面进行数据库的管理和操作,例如创建表、执行SQL语句、导入导出数据等。 Navicat万能OCI文件的优势在于它的易用性和灵活性。用户不需要熟悉或了解Oracle的底层通信协议,只需使用Navicat提供的界面和工具即可完成各种数据库操作。此外,OCI文件还可以保存和分享,方便用户在不同的电脑和环境之间进行数据库连接的切换和配置的复用。 总之,Navicat万能OCI文件为用户提供了便捷的连接和管理Oracle数据库的方式,帮助用户节省时间和精力,提高工作效率。无论是数据库管理员还是开发人员,都可以通过使用Navicat万能OCI文件来简化数据库操作,提升工作效果。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值