输入变量

可以通过Request对象完成全局输入变量的检测、获取和安全过滤,支持包括$_GET、$_POST、$_REQUEST、$_SERVER、$_SESSION、$_COOKIE、$_ENV等系统变量,以及文件上传信息。

检测是否存在has

Request::instance()->has('id','get');

input('?get.id');

变量获取

方法 描述

param 获取当前请求的变量

get 获取 $_GET 变量

post 获取 $_POST 变量

put 获取 PUT 变量

delete 获取 DELETE 变量

session 获取 $_SESSION 变量

cookie 获取 $_COOKIE 变量

request 获取 $_REQUEST 变量

server 获取 $_SERVER 变量

env 获取 $_ENV 变量

route 获取 路由(包括PATHINFO) 变量

file 获取 $_FILES 变量

// 获取当前请求的name变量

Request::instance()->param('name');

// 获取当前请求的所有变量(经过过滤)

Request::instance()->param();

// 获取当前请求的所有变量(原始数据)

Request::instance()->param(false);

// 获取当前请求的所有变量(包含上传文件)

Request::instance()->param(true);

input('param.name');

input('param.');

或者

input('name');

input('');

Request::instance()->get('id'); // 获取某个get变量

Request::instance()->get('name'); // 获取get变量

Request::instance()->get(); // 获取所有的get变量(经过过滤的数组)

Request::instance()->get(false); // 获取所有的get变量(原始数组)

Request::instance()->post('name'); // 获取某个post变量

Request::instance()->post(); // 获取经过过滤的全部post变量

Request::instance()->post(false); // 获取全部的post原始变量

Request::instance()->request('id'); // 获取某个request变量

Request::instance()->request(); // 获取全部的request变量(经过过滤)

Request::instance()->request(false); // 获取全部的request原始变量数据

Request::instance()->server('PHP_SELF'); // 获取某个server变量

Request::instance()->server(); // 获取全部的server变量

Request::instance()->session('user_id'); // 获取某个session变量

Request::instance()->session(); // 获取全部的session变量

Request::instance()->cookie('user_id'); // 获取某个cookie变量

Request::instance()->cookie(); // 获取全部的cookie变量

变量过滤

默认没有过滤

// 默认全局过滤方法 用逗号分隔多个

'default_filter' => 'htmlspecialchars',

也支持使用Request对象进行全局变量的获取过滤,过滤方式包括函数、方法过滤,以及PHP内置的Types of filters,我们可以设置全局变量过滤方法,例如:

Request::instance()->filter('htmlspecialchars');

支持设置多个过滤方法,例如:

Request::instance()->filter(['strip_tags','htmlspecialchars']),

也可以在获取变量的时候添加过滤方法,例如:

Request::instance()->get('name','','htmlspecialchars'); // 获取get变量 并用htmlspecialchars函数过滤

Request::instance()->param('username','','strip_tags'); // 获取param变量 并用strip_tags函数过滤

Request::instance()->post('name','','org\Filter::safeHtml'); // 获取post变量 并用org\Filter类的safeHtml方法过滤

可以支持传入多个过滤规则,例如:

Request::instance()->param('username','','strip_tags,strtolower'); // 获取param变量 并依次调用strip_tags、strtolower函数过滤

Request对象还支持PHP内置提供的Filter ID过滤,例如:

Request::instance()->post('email','',FILTER_VALIDATE_EMAIL);

框架对FilterID做了转换支持,因此也可以使用字符串的方式,例如:

Request::instance()->post('email','','email');

采用字符串方式定义FilterID的时候,系统会自动进行一次filter_id调用转换成Filter常量。

具体的字符串根据filter_list函数的返回值来定义。

需要注意的是,采用Filter ID 进行过滤的话,如果不符合过滤要求的话 会返回false,因此你需要配合默认值来确保最终的值符合你的规范。

例如,

Request::instance()->post('email','',FILTER_VALIDATE_EMAIL);

就表示,如果不是规范的email地址的话 返回空字符串。

如果当前不需要进行任何过滤的话,可以使用(V5.0.3+版本)

// 获取get变量 并且不进行任何过滤 即使设置了全局过滤

Request::instance()->get('name','',null);

获取部分变量

// 只获取当前请求的id和name变量

Request::instance()->only('id,name');

或者使用数组方式

// 只获取当前请求的id和name变量

Request::instance()->only(['id','name']);

默认获取的是当前请求参数,如果需要获取其它类型的参数,可以使用第二个参数,例如:

// 只获取GET请求的id和name变量

Request::instance()->only(['id','name'],'get');

// 只获取POST请求的id和name变量

Request::instance()->only(['id','name'],'post');

排除部分变量

也支持排除某些变量获取,例如

// 排除id和name变量

Request::instance()->except('id,name');

或者使用数组方式

// 排除id和name变量

Request::instance()->except(['id','name']);

同样支持指定变量类型获取:

// 排除GET请求的id和name变量

Request::instance()->except(['id','name'],'get');

// 排除POST请求的id和name变量

Request::instance()->except(['id','name'],'post');

变量修饰符

input函数支持对变量使用修饰符功能,可以更好的过滤变量。

用法如下:

input('变量类型.变量名/修饰符');

或者

Request::instance()->变量类型('变量名/修饰符');

例如:

input('get.id/d');

input('post.name/s');

input('post.ids/a');

Request::instance()->get('id/d');

ThinkPHP5.0版本默认的变量修饰符是/s,如果需要传入字符串之外的变量可以使用下面的修饰符,包括:

修饰符 作用

s 强制转换为字符串类型

d 强制转换为整型类型

b 强制转换为布尔类型

a 强制转换为数组类型

f 强制转换为浮点类型

如果你要获取的数据为数组,请一定注意要加上 /a 修饰符才能正确获取到。

更改变量

// 更改GET变量

Request::instance()->get(['id'=>10]);

// 更改POST变量

Request::instance()->post(['name'=>'thinkphp']);

尽量避免直接修改$_GET 或者 $_POST数据,同时也不能直接修改param变量,例如下面的操作是无效的:

// 更改请求变量

Request::instance()->param(['id'=>10]);

php thinkphp修改,thinkphp5.0 | 输入变量更改变量相关推荐

  1. 修改thinkphp配置nginx服务器,thinkphp5.0配置nginx重写规则

    thinkphp5.0配置nginx重写规则 2018年07月06日 09:29:03阅读数:1529 server { listen 80; #端口号 server_name demo.aa.com ...

  2. php104.tmp,ThinkPHP5.0多个文件上传后找不到临时文件的修改方法

    这是修改之前的代码 if(!empty($_FILES)){ if(!empty($_FILES[org_positive])){ $org_positive = request()->file ...

  3. Thinkphp5.0快速入门笔记(3)

    学习来源与说明 https://www.kancloud.cn/thinkphp/thinkphp5_quickstart 测试与部署均在windows10下进行学习. 快速入门第三节 获取当前的请求 ...

  4. ThinkPHP5.0教程学习06:TP5 数据库与模型操作

    学习教程来源于: php中文网 ThinkPHP5 视频教程 ThinkPHP5.0完全开发手册 连接器与查询构造器 TP5采用的是惰性连接,故而仅在查询时才会连接到数据库 TP5的数据库操作对底层进 ...

  5. php 追查框架生命周期,thinkPHP5.0框架应用请求生命周期分析

    本文实例讲述了thinkPHP5.0框架应用请求生命周期.分享给大家供大家参考,具体如下: 本篇内容我们对ThinkPHP5.0的应用请求的生命周期做大致的介绍,以便于开发者了解整个执行流程. 1.入 ...

  6. thinkphp5.0.24反序列化漏洞分析

    thinkphp5.0.24反序列化漏洞分析 文章目录 thinkphp5.0.24反序列化漏洞分析 具体分析 反序列化起点 toArray getRelationData分析 $modelRelat ...

  7. PHP:ThinkPHP5.0下载安装和各种配置

    1.ThinkPHP5.0简介 composer包管理工具 ThinkPHP3.0不兼容 php环境: 测试 开发 线上 url路由 请求响应 模板视图 MVC 一种设计典范 分离 model 模型 ...

  8. ThinkPHP5.0完全开发手册——调试模式

    调试模式 ThinkPHP有专门为开发过程而设置的调试模式,开启调试模式后,会牺牲一定的执行效率,但带来的方便和除错功能非常值得. 我们强烈建议ThinkPHP开发人员在开发阶段始终开启调试模式(直到 ...

  9. thinkphp5.0.9预处理导致的sql注入复现与详细分析

    复现 先搭建thinkphp5.0.9环境 配置下测试环境 然后访问 http://tptest.cc/index.php/index/index/getage?names[0,updatexml(0 ...

最新文章

  1. 刻意练习:LeetCode实战 -- Task08.删除排序链表中的重复元素
  2. Microsoft Visual C++ 不支持long long
  3. FreeSWITCH快速录音
  4. iOS 即时聊天键盘处理
  5. 如何走近深度学习人脸识别?你需要这篇超长综述 | 附开源代码
  6. [转载]使用命名管道实现进程间通信
  7. 前端学习(2978):上午回顾
  8. linux php cpu,获取Linux服务器性能CPU、内存、硬盘等使用率 PHP
  9. linux查看某进程的连接,linux下查看指定进程的所有连接信息(转)
  10. ApacheCN JavaScript 译文集(二) 20211123 更新
  11. Python菜鸟入门:day16编程学习
  12. Bailian4003 十六进制转十进制【入门】
  13. python基本数据类型和简单用法
  14. C语言逻辑运算符及其表达式
  15. 复合隐写/图片混合/图片格式头修改-西伯利亚大尾巴狼
  16. 蓝牙sbc怎么解决_蓝牙耳机不会挑?蓝牙编解码器了解一下
  17. 点餐系统,餐厅点餐系统,外卖点餐系统python计算机毕业设计
  18. 【云速建站】如何实现多用户权限管理
  19. 相思子肯来,约在莲花岸。(模拟
  20. AntV G6将节点修改成图片

热门文章

  1. jQuery Ajax实现下拉框无刷新联动
  2. eclipse中添加插件的方法
  3. chm editor
  4. JavaScript选择器
  5. dnf如何快速拾取物品_DNF游戏里的一些便利性功能,每个都非常实用
  6. cass地籍参数设置命令_想成为一名厉害的测绘员?南方Cass教程+插件+课件不可少!...
  7. gitlab贡献率_如何为GitLab做贡献
  8. pki和证书_PKI的位和字节
  9. opensource项目_最佳Opensource.com:法律
  10. drupal主题开发_Drupal开发人员,关于如何使您的网站更易于访问