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. golang操作mysql2

    目录 Go操作MySQL 连接 下载依赖 使用MySQL驱动 初始化连接 SetMaxOpenConns SetMaxIdleConns CRUD 建库建表 查询 单行查询 多行查询 插入数据 更新数 ...

  2. 如何在 ASP.NET Core 中写出更干净的 Controller

    你可以遵循一些最佳实践来写出更干净的 Controller,一般我们称这种方法写出来的 Controller 为瘦Controller,瘦 Controller 的好处在于拥有更少的代码,更加单一的职 ...

  3. 图文详解:内存总是不够,我靠HBase说服了Leader为新项目保驾护航

  4. CF557E Ann and Half-Palindrome 题解

    算法:dp+字典树 题目链接Ann and Half-Palindrome   在CF刷字符串题的时候遇到了这题,其实并没有黑题这么难,个人感觉最多是紫题吧(虽然一开始以为是后缀自动机的神仙题).   ...

  5. 读 Kafka 源码写优雅业务代码:配置类

    这个 Kafka 的专题,我会从系统整体架构,设计到代码落地.和大家一起杠源码,学技巧,涨知识.希望大家持续关注一起见证成长! 我相信:技术的道路,十年如一日!十年磨一剑! 往期文章 Kafka 探险 ...

  6. css实现0.5像素的底边框。

    由于设计图的1px在移动端开发中的像素比是2倍,在实际开发中却是需要1px的线条,虽然最直接的方式是将线条设置为0.5px,但有些移动端对于0.5px的解析为0,变成了无边框的显示.因此处理该需求我们 ...

  7. 【odoo14】第十三章、网站开发(对外服务)

    本章我们将介绍一些关于odoo web服务方面的基础知识.进阶的内容,将在第十四章介绍. odoo中的web请求是由python的werkzeug库驱动的.odoo为了操作方便,对werkzeug进行 ...

  8. vue全局错误捕获

    1.errorHandler Vue全局配置 errorHandler可以进行全局错误收集,捕获全局错误抛出,避免前端页面挂掉   export default function errorHandl ...

  9. Linux和Docker的Capabilities介绍及Setcap命令

    Linux和Docker的capabilities介绍 转载:https://www.cnblogs.com/charlieroro/p/10108577.html 验证环境:centos7 x86/ ...

  10. 给我一个shell我能干翻你内网

    0x00 前言 在去年小菜鸡学了点内网知识就闲着没事跑点jboss的站看看,在经历过很多次内网横向失败之后终于算是人生圆满了一把,阿三的站一般进去之后很难横向,不知道是不是我太菜的原因,反正阿三的站能 ...