PHP-输入变量

在Web开发过程中,我们经常需要获取系统变量或者用户提交的数据,这些变量数据错综复杂,而且一不小心就容易引起安全隐患,但是如果利用好ThinkPHP提供的变量获取功能,就可以轻松的获取和驾驭变量了。

获取变量

虽然你仍然可以在开发过程中使用传统方式获取各种系统变量,例如:

  1. $id = $_GET[‘id‘]; // 获取get变量
  2. $name = $_POST[‘name‘]; // 获取post变量
  3. $value = $_SESSION[‘var‘]; // 获取session变量
  4. $name = $_COOKIE[‘name‘]; // 获取cookie变量
  5. $file = $_SERVER[‘PHP_SELF‘]; // 获取server变量

但是我们不建议直接使用传统方式获取,因为没有统一的安全处理机制,后期如果调整的话,改起来会比较麻烦。所以,更好的方式是在框架中统一使用I函数进行变量获取和过滤。

I方法是ThinkPHP用于更加方便和安全的获取系统输入变量,可以用于任何地方,用法格式如下:

I(‘变量类型.变量名/修饰符‘,[‘默认值‘],[‘过滤方法‘],[‘额外数据源‘])

变量类型是指请求方式或者输入类型,包括:

变量类型 含义
get 获取GET参数
post 获取POST参数
param 自动判断请求类型获取GET、POST或者PUT参数
request 获取REQUEST 参数
put 获取PUT 参数
session 获取 $_SESSION 参数
cookie 获取 $_COOKIE 参数
server 获取 $_SERVER 参数
globals 获取 $GLOBALS参数
path 获取 PATHINFO模式的URL参数(3.2.2新增)
data 获取 其他类型的参数,需要配合额外数据源参数(3.2.2新增)

注意:变量类型不区分大小写。
变量名则严格区分大小写。
默认值和过滤方法均属于可选参数。

变量修饰符是3.2.3版本新增

我们以GET变量类型为例,说明下I方法的使用:

  1. echo I(‘get.id‘); // 相当于 $_GET[‘id‘]
  2. echo I(‘get.name‘); // 相当于 $_GET[‘name‘]

支持默认值:

  1. echo I(‘get.id‘,0); // 如果不存在$_GET[‘id‘] 则返回0
  2. echo I(‘get.name‘,‘‘); // 如果不存在$_GET[‘name‘] 则返回空字符串

采用方法过滤:

  1. // 采用htmlspecialchars方法对$_GET[‘name‘] 进行过滤,如果不存在则返回空字符串
  2. echo I(‘get.name‘,‘‘,‘htmlspecialchars‘);

支持直接获取整个变量类型,例如:

  1. // 获取整个$_GET 数组
  2. I(‘get.‘);

用同样的方式,我们可以获取post或者其他输入类型的变量,例如:

  1. I(‘post.name‘,‘‘,‘htmlspecialchars‘); // 采用htmlspecialchars方法对$_POST[‘name‘] 进行过滤,如果不存在则返回空字符串
  2. I(‘session.user_id‘,0); // 获取$_SESSION[‘user_id‘] 如果不存在则默认为0
  3. I(‘cookie.‘); // 获取整个 $_COOKIE 数组
  4. I(‘server.REQUEST_METHOD‘); // 获取 $_SERVER[‘REQUEST_METHOD‘]

param变量类型是框架特有的支持自动判断当前请求类型的变量获取方式,例如:

echo I(‘param.id‘);

如果当前请求类型是GET,那么等效于 $_GET[‘id‘],如果当前请求类型是POST或者PUT,那么相当于获取 $_POST[‘id‘] 或者 PUT参数id。

由于param类型是I函数默认获取的变量类型,因此事实上param变量类型的写法可以简化为:

  1. I(‘id‘); // 等同于 I(‘param.id‘)
  2. I(‘name‘); // 等同于 I(‘param.name‘)

3.2.2新增了path和data两个变量类型,用法如下:

path类型变量可以用于获取URL参数(必须是PATHINFO模式参数有效,无论是GET还是POST方式都有效),例如: 当前访问URL地址是 http://serverName/index.php/New/2013/06/01

那么我们可以通过

  1. echo I(‘path.1‘); // 输出2013
  2. echo I(‘path.2‘); // 输出06
  3. echo I(‘path.3‘); // 输出01

data类型变量可以用于获取不支持的变量类型的读取,例如:

  1. I(‘data.file1‘,‘‘,‘‘,$_FILES);

变量过滤

如果你没有在调用I函数的时候指定过滤方法的话,系统会采用默认的过滤机制(由DEFAULT_FILTER配置),事实上,该参数的默认设置是:

  1. // 系统默认的变量过滤机制
  2. ‘DEFAULT_FILTER‘ => ‘htmlspecialchars‘

也就说,I方法的所有获取变量如果没有设置过滤方法的话都会进行htmlspecialchars过滤,那么:

  1. // 等同于 htmlspecialchars($_GET[‘name‘])
  2. I(‘get.name‘);

同样,该参数也可以设置支持多个过滤,例如:

  1. ‘DEFAULT_FILTER‘ => ‘strip_tags,htmlspecialchars‘

设置后,我们在使用:

  1. // 等同于 htmlspecialchars(strip_tags($_GET[‘name‘]))
  2. I(‘get.name‘);

如果我们在使用I方法的时候 指定了过滤方法,那么就会忽略DEFAULT_FILTER的设置,例如:

  1. // 等同于 strip_tags($_GET[‘name‘])
  2. echo I(‘get.name‘,‘‘,‘strip_tags‘);

I方法的第三个参数如果传入函数名,则表示调用该函数对变量进行过滤并返回(在变量是数组的情况下自动使用array_map进行过滤处理),否则会调用PHP内置的filter_var方法进行过滤处理,例如:

  1. I(‘post.email‘,‘‘,FILTER_VALIDATE_EMAIL);

表示 会对$_POST[‘email‘] 进行 格式验证,如果不符合要求的话,返回空字符串。 (关于更多的验证格式,可以参考 官方手册的filter_var用法。) 或者可以用下面的字符标识方式:

  1. I(‘post.email‘,‘‘,‘email‘);

可以支持的过滤名称必须是filter_list方法中的有效值(不同的服务器环境可能有所不同),可能支持的包括:

  1. int
  2. boolean
  3. float
  4. validate_regexp
  5. validate_url
  6. validate_email
  7. validate_ip
  8. string
  9. stripped
  10. encoded
  11. special_chars
  12. unsafe_raw
  13. email
  14. url
  15. number_int
  16. number_float
  17. magic_quotes
  18. callback

3.2.3版本开始支持进行正则匹配过滤,例如:

  1. // 采用正则表达式进行变量过滤
  2. I(‘get.name‘,‘‘,‘/^[A-Za-z]+$/‘);
  3. I(‘get.id‘,0,‘/^\d+$/‘);

如果正则匹配不通过的话,则返回默认值。

在有些特殊的情况下,我们不希望进行任何过滤,即使DEFAULT_FILTER已经有所设置,可以使用:

  1. // 下面两种方式都不采用任何过滤方法
  2. I(‘get.name‘,‘‘,‘‘);
  3. I(‘get.id‘,‘‘,false);

一旦过滤参数设置为空字符串或者false,即表示不再进行任何的过滤。

变量修饰符

3.2.3版本开始,I函数支持对变量使用修饰符功能,可以更好的过滤变量。

用法如下: I(‘变量类型.变量名/修饰符‘);

例如:

  1. I(‘get.id/d‘);
  2. I(‘post.name/s‘);
  3. I(‘post.ids/a‘);

可以使用的修饰符包括:

修饰符 作用
s 强制转换为字符串类型
d 强制转换为整形类型
b 强制转换为布尔类型
a 强制转换为数组类型
f 强制转换为浮点类型

时间: 2024-08-10 20:29:05

PHP-输入变量的相关文章

【C#学习笔记】【7】我想从键盘输入变量的值,这样程序就更灵活了(输入输出函数以及类型转换)

我们在之前的文章中,对于变量的赋值(初始化)都是直接写在程序中的,那如果想从键盘输入,怎么做呢?我来介绍一个用于从键盘获取输入值的方法. Console.ReadLine()方法 看到这个标题,是不是想起了什么?对,我们之前用的输出函数Console.WriteLine()方法.今天我们再介绍一下输入函数. 猜猜怎么用?好吧,我介绍一下用法: string s; s=Console.ReadLine(); Console.WriteLine(s); 从上面的例子中我们可以看出,Console.R

Eclipse中输入变量会自动补全上屏的解决方法

我自己在启动Eclipse代码补全后输入感觉确实爽多了,但是每次输入变量后一按下空格,编译器会自己帮你写一个很蛋疼的名字,比如你输入了:String mStr后按下空格,它就变成了mString,十分讨厌.下面是正规的解决办法,但是经过我反复折腾,我实在没办法把插件的源码显示到工程中.于是偷个懒去网上下载了已经修改好的jar包,成功搞定. 我自己复制jar包的目录是:D:\Work Appliactions\adt-bundle-windows-x86-20140702\eclipse\plug

ThinkPHP获取输入变量

1. http://localhost/jike/index.php/Home/User/login/user/jike 模块 >> 控制器 >> 函数方法 >> 变量 >> 变量的值,代码见下面的粗体部分. 2. ThinkPHP控制器(四):获取输入变量 获取输入变量有以下几种方式: a. $_GET/$_POST/$_SEVER (这样做是不安全,因为没有经过统一的数据过滤,容易发送??恶意攻击) b. ThinkPHP框架提供了I函数(Input单词

输入变量I()

在Web开发过程中,我们经常需要获取系统变量或者用户提交的数据,这些变量数据错综复杂,而且一不小心就容易引起安全隐患,但是如果利用好ThinkPHP提供的变量获取功能,就可以轻松的获取和驾驭变量了. 获取变量 虽然你仍然可以在开发过程中使用传统方式获取各种系统变量,例如: $id = $_GET['id']; // 获取get变量 $name = $_POST['name']; // 获取post变量 $value = $_SESSION['var']; // 获取session变量 $name

组合电路(反推逻辑表达式,组合电路的控制结果只和输入变量的状态有关)

如何根据真值表反推逻辑表达式? 第一种方法:以真值表内输出端“1”为准 第一步:从真值表内找输出端为“1”的各行,把每行的输入变量写成乘积形式;遇到“0”的输入变量上加非号. 第二步:把各乘积项相加,即得逻辑函数的表达式. 第二种方法:以真值表内输出端“0”为准 第一步:从真值表内找输出端为“0”的各行,把每行的输入变量写成求和的形式,遇到“1”的输入变量上加非号. 第二步:把各求和项相乘,即得逻辑函数表达式. 最后化简,在实际运用过程中,哪个方法简便就采用哪种. 具体实例演示: 假设在楼梯走廊

shell判断输入变量或者参数是否为空

判断变量 read -p "input a word :" word if  [ ! -n "$word" ] ;then echo "you have not input a word!" else echo "the word you input is $word" fi 判断输入参数 #!/bin/bash if [ ! -n "$1" ] ;then echo "you have not

绘制等腰空心梯形,下底和高都为输入变量n(上宽下窄)

1 #include <stdio.h> 2 int main() 3 { 4 int n,i,j; 5 scanf("%d",&n); 6 for(j=1;j<=3*n-2;j++) //第一排 7 printf("*"); 8 printf("\n"); 9 10 for(i=2;i<=n-1;i++) //除了第一排和最后一排 11 { 12 for(j=1;j<=i-1;j++) 13 printf(

unity shader笔记

clip函数可以用来切割mesh clip(var); var 的值小于0时就会被切割 表面着色器 其实就是生成了定点片元着色器,相当于一种包装和简化吧 标准的填充结构 struct SurfaceOutput { fixed3 Albedo; // diffuse color fixed3 Normal; // tangent space normal, if written fixed3 Emission; half Specular; // specular power in 0..1 r

GCC在C语言中内嵌汇编 asm __volatile__ 【转】

转自:http://blog.csdn.net/pbymw8iwm/article/details/8227839 在内嵌汇编中,可以将C语言表达式指定为汇编指令的操作数,而且不用去管如何将C语言表达式的值读入哪个寄存器,以及如何将计算结果写回C 变量,你只要告诉程序中C语言表达式与汇编指令操作数之间的对应关系即可, GCC会自动插入代码完成必要的操作. 1.简单的内嵌汇编 例: __asm__ __volatile__("hlt"); "__asm__"表示后面的

Linux C中内联汇编的语法格式及使用方法(Inline Assembly in Linux C)

在阅读Linux内核源码或对代码做性能优化时,经常会有在C语言中嵌入一段汇编代码的需求,这种嵌入汇编在CS术语上叫做inline assembly.本文的笔记试图说明Inline Assembly的基本语法规则和用法(建议英文阅读能力较强的同学直接阅读本文参考资料中推荐的技术文章 ^_^). 注意:由于gcc采用AT&T风格的汇编语法(与Intel Syntax相对应,二者的区别参见这里),因此,本文涉及到的汇编代码均以AT&T Syntax为准. 1. 基本语法规则 内联汇编(或称嵌入汇