thinkphp中获取参数值的方法

以获取$type这个参数为例:
一:通过传统方法:$_GET, $_POST
    $type = intval($_GET['type'])
这种方法需要自己写过滤规则,保证数据安全。

二:在Action中通过$this->_get或$this->_post,$this->param

这种方法:第一个参数是获取的参数;第二个参数为处理函数,可以为用逗号分隔的多个函数,默认为默认处理函数;第三个参数是默认值。

如:

$mod = $this->_get('mod', 'trim');
$type = $this->_get('type', 'trim', 'login');

 

Tp中的魔术处理方法:

    /**
     * 魔术方法 有不存在的操作的时候执行
     * @access public
     * @param string $method 方法名
     * @param array $args 参数
     * @return mixed
     */
    public function __call($method,$args) {
        if( 0 === strcasecmp($method,ACTION_NAME.C('ACTION_SUFFIX'))) {
            if(method_exists($this,'_empty')) {
                // 如果定义了_empty操作 则调用
                $this->_empty($method,$args);
            }elseif(file_exists_case($this->view->parseTemplate())){
                // 检查是否存在默认模版 如果有直接输出模版
                $this->display();
            }elseif(function_exists('__hack_action')) {
                // hack 方式定义扩展操作
                __hack_action();
            }else{
                _404(L('_ERROR_ACTION_').':'.ACTION_NAME);
            }
        }else{
            switch(strtolower($method)) {
                // 判断提交方式
                case 'ispost'   :
                case 'isget'    :
                case 'ishead'   :
                case 'isdelete' :
                case 'isput'    :
                    return strtolower($_SERVER['REQUEST_METHOD']) == strtolower(substr($method,2));
                // 获取变量 支持过滤和默认值 调用方式 $this->_post($key,$filter,$default);
                case '_get'     :   $input =& $_GET;break;
                case '_post'    :   $input =& $_POST;break;
                case '_put'     :   parse_str(file_get_contents('php://input'), $input);break;
                case '_param'   :  
                    switch($_SERVER['REQUEST_METHOD']) {
                        case 'POST':
                            $input  =  $_POST;
                            break;
                        case 'PUT':
                            parse_str(file_get_contents('php://input'), $input);
                            break;
                        default:
                            $input  =  $_GET;
                    }
                    if(C('VAR_URL_PARAMS') && isset($_GET[C('VAR_URL_PARAMS')])){
                        $input  =   array_merge($input,$_GET[C('VAR_URL_PARAMS')]);
                    }
                    break;
                case '_request' :   $input =& $_REQUEST;   break;
                case '_session' :   $input =& $_SESSION;   break;
                case '_cookie'  :   $input =& $_COOKIE;    break;
                case '_server'  :   $input =& $_SERVER;    break;
                case '_globals' :   $input =& $GLOBALS;    break;
                default:
                    throw_exception(__CLASS__.':'.$method.L('_METHOD_NOT_EXIST_'));
            }
            if(!isset($args[0])) { // 获取全局变量
                $data       =   $input; // 由VAR_FILTERS配置进行过滤
            }elseif(isset($input[$args[0]])) { // 取值操作
                $data       =    $input[$args[0]];
                $filters    =   isset($args[1])?$args[1]:C('DEFAULT_FILTER');   //第二个参数为处理函数,可以为用逗号分隔的多个函数,默认为默认处理函数
                if($filters) {// 2012/3/23 增加多方法过滤支持
                    $filters    =   explode(',',$filters);
                    foreach($filters as $filter){
                        if(function_exists($filter)) {
                            $data   =   is_array($data)?array_map($filter,$data):$filter($data); // 参数过滤
                        }
                    }
                }
            }else{ // 变量默认值
                $data       =     isset($args[2])?$args[2]:NULL;
            }
            Log::record('建议使用I方法替代'.$method,Log::NOTICE);
            return $data;
        }
    }

 

三、通过I方法获取

/**
 * 获取输入参数 支持过滤和默认值
 * 使用方法:
 * <code>
 * I('id',0); 获取id参数 自动判断get或者post
 * I('post.name','','htmlspecialchars'); 获取$_POST['name']
 * I('get.'); 获取$_GET
 * </code> 
 * @param string $name 变量的名称 支持指定类型
 * @param mixed $default 不存在的时候默认值
 * @param mixed $filter 参数过滤方法
 * @return mixed
 */
function I($name,$default='',$filter=null) {
    if(strpos($name,'.')) { // 指定参数来源
        list($method,$name) =   explode('.',$name,2);
    }else{ // 默认为自动判断
        $method =   'param';
    }
    switch(strtolower($method)) {
        case 'get'     :   $input =& $_GET;break;
        case 'post'    :   $input =& $_POST;break;
        case 'put'     :   parse_str(file_get_contents('php://input'), $input);break;
        case 'param'   :  
            switch($_SERVER['REQUEST_METHOD']) {
                case 'POST':
                    $input  =  $_POST;
                    break;
                case 'PUT':
                    parse_str(file_get_contents('php://input'), $input);
                    break;
                default:
                    $input  =  $_GET;
            }
            if(C('VAR_URL_PARAMS') && isset($_GET[C('VAR_URL_PARAMS')])){
                $input  =   array_merge($input,$_GET[C('VAR_URL_PARAMS')]);
            }
            break;
        case 'request' :   $input =& $_REQUEST;   break;
        case 'session' :   $input =& $_SESSION;   break;
        case 'cookie'  :   $input =& $_COOKIE;    break;
        case 'server'  :   $input =& $_SERVER;    break;
        case 'globals' :   $input =& $GLOBALS;    break;
        default:
            return NULL;
    }
    // 全局过滤
    // array_walk_recursive($input,'filter_exp');
    if(C('VAR_FILTERS')) {
        $_filters    =   explode(',',C('VAR_FILTERS'));
        foreach($_filters as $_filter){
            // 全局参数过滤
            array_walk_recursive($input,$_filter);
        }
    }
    if(empty($name)) { // 获取全部变量
        $data       =   $input; 
        $filters    =   isset($filter)?$filter:C('DEFAULT_FILTER');
        if($filters) {
            $filters    =   explode(',',$filters);
            foreach($filters as $filter){
                $data   =   array_map($filter,$data); // 参数过滤
            }
        }        
    }elseif(isset($input[$name])) { // 取值操作
        $data       =    $input[$name];
        $filters    =   isset($filter)?$filter:C('DEFAULT_FILTER');
        if($filters) {
            $filters    =   explode(',',$filters);
            foreach($filters as $filter){
                if(function_exists($filter)) {
                    $data   =   is_array($data)?array_map($filter,$data):$filter($data); // 参数过滤
                }else{
                    $data   =   filter_var($data,is_int($filter)?$filter:filter_id($filter));
                    if(false === $data) {
                        return     isset($default)?$default:NULL;
                    }
                }
            }
        }
    }else{ // 变量默认值
        $data       =     isset($default)?$default:NULL;
    }
    return $data;
}

 

<think>好的,我现在需要帮助用户解决在ThinkPHP6中判断变量是否为NULL的问题。首先,用户提到了is_null、empty这几个函数,可能对它们之间的区别不太清楚。我需要先回忆PHP中这些函数的具体行为,然后结合ThinkPHP6的框架特性来给出答案。 首先,根据用户提供的引用内容,引用[1]提到is_null()函数的使用,以及isset()和empty的区别。引用[2]说明isset()在变量被unset或设为NULL时会返回FALSE。而用户的问题是关于ThinkPHP6中的方法,可能需要参考框架的特定函数。 在PHP中,is_null()用于检查变量是否为NULL,而empty()会检查变量是否为空值,包括NULL、空字符串、0等。isset()则检查变量是否已设置且不为NULL。用户可能想知道在ThinkPHP6中是否有更推荐的方法,或者框架是否提供了自己的函数来处理变量检查。 接下来,我需要查看ThinkPHP6的文档或常见做法。引用[3]提到了ThinkPHP的一些常用变量方法,比如getFieldBy字段名,这可能暗示ThinkPHP中有自己的数据库查询方法,但对于变量检查,可能还是依赖PHP原生函数。引用[4]涉及RCE漏洞,可能与当前问题无关,但需要注意安全性。 在ThinkPHP6中,通常推荐使用框架提供的助手函数,比如request()->param()获取参数,然后进行判断。例如,使用param('变量名')获取变量后,用is_null()判断是否为NULL。另外,框架可能有自己的验证机制,比如在验证器中使用规则检查是否为NULL。 用户的问题可能还涉及到表单提交或请求参数的处理。在这种情况下,使用Request类的param方法获取变量,然后进行判断。例如: $value = request()->param('var'); if (is_null($value)) { // 处理逻辑 } 或者使用框架的助手函数,比如empty_val()是否存在,但根据现有知识,ThinkPHP6可能没有额外封装is_null,而是直接使用PHP函数。因此,正确的做法是结合PHP的原生函数和框架的方法。 此外,用户需要注意empty()和is_null()的区别。比如,当变量不存在时,is_null()会报错,而empty()不会。所以,在不确定变量是否存在的情况下,应先使用isset()检查,再判断是否为NULL。 总结步骤: 1. 使用ThinkPHP6的请求对象获取变量。 2. 根据PHP函数判断是否为NULL:is_null()。 3. 注意变量是否存在,避免报错,可能需要先isset()检查。 4. 考虑框架的验证器,在验证规则中定义nullable等规则。 然后需要生成相关问题,可能涉及ThinkPHP6的变量获取方法、验证器的使用,以及PHP函数的区别。</think>在ThinkPHP6中判断变量是否为NULL,需结合PHP原生函数和框架特性。以下是具体方法: ### 1. **使用`is_null()`函数** PHP原生函数`is_null($var)`直接判断变量是否为NULL: ```php $value = request()->param('key'); if (is_null($value)) { // 变量为NULL的逻辑 } ``` 注意:若变量未定义,直接调用`is_null()`会报错,建议先通过`isset()`检测变量是否存在[^2]。 --- ### 2. **ThinkPHP6的`Request`对象方法** 通过框架的请求对象获取参数时,未传值参数默认返回NULL: ```php // 获取参数,若未传递则返回NULL $value = request()->param('key'); if ($value === null) { // 处理NULL值 } ``` --- ### 3. **与`empty()`的区别** - `empty()`会为`NULL`、空字符串、0、未定义变量等返回`true`[^1]。 - `is_null()`仅当变量严格等于`NULL`时返回`true`。 示例对比: ```php $var = null; empty($var); // true is_null($var); // true $var = ""; empty($var); // true is_null($var); // false ``` --- ### 4. **验证器场景(表单验证)** 在ThinkPHP6的验证器中,可通过`nullable`规则允许字段为NULL: ```php $validate = Validate::rule([ 'field' => 'nullable|array' ]); ``` --- ### 总结建议 - **明确场景**:若需严格判断NULL值,使用`is_null()`;若需兼容空值,用`empty()`。 - **安全优先**:先通过`isset()`或`request()->has('key')`检测变量是否存在[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值