PHP数组

这篇具有很好参考价值的文章主要介绍了PHP数组。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

数组是一个能在单个变量中存储多个值的特殊变量。

数组的英文是array,可以存入多个不同类型的数据,是一个复合数据类型。

在 PHP 中,有三种类型的数组:

  • 索引数组 - 带有数字 ID 键的数组
  • 关联数组 - 带有指定的键的数组,每个键关联一个值
  • 多维数组 - 包含一个或多个数组的数组

数组特点:

  • 键值对(key-value);
  • 键,key,存储数组中,变量的“编号”。
  • 值,value,存储数组中,变量的值。
  • 数组中的元素可以是任意类型的数据对象。
  • 索引数组,变量的“编号”是整数,整数不具备一定的语义。
  • 关联数组,变量的"编号"用字符串表示,可以具备一定的语义。

输出数组的时候不能使echo 语句,可以使用print_r() 函数来代替。


array 函数

在 PHP 中,array() 函数用于创建数组:

语法:

变量 = array(变量1,变量2,...);

变量 = array(
    'key1' => value1,
    'key2' => value2,
  ...
)
  • => 特殊的字符,在array 语言结构 中连接keyvalue
  • PHP 中数组的key 如果是字符串就具备一定的语义,可以非常方便的了解变量的含义。
  • PHP 数组中的key ,不建议使用除了整型和字符串的其他类型。
  • array() 不是函数,而是一种语言结构。

索引数组

直接创建

$animal[]='dog';
$animal[]='wolf';
$animal[]='cat';
var_dump($animal);

PHP数组,# 后端代码审计,php,开发语言,代码审计

array创建

$stu=array("hxy",'woman',18,100);
print_r($stu);

PHP数组,# 后端代码审计,php,开发语言,代码审计

关联数组

直接创建

把学生信息存储在一个变量里,需要用数组来实现。

$stu1['name'] = 'zs';
$stu1['sex'] = 'man';
$stu1['age'] = 18;
$stu1['score'] = 88;

echo "<pre>";
print_r($stu1);

PHP数组,# 后端代码审计,php,开发语言,代码审计

arry创建

$stu4 = array(
    'name'  => 'LSP',
    'sex'   => 'woman',
    'age'   => 19,
    'score' => 90.9
);

print_r($stu4);

print_r echo 类似,在输出布尔类型变量True 时,打印的是1;在输出False 时,打印什么都没有。

多维数组

数组中的元素可以是任何类型的数据。数组中的元素也可以是数组。

<?php
$name   = "zs";
$sex    = 'man';
$age    = 18;
$score  = 100;
$people['name']=$name;
$people['sex']=$sex;
$people['age']=$age;
$people['score']=$score;


$people1['name']='zs';
$people1['sex']='man';
$people1['age']=18;
$people1['score']=100;

$stu1['name'] = 'zs';
$stu1['sex'] = 'man';
$stu1['age'] = 18;
$stu1['score'] = 88;


$stu=array("hxy",'woman',18,100);

echo "<br />";
$ns_class=array($people,$people1,$stu,$stu1);
echo "<pre>";
print_r($ns_class);
?>

PHP数组,# 后端代码审计,php,开发语言,代码审计

元素访问

通过key 找到数组中的元素。

echo "hxy's score is {$stu[3]}";

echo "li's age is {$stu1['age']}";

echo "zs's age is {$ns_class[0]['age']}";

元素操作

对元素的操作包括:

数组元素操作 说明
读取 通过key,捕获数组中的value。
修改 直接赋值即可。
增加 直接赋值即可。
删除 PHP 中删除数组中的元素意义不大,置之不理即可。

尝试修改数组中的元素:

echo "hxy's score is {$ns_class[2][3]}<br />";

$ns_class[2][3] += 10;
echo "hxy's score is  {$ns_class[2][3]}";
$stu1['word'] = "为往圣继绝学,为万世开太平。";
var_dump($stu1);

数组遍历

for 循环

使用for 循环可以遍历数组,但是此种方法依赖于数组中key 自然数规律。

for ($i = 0; $i < count($stu1); $i++) { 
    echo $stu1[$i]."<br />";
}

显然,此种方法具有局限性,只能遍历索引数组。

foreach 语句

foreach 语法结构提供了遍历数组的简单方式。

foreach 这种语言结构是专门用来遍历数组的,foreach 是一种循环,不需要额外计时器。

foreach ($variable as $key => $value) {
    # code...
}

直接访问数组的值:

foreach ($stu as $v) {
    echo $v."<br />";
}

访问键值对:

foreach ($stu1 as $k => $v) {
    echo $k. "=". $v. "<br />";
}

注意:

  • foreach 是用来遍历数组的循环语言结构,数组中多少个元素,该语言结构就会循环执行几次。
  • foreach 语言结构中,临时变量的名字可以变化,但是语言结构不能改变。

数组相关函数

函数 作用
count() count($value, $mode): int
array_count_values() array_count_values(array $array): array
in_array() 检查数组中是否存在某一个元素。 此函数可以应用于黑白名单策略。
array_key_exists()
array_search()

预定义超全局数组变量

PHP中预定义了几个超级全局变量(superglobals) ,这意味着它们在一个脚本的全部作用域中都可用

名称 作用
$_GET 通过URL 参数(又叫query string)传递给当前脚本的变量的数组。 注意:该数组不仅仅对method 为 GET 的请求生效,而是会针对所有带query string 的请求。
$_POST 当HTTP POST 请求的==Content-Type 是application/x-www-form-urlencoded 或multipart/form-data== 时,会将变量以关联数组形式传入当前脚本。
$GLOBALS 关联数组array,包含当前脚本内定义成全局范围的所有变量的引用。数组的键就是变量的名字。
$_SERVER 服务器和执行环境信息。
$_FILES 通过HTTP POST 方式上传到当前脚本的项目的数组。此数组的概况在POST 方法上传 章节中有描述。
$_COOKIE 通过HTTP Cookies 方式传递给当前脚本的变量的数组。
$_SESSION 当前脚本可用 SESSION 变量的数组。更多关于如何使用的信息,参见Session 函数 文档。
$_REQUEST 默认情况下包含了$_GET,$_POST 和$_COOKIE 的数组。
$_ENV 通过环境方式传递给当前脚本的变量的数组。

注意:

  • 以上数组都是预定义,超全局的。
  • 以上数组在不同的PHP 版本中有不同的表现,但是大方向没变。
$_GET
  • 接收从浏览器客户端用户GET 方式传递到服务器的参数。
  • GET 传参的参数名做$_GET 数组的key,参数值作为数组的value。
  • GET 传参时,直接将参数拼接到URL 中即可。

前端代码:

<!DOCTYPE html>
<html lang="en">

<head>
    <link rel="stylesheet" href="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/3.4.1/css/bootstrap.min.css"
        integrity="sha384-HSMxcRTRxnN+Bdg0JdbxYKrThecOKuH5zCYotlSAcp1+c8xmyTe9GYg1l9a69psu" crossorigin="anonymous">
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <div class="container" style="margin-top: 20%;">
        <div class="row">
            <div class="col-md-8 col-md-offset-3">
                <form class="form-inline" action="8.php" method="get">
                    <div class="form-group">
                        <label for="ip">IP:</label>
                        <input type="text" class="form-control" id="ip" placeholder="127.0.0.1" name="ipaddr">
                    </div>
                    <div class="form-group">
                        <label for="Port">Port:</label>
                        <input type="text" class="form-control" id="Port" placeholder="0-65535" name="port">
                    </div>
                    <button type="submit" class="btn btn-default">快速连接</button>
                </form>
            </div>
        </div>
    </div>

</body>

</html>

PHP数组,# 后端代码审计,php,开发语言,代码审计

后端代码:

<!-- 使用switch语句编写一个程序,前端get传参,后端根据传参的端口号判断具体的服务类型 -->

<?php
$ipaddr = @$_GET['ipaddr'];
$port =  @$_GET['port'];
echo "接收到的IP地址为" . $ipaddr;
echo "<br />";
echo "<br />";
switch ($port) {
    case 80:
        echo "HTTP协议请求,80端口开放";
        break;
    case 443:
        echo "HTTPS协议请求,443端口开放";
        break;
    case 20:
        echo "FTP协议,数据端口开放  20";
        break;
    case 21:
        echo "FTP协议,控制端口开放 21";
    case 22: 
        echo "SSH协议端口开放 22";
        break;
    case 3306:
        echo "MySQL数据库端口开放  3306";
        break;
    case 27017:
        echo "MongoDB数据库端口开放 27017";
        break;
    case 6379:
        echo "Redis数据库端口开放  6379";
        break;
    case 3389:
        echo "Windows远程桌面服务端口开放  3389";
        break;
    default:
        echo "输入的端口号不在范围内。。。。";
}

PHP数组,# 后端代码审计,php,开发语言,代码审计

$_POST
  • $_POST 用于接收浏览器客户端用户以POST 方式传递过来的参数。
  • POST 传参,参数在请求正文中。

前端代码示例:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <link rel="stylesheet" href="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/3.4.1/css/bootstrap.min.css"
    integrity="sha384-HSMxcRTRxnN+Bdg0JdbxYKrThecOKuH5zCYotlSAcp1+c8xmyTe9GYg1l9a69psu" crossorigin="anonymous">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>post request</title>
</head>
<body>
    <div class="container">
        <div class="row">
            <div class="col-md-8 col-md-offset-2" style="margin-top: 10%;">
                <h3 class="text-center">form表单</h3>
                <form action="1.php" method="post">
                    username:<input type="text" name="username" class="form-control" >
                    password:<input type="password" name="password" class="form-control">
                    <br>
                    <p>
                        <input type="submit" name="button" value="提交" class="btn btn-danger">
                    </p>
                </form>
            </div>
        </div>
    </div>
   
</body>
</html>

后端代码:

//1.php
<?php
$username = @$_POST['username'];
$password = @$_POST['password'];
echo $username;
echo $password;
if(!$username){
	echo 'Please input a username!!';
}
if(!$password){
	echo ' input a password  is require!!';
}
?>
$_COOKIE

为了弥补HTTP 协议的无状态性,保持用户的会话状态,需要使用Cookie 技术。

Cookie 过程:

  • 用户提交账密
  • 服务器进行身份认证
  • 下发身份证,下发Cookie。
  • 浏览器客户端用户所有的请求都会携带身份信息,携带Cookie 信息。
  • 整体流程体现为,保持了HTTP 会话的状态性。
$_REQUEST

$_REQUEST,默认包含了$_GET,$_POST,$_COOKIE 数组中的所有变量。以上提到的三个数组,包含了浏览器客户端的三大传参方式,也称GPC。

但是$_REQUEST 数组在接收参数的时候,会受到一个PHP 选项的控制。

$_FILES

相关参数文章来源地址https://www.toymoban.com/news/detail-655270.html

变量 含义
$_FILES[‘uploaded’] 用来保存文件上传信息的。 uploaded 就是文件域input 标签name 属性的值。
$_FILES[‘uploaded’][‘name’] 上传文件的名字。
$_FILES[‘uploaded’][‘type’] 上传文件的类型。
$_FILES[‘uploaded’][‘tmp_name’] 上传文件存储在服务器中的缓存路径。
$_FILES[‘uploaded’][‘error’] 错误代码。
$_FILES[‘uploaded’][‘size’] 上传文件的大小
  • $_FILES 中存储的与上传文件有关的信息,不是文件本身,文件内容在缓存路径中。
  • 正常完成文件上传功能,需要将文件的从缓存拷贝到服务器文件系统中。

到了这里,关于PHP数组的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • PHP代码审计8—SSRF 漏洞

    1、漏洞原理与防御方法 1) 漏洞原理 SSRF的形成大多是由于服务端提供了从其他服务器应用获取数据的功能,并且没有对目标地址做过滤与限制。例如,黑客操作服务端从指定URL地址获取网页文本内容,加载指定地址的图片等,利用的是服务端的请求伪造。 2)防御方法 过滤返

    2024年02月09日
    浏览(42)
  • php许愿墙代码包括前端和后端部分

    以下是一个简单的PHP许愿墙代码示例,包括前端和后端部分: 前端HTML代码(index.html): 后端PHP代码(wishwall.php): 以上代码实现了一个简单的许愿墙功能。用户在前端页面填写姓名和愿望,点击提交后,后端PHP代码会将愿望以文本形式追加到一个名为 \\\"wishes.txt\\\" 的文件中,

    2024年02月03日
    浏览(45)
  • php 系列题目,包含查看后端源代码

    1.字符串和数字比较,字符串回被转换成数字。 \\\"admin\\\" ==0(true) admin被转换成数字,由于admin是字符串,转换失败,变成0 int(admin)=0,所以比较结果是ture 2.混合字符串转换成数字,看字符串的第一个 “1admin” == 1 ‘’2admin“ == 2  3.字符串开头以xex开头,x代表数字。会被转换成科

    2024年02月11日
    浏览(53)
  • 微信小程序学习实录2(下拉刷新、下拉加载更多、小程序事件、PHP后端代码、刷新无数据解决方案)

    lazyCodeLoading基础库 2.11.1 及以上版本支持,2.11.1 以下兼容但无优化效果 通常情况下,在小程序启动期间,所有页面及自定义组件的代码都会进行注入,当前页面没有使用到的自定义组件和页面在注入后其实并没有被使用。自基础库版本 2.11.1 起,小程序支持有选择地注入必要

    2024年02月05日
    浏览(49)
  • PHP开发日志 ━━ 不同方法判断某个数组中是否存在指定的键名,测试哪种方法效率高

    我们可以用 isset($arr[\\\'a\\\']) 或者 array_key_exists(\\\'a\\\', $arr) 来判断 \\\'a\\\' 键名是否存在与 $arr 数组。 那么这两种方式哪个运行速度快呢? 不多废话了,现在我们写一段代码来测试一下: 结论是 isset() 更胜一筹。

    2024年02月02日
    浏览(81)
  • 短视频矩阵系统源码开发搭建技术解析-PHP语言

    一、系统架构 整个短视频矩阵系统大概分为以下几个模块: 1.多平台账号管理 支持抖音、快手、小红书、西瓜、头条视频号等多平台账号管理。 2.视频管理模块 支持视频批量上传、批量剪辑、文字转语音,特效等功能配置 3.推荐算法模块 推荐算法模块主要用来推荐用户感兴

    2024年02月07日
    浏览(64)
  • 小迪安全20WEB 攻防-PHP 特性&缺陷对比函数&CTF 考点&CMS 审计实例

    #研究对象 PHP代码漏洞(代码问题) # 知识点: 1 、过滤函数缺陷绕过 2 、 CTF 考点与代码审计 一、原理-缺陷函数-使用讲解-本地 内置函数: 大部分是比较函数(过滤时使用的函数) (1)、== 与 === : 参考: PHP 浅谈 == 和=== 中,数字和字符串比较的问题。_php 数字==字符串

    2024年01月19日
    浏览(53)
  • 【PHP】二维数组转一维数组

    在 PHP 中,如果你想将一个二维数组转换为一维数组,你可以使用几种不同的方法。以下是一些常见的方法: array_column() 用于提取数组中的列,最为直接 array_map() 用于对数组中的每个元素应用回调函数,返回的是由回调函数的返回值组成的新数组。 以上任何一种方法都可以

    2024年02月04日
    浏览(62)
  • PHP后端连接数据库插入数据

    一、打开phpstudy。怎么搭建phpstudy,我上一个文章里有教。   二、编写代码 在网站根目录下(默认是www文件下)创建一个任意名称的文件夹,文件夹里创建两个php后缀的文件,一个html后缀的文件,名称自定义。但为了方便理解我把文件名命名成这样:          后端连接数据库

    2024年02月06日
    浏览(57)
  • Unity UnityWebRequest 向php后端上传图片文件

    之前测试功能写过一次,因为代码忘记保存,导致真正用到的时候怎么也想不起来当初怎么写的了,复现后还是写个文章记录一下,省的下次再忘记。 搞定。

    2024年01月23日
    浏览(54)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包