对于该篇文章主要自用吧,为CTF的web项做点php前驱准备
1.认识PHP
本部分主要从代码技术层面认识PHP
首先注意,php语句和C,java等许多语言一样,以;(分号)表示一句的结束。下面展示一段完整的php代码:
<!DOCTYPE html>
<html>
<body>
<h1>My first PHP page</h1>
<?php
echo "Hello World!";
?>
</body>
</html>
下面是运行结果:
认准下面开头结束特征为为PHP代码:
<?php
//里面开始写php代码了
?>
俩尖括号,?(问号)开首尾,开头的?后再标一个php,中间就能写代码了
注释主要有俩种//和/**/
//php注释
/*php注释*/
2.php的变量
2.1 PHP 变量规则:
1.变量以 $ 符号开始,后面跟着变量的名称
2.变量名必须以字母或者下划线字符开始
3.变量名只能包含字母、数字以及下划线(A-z、0-9 和 _ )
4.变量名不能包含空格
5.变量名是区分大小写的($y 和 $Y 是两个不同的变量)
2.2变量的作用域
首先,在定义函数的内部,是无法使用全局变量的。(当然在调用函数时可用使用全局变量)
<?php
$x=5; // 全局变量
function myTest()
{
$y=10; // 局部变量
echo "<p>测试函数内变量:<p>";
echo "变量 x 为: $x";
echo "<br>";
echo "变量 y 为: $y";
}
myTest();
echo "<p>测试函数外变量:<p>";
echo "变量 x 为: $x";
echo "<br>";
echo "变量 y 为: $y";
?>
如果要解决函数内部调全局变量的例子,这里介绍一个关键字:global
2.2.1 Global
global 关键字用于函数内访问全局变量。
在函数内调用函数外定义的全局变量,我们需要在函数中的变量前加上 global 关键字:
<?php
$x=5;
$y=10;
function myTest()
{
global $x,$y;
$y=$x+$y;
}
myTest();
echo $y; // 输出 15
?>
结果就是输出了数字15
PHP 将所有全局变量存储在一个名为 $GLOBALS[index] 的数组中。 index 保存变量的名称。这个数组可以在函数内部访问,也可以直接用来更新全局变量。
上面的实例可以写成这样:
<?php
$x=5;
$y=10;
function myTest()
{
$GLOBALS['y']=$GLOBALS['x']+$GLOBALS['y'];
}
myTest();
echo $y;
?>
结果仍未输出数字15
2.2.2 Static
当一个函数完成时,它的所有变量通常都会被删除。然而,有时候您希望某个局部变量不要被删除。
要做到这一点,请在您第一次声明变量时使用 static 关键字:
<?php
function myTest()
{
static $x=0;
echo $x;
$x++;
echo PHP_EOL; // 换行符
}
myTest();
myTest();
myTest();
?>
输出0\n1\n2\n
换行也可以echo"<br>"
然后,每次调用该函数时,该变量将会保留着函数前一次被调用时的值。
注意:该变量仍然是函数的局部变量。
3.EOF的使用
PHP EOF(heredoc)是一种在命令行shell(如sh、csh、ksh、bash、PowerShell和zsh)和程序语言(像Perl、PHP、Python和Ruby)里定义一个字符串的方法。
使用概述:
- 必须后接分号,否则编译通不过。
- EOF 可以用任意其它字符代替,只需保证结束标识与开始标识一致。
- 结束标识必须顶格独自占一行(即必须从行首开始,前后不能衔接任何空白和字符)。
- 开始标识可以不带引号或带单双引号,不带引号与带双引号效果一致,解释内嵌的变量和转义符号,带单引号则不解释内嵌的变量和转义符号。
- 当内容需要内嵌引号(单引号或双引号)时,不需要加转义符,本身对单双引号转义,此处相当与q和qq的用法。
使用范例:
<?php
echo <<<EOF
<h1>我的第一个标题</h1>
<p>我的第一个段落。</p>
EOF;
// 结束需要独立一行且前后不能空格
?>
注意:
1.以 <<<EOF
开始标记开始,以 EOF
结束标记结束,结束标记必须顶头写,不能有缩进和空格,且在结束标记末尾要有分号 。
2.开始标记和结束标记相同,比如常用大写的 EOT、EOD、EOF 来表示,但是不只限于那几个(也可以用:JSON、HTML等),只要保证开始标记和结束标记不在正文中出现即可。
3.位于开始标记和结束标记之间的变量可以被正常解析,但是函数则不可以。在 heredoc 中,变量不需要用连接符 . 或 , 来拼接,如下:
<?php
$name="runoob";
$a= <<<EOF
"abc"$name
"123"
EOF;
// 结束需要独立一行且前后不能空格
echo $a;
?>
4.PHP的数据类型
PHP 变量存储不同的类型的数据,不同的数据类型可以做不一样的事情。
PHP 支持以下几种数据类型:
String(字符串)
Integer(整型)
Float(浮点型)
Boolean(布尔型)
Array(数组)
Object(对象)
NULL(空值)
Resource(资源类型)
如果我们想看某变量的数据类型,PHP中可以使用var_dump()
,该函数返回变量的数据类型和值
<?php
$x = 5985;
var_dump($x);
//echo PHP_EOL;
$x = "你好"; // 负数
var_dump($x);
//echo "<br>";
$x = 0x8C; // 十六进制数
var_dump($x);
//echo "<br>";
$x = 047; // 八进制数
var_dump($x);
?>
其中,string(6)“你好"这个结果的含义是:
string(6):表示输出的是一个字符串,字符串的长度为6个字符。(在UTF-8编码中,汉字通常占用3个字节来表示。)
“你好”:表示输出的字符串内容为"你好”。
8种数据类型本部份将重点介绍数组Array,对象Object,资源Resource这三类
4.1数组Array
上案例(此处为最常见的数值数组):
<?php
$cars=array("Volvo","BMW","Toyota");
echo "I like",$cars[2],"very much";
?>
中间用,(逗号).(英文句号)都行。下面系统走一遍:
4.1.1创建数组:
4.1.2赋值数组:
4.1.3三种数组类型
1.数值型数组:
<?php
$cars=array("Volvo","BMW","Toyota");
echo "I like " . $cars[0] . ", " . $cars[1] . " and " . $cars[2] . ".";
?>
2.关联型数组
可以看到特征:
类比python的字典,以大括号前后开头,键值对用:冒号连接
PHP这首先叫关联数组,所以array()定义,(所谓的)键值用=>
连接
用的时候,$加上数组名加上中括号[],括号里写键
<?php
$age=array("Peter"=>35,"Ben"=>37,"Joe"=>43);
echo "Peter is " . $age['Peter'] . " years old.";
?>
3.多维数组(暂时略)
4.1.4数组遍历
首先,学会数组count()方法:
<?php
$cars=array("Volvo","BMW","Toyota");
echo count($cars);
?>
输出就是3
遍历数组,如果是数值型:
<?php
$cars=array("Volvo","BMW","Toyota");
$arrlength=count($cars);
for($x=0;$x<$arrlength;$x++)
{
echo $cars[$x];
echo "<br>";
}
?>
如果是关联型:
<?php
$age=array("Peter"=>"35","Ben"=>"37","Joe"=>"43");
foreach($age as $x=>$x_value)
{
echo "Key=" . $x . ", Value=" . $x_value;
echo PHP_EOL;
}
?>
注意,$x_value这里的下划线是语法。执行结果如下:
4.1.5数组排序
这里就不在一 一给例子了
4.2对象
在 PHP 中,对象必须声明。
首先,你必须使用class关键字声明类对象。类是可以包含属性和方法的结构。
然后我们在类中定义数据类型,然后在实例化的类中使用数据类型:
<?php
class Car
{
var $color;
function __construct($color="green") {
$this->color = $color;
}
function what_color() {
return $this->color;
}
}
?>
对以上的代码呢,__construct()是构造函数。主要用来在创建对象时初始化对象, 即为对象成员变量赋初始值,在创建对象的语句中与 new 运算符一起使用