0x01

  • 我们知道 PHP 接收的变量最常用的是 GET,POST,COOKIE 这三个变量。GET变量是附在 url 后传输的,而 POST 变量是放在 http 包中传输的,COOKIE 则是浏览器中储存的,变量最常用的接收变量的方法比如 get 方式是通过 $_GET[],中括号中是变量名,但是是在变量名知道的情况下并且一次只能接收一个变量值,那么怎么在不知道变量名的情况下去动态的接收变量名和变量名对应的值呢,可以通过结合 PHP 中的可变变量和 foreach 遍历的方法来实现这个方法(这个方法是我在看米拓 cms 源码的时候偶然发现的,这里研究了一下,顺便和大家分享一下)。首先大家看一下什么是PHP 中的可变变量

0x02

  • PHP 变量的定义方式,比如说我要定义一个变量名为 var 的值为 test,那么可以这样办:$var="test",定义完之后这个变量名就不可以改变了,如果要修改这个变量名的话,就需要用到 PHP中的可变变量:$$var,以下是可变变量的利用方法,利用可变变量来查询 _COOKIE。
  • 首先呢查看一下网页的 COOKIE

  • 之后用可变变量的方式来查询这个 COOKIE,并且把他打印出来



    为了帮助大家更好的理解这个可变变量,这里贴出了 PHP 官网的一个例子
    <?php

      //You can even add more Dollar Signs

      $Bar = "a";
$Foo = "Bar";
$World = "Foo";
$Hello = "World";
$a = "Hello";
// PS:$$var 和 ${$var}的效果是一样的
$a; //Returns Hello
$$a; //Returns World
$$$a; //Returns Foo
$$$$a; //Returns Bar
$$$$$a; //Returns a $$$$$$a; //Returns Hello
$$$$$$$a; //Returns World
//... and so on ...//
?>

0x03

  • 动态的查询COOKIE变量

0x04

  • 动态的接收GET传递过来的变量

0x05

  • 动态的接收POST传递过来的变量



0x06

  • 还有一种方法就是 GET,POST 和 COOKIE 三个参数都接收(米拓 cms 就是这样的)

总结

利用 PHP 可变变量来接收传递过来的变量名和变量值确实很方便,但可变变量的利用方式还有很多,有兴趣可以去官网看一看。还有一个就是安全方面的问题,以这种方式接收传递的变量必须进行严格过滤

下面是源码方便粘贴

部分接收的 (异曲同工,所以只贴了一个)

    <!DOCTYPE html>
<html>
<head>
<title>Demo</title>
<meta charset="utf-8">
</head>
<body>
<?php $test = "_GET";
foreach (${$test} as $key => $value) {
# code...
echo '$key的值是:'."$key"."<br>";
echo '$value的值是:'."$value"."<br>";
}
?>
</body>
</html>

全都接收的

    <!DOCTYPE html>
<html>
<head>
<title>Demo</title>
<meta charset="utf-8">
</head>
<body>
<?php $var_all = array("_GET", "_POST", "_COOKIE");
foreach ($var_all as $key) {
# code...
foreach ($$key as $_key => $value) {
# code...
echo '$_key的值是:'."$_key"."<br>";
echo '$value的值是:'."$value"."<br>";
}
} ?>
</body>
</html>

PS:如果认为我这个博客有什么问题或者有修改意见的,请一定要告诉我,非常感谢(我的邮箱2412875746@qq.com)

关于PHP动态的接收传递的GET,POST和COOKIE变量的更多相关文章

  1. 前端传递给后端且通过cookie方式,尽量传递id

    前端传递给后端且通过cookie方式,尽量传递id

  2. Android 静态广播和动态广播接收顺序

    Android广播有两个很重要的要素: 1 广播 - 用于发送广播 有序广播  -  被广播接收器接收后,可被终止,无法往下继续传达.         典型代表:短信广播 普通广播  -  发送至每一 ...

  3. DATAX动态参数数据传递

    实例:ORACLE到ORACLE的数据传递   编写job.xml文件,添加变量参数 执行datax.py文件时记得带参数 格式:./datax.py –p"-Ddbname=*** -Di ...

  4. vue 动态组件,传递参数

    <template> <div class="top"> <div class='nav'> <ul class='navHader'&g ...

  5. jsonp跨域实现单点登录,跨域传递用户信息以及保存cookie注意事项

    网站A:代码:网站a的login.html页面刷新,使用jsonp方式将信息传递给b.com的login.php中去,只需要在b.com中设置一下跨域以及接收参数,然后存到cookei即可, 注意:网 ...

  6. go语言练习:幂、函授接收和返回参数、转义字符、变量和常量

    1.实现a^b次方 package main func main() { r2 := power1(2,4) println(r2) } func power1(a uint64, b uint64) ...

  7. 动态执行SQL语句,接收返回值

    一.exec和sp_executesql介绍 当需要根据外部输入的参数来决定要执行的SQL语句时,常常需要动态来构造SQL查询语句.比如,一个比较通用的分页存储过程,可能需要传入表名,字段,过滤条件, ...

  8. EasyUI Tree 动态传递参数

    1.问题背景 一般出现在加载的时候,传递参数给后台,进行数据筛选,然后在加载tree渲染数据.所谓动态参数,可以是你的上一级节点node,或者是根节点node. 2.涉及方法 onBeforeLoad ...

  9. JavaScript—之对象参数的引用传递

    变量 1.JavaScript hoisting >>请看例子,我们拿Chrome的console作为JS的运行环境. 上面直接执行console.log(a), 不带一点悬念地抛出了no ...

随机推荐

  1. Hadoop的常用命令

    注:hadoop的使用命令包含 hadoop fs 开头 or hdfs dfs开头 等多种形式来操作. 这里以hadoo fs的形式来介绍在这些命令 1.列出根目录下所有的目录或文件 hadoop ...

  2. MySQL日志收集之Filebeat和Logstsh的一键安装配置(ELK架构)

    关于ELK是什么.做什么用,我们不在此讨论.本文重点在如何实现快速方便地安装logstash和filebeat组件,特别是在近千台DB Server的环境下(为了安全保守,公司DB Server 目前 ...

  3. [实战]ASP.NET Padding Oracle信息泄露漏洞

    前言 这个漏洞是很多年前的了,刚好碰到网站有这个漏洞,利用一下也记录一下.具体原理请搜索学习,反正我不会. 推荐看这里,写得很清楚:http://www.91ri.org/6715.html 工具 p ...

  4. 解决 Ant Design Modal 中的 Select 选项框不能显示的问题

    antd 的 select 在 modal 里不能显示候选框 代码示例 <a-modal> <a-select> <!-- options --> </a-s ...

  5. WPF 基础 - Window 启动动画

    <Window ... WindowStyle="None" AllowsTransparency="True" RenderTransformOrigi ...

  6. 翻译:《实用的Python编程》06_01_Iteration_protocol

    目录 | 上一节 (5.2 封装) | 下一节 (6.2 自定义迭代) 6.1 迭代协议 本节将探究迭代的底层过程. 迭代无处不在 许多对象都支持迭代: a = 'hello' for c in a: ...

  7. JVM之基础概念(运行时数据区域、TLAB、逃逸分析、分层编译)

    运行时数据区域 JDK8 之前的内存布局 JDK8 之后的 JVM 内存布局 JDK8 之前,Hotspot 中方法区的实现是永久代(Perm),JDK8 开始使用元空间(Metaspace),以前永 ...

  8. 攻防世界 reverse 进阶 9-re1-100

    9.re1-100 1 if ( numRead ) 2 { 3 if ( childCheckDebugResult() ) 4 { 5 responseFalse(); 6 } 7 else if ...

  9. TypeError: 'list' object cannot be interpreted as an integer Python常见错误

    想要通过索引来迭代一个list或者string的元素, 这需要调用 range() 函数.要记得返回len 值而不是返回这个列表.

  10. seq 命令用法

    以指定增量从首数开始打印数字到尾数. 用法: seq [选项]... 尾数 或:seq [选项]... 首数 尾数 或:seq [选项]... 首数 增量 尾数 选项: -f, --format=格式 ...