练习
成绩定级
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>成绩定级脚本</title>
</head>
<body>
<form method="post">
输入成绩:
<input type="text" name="score">
<input type="submit">
</form>
<?php
@$score=$_POST["score"];
if($score==NULL){
}else{
if($score>=60){
echo"congratulations";
}else{
echo "sorry";
}
}
?>
</body>
</html>
验证可变变量
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>The person around me</title>
</head>
<body>
<?php
$gaopeng="favorite";
$favorite="gaopeng_love_eating_dick";
echo $$gaopeng;
?>
</body>
</html>
九九乘法表
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>99 乘法表</title>
</head>
<body>
<?php
echo"<table border=1>";
for ($i = 1; $i < 10; $i++) {
echo "<tr>";
for ($j = 1; $j <= $i; $j++) {
echo "<td>";
echo "{$j}"."*"."{$i}"."="."{$j}"*"{$i}";
echo "</td>";
}
echo "</tr>";
}
echo"</table>";
?>
</body>
</html>
PHP 基础
概述
-
在PHP 文件中,可以与HTML 和JavaScript 混编。
-
开始标记
<?php
表示进入PHP 模式,结束标记?>
,标识退出PHP 模式。 -
PHP 模式之外的内容会被作为字符输出到浏览器中。
-
PHP 在服务端执行,HTML 和 JS 在浏览器执行
-
HTML 或JavaScript 对于PHP 来说就是纯文本字符串
-
phpinfo
安全问题:如果是一个在线的网站能够看到phpinfo 页面,说明存在敏感信息泄露漏洞,这个漏洞需要体现在后面的渗透测试报告中。
<?php phpinfo()?>
基础语法
PHP 开始标记
<?php
PHP 结束标记
?>
指令分隔符
分号;
,代表一句PHP 代码的结束。
注释
-
单行注释
该行
//
后的内容为注释内容phpinfo(); // 该函数会显示PHP 配置信息
-
多行注释
/*
开始,*/
结束/* 这是多行注释! 以下语句表示PHP 配置信息 */ phpinfo();
空白字符
-
空白符包括:
空白字符 表达 空格 TAB 制表符 \t 回车换行 \r\n
换行也可以在输出的字符中输出<br>
这些空白字符在PHP 中都是无关紧要的,可以将一个语句展开成任意行,或者紧缩在一行,空格与空行的合理运用可以增强代码的清晰性与可读性,如果运用不合理反而会对阅读产生负担!
但是,不能是用空白符打断 PHP 的关键字,例如函数名,语句名,变量名,类名,方法名等等。
-
例,不打断关键字
phpinfo
依旧可执行
-
例,打断关键字
phpinfo
错误级别
- Notice、Warning 不会打断 PHP 运行
- Error 会直接导致 PHP 程序结束运行
变量
变量的声明、使用、释放
变量定义
-
形式
$ + 变量名;
-
严格区分大小写
$name; $Name; $NAME //三个变量不是同一个变量
-
字母、数字、下划线组成,不能以数字开头,不能包含其他字符(空白字符、特殊字符)
-
驼峰式命名法、下划线式命名法
$first_name; $firstName; $FirstName;
-
标识符(关键字)尽量不作为变量名
变量的赋值、使用
-
echo
输出字符串<?php $username="gjl"; echo $username; //在网页输出 gjl ?>
变量的释放
-
unset()
函数unset($变量名);
<?php $username="gjl"; unset($username); echo $username; //报错Notice: Undefined variable: username in E:\phpstudy\WWW\test.php on line 4 //未定义变量 ?>
可变变量
-
可变变量:
一个变量的名字可以动态设置和使用
也是 php 中变量覆盖漏洞的原因之一
定义:
$$
-
使用举例
<?php $username="gjl"; $gjl="GuoJialiang"; echo $$username; //输出 GuoJialiang //$($username) ?>
-
应用
<?php $username="gjl"; $gjl="GuoJialiang"; $$username="liang"; echo $gjl; //输出 liang ?>
变量类型
- 具有相同类型的数据才能相互操作
输出变量类型
-
将变量类型输出使用函数
var_dump()
<?php $name = "ZhangSan"; var_dump($name); //输出 string(8) "ZhangSan" //长度为8的字符串“ZhangSan” ?>
<?php $sex = true; var_dump($sex); $age = 24; var_dump($age); $score = 59.9; var_dump($score); //输出 bool(true) int(24) float(59.9) ?>
bool
-
true/false
进行 if 判断的时,候如果表达式不是布尔类型的值,会自动进行类型转换,将其它类型的值转换成布尔值,以下值被认为是
false
,其他大部分的值则被认为是true
bool(false) // $flag = int(0) // 0 float(0) // 0.0 string(0)"" // "" string(1)"0" // "0" array(0){} // array() NULL // NULL
int
-
整型,存储整数
$age = 24; var_dump($age); // int(21)
float
-
浮点型,包含小数的数
$score = 59.9; var_dump($score); // float(59.9)
string
- 字符串,可以使用单引号、双引号、定界符三种方法进行定义
单引号
-
单引号定义的字符串不能再包含单引号,如果必须使用单引号则需要用反斜杠
\
进行转义\'
<?php $welcome = 'welcome \'ZhangSan\''; echo $welcome; //输出 welcome 'ZhangSan' ?>
-
php 不会解析单引号中的变量
<?php $name = 'zhangSan'; $msg = 'welcome $name'; echo $msg; //输出 welcome $name ?>
双引号
-
可以包含单引号,无须转义,但包含双引号时需要转义
php 会解析双引号间的变量
<?php $name = "zhangSan"; $msg = "welcome $name"; echo $msg; //输出 welcome zhangSan ?>
-
双引号中要解析的变量通常要用
{}
括起来<?php $name = "zhangSan"; $msg = "welcome {$name}"; echo $msg; //输出 welcome zhangSan ?>
定界符
-
使用情景
当需要定义大段字符串时,并且该字符串出现大量特殊字符(包括反引号、双引号等)
-
定界符定义字符串中的单双引号、大部分特殊字符不需要转义
-
<<< 标志
表示定界符开始,同样的标志;
为结束标识符,定界符结束要顶格,分号之后的此行不可有任何字符(包括空字符) -
定界符中的标志建议使用纯大写字母
-
定界符中的
$
同样会被识别为变量,变量名要用{}
括起来<?php $name = "gjl"; $msg = <<<GJL <h1>My Name is <span style = "color:pink">{$name}</span>!</h1> <script> console.log( 'This message is from info.php! ") </script> GJL; //若结束符后输入任何字符(包括空字符)则会报错Parse error: syntax error, unexpected $end echo $msg; ?>
输出效果
字符串拼接
-
在php中
.
表示拼接$a.$b
<?php $name = "zhangSan"; $message = "welcome,"; echo $message.$name; //输出 welcome,zhangSan ?>
常量
在php脚本执行期间,常量一旦本定义,就不能被改变或取消定义,常量的作用域是全局,有
bool
,int
,float
,string
类型
自定义常量
-
按照惯例常量标识符使用大写定义
-
使用函数
define()
定义<?php define("USERNAME","GJL"); //给常量 USERNAME赋值 GJL echo USERNAME; //输出结果 GJL ?>
尝试对其赋值报错
<?php define("USERNAME","GJL"); USER echo USERNAME; ?> // Parse error: syntax error, unexpected T_ECHO in E:\phpstudy\WWW\php\test.php on line 13
预定义常量
总览
-
PHP已经定义好的,可以直接使用的常量,一般代表特殊含义。
魔术常量是预定义常量中特殊的一类
常量名 常量值 __FILE__
当前文件名,完整路径 __LINE__
当前行号 __FUNCTION__
当前函数名 __CLASS__
当前的类名 __NETHOD__
当前对象的方法名 PHP_OS UNIX | WINNT | Darwin PHP_VERSION 当前 PHP 的版本 DIRECTORY_SEPARATOR \
或/
,根据操作系统决定目录的分隔符
使用
__FILE__
当前文件名,完整路径
<?php
echo __FILE__;
//输出效果 E:\phpstudy\WWW\test.php
?>
__LINE__
当前行号
<?php
echo __LINE__;
//输出效果 2
?>
PHP_OS
操作系统
<?php
echo PHP_OS;
//输出效果 WINNT
?>
PHP_VERSION
当前 PHP 的版本
<?php
echo PHP_VERSION;
//输出效果 5.3.29
?>
DIRECTORY_SEPARATOR
当前目录的分隔符
<?php
echo DIRECTORY_SEPARATOR;
//输出效果 \
?>
常见的运算符
算数运算符
-
除加
+
减-
乘*
除/
取余%
外对
$a
和$b
的运算运算符 计算 结果 -$a
取反 $a 的负值 ++$a
前加 $a 的值+1,然后返回 $a $a++
后加 返回 $a,然后将 $a 的值+1 --$a
前减 $a 的值-1,然后返回 $a $a--
后减 返回 $a,然后将 $a 的值-1
字符串运算符
-
字符串运算符用来拼接字符串
-
JS 语言中,字符串拼接用
+
,预算符.
的作用是访问对象中的属性或方法 -
PHP 中使用
.
进行字符串拼接。PHP 中.
也叫连接运算符<?php $name = "Jucy"; $str = "hello,"; echo $str.$name; //输出效果 hello,Jucy ?>
-
赋值运算符
-
包括
=
,+=
,-=
,*=
,/=
,%=
,.=
-
解释 :
$a ?= $b
即$a = $a ? $b
-
.=
<?php $a = "hello,"; $b = "LiHua"; $a .= $b; echo $a; //输出 hello,LiHua ?>
-
示例
<?php $a = 5; $b = 3; $a *= $b; echo $a; // 输出结果 15 //解释 第四行代码即 $a = $a * $b ?>
比较运算符
-
运算结果为布尔类型
true
或false
运算符 | 说明 | 备注 |
---|---|---|
== | 等于 | 执行== 运算时要求运算符两边的数据类型一致自动强制类型转换 |
=== | 全等 | 全等判断时若两边数据类型不同则直接返回false |
!= | 不等 | |
<> | 不等 | |
!== | 不全等 | |
< | 小于 | |
> | 大于 | |
<= | 小于等于 | |
>= | 大于等于 |
<?php
$a = 3;
$b = 3;
$c = '3';
$j1 = $a == $b;
echo var_dump($j1);
//输出 bool(true)
$j2 = $a === $b;
echo var_dump($j2);
//输出 bool(true)
$j3 = $a == $c;
echo var_dump($j3);
//输出 bool(true)
$j4 = $a === $c;
echo var_dump($j4);
//输出 bool(false)
?>
逻辑运算符
逻辑运算符 | 例子 | 解释 | 运算符规则 |
---|---|---|---|
and && | $a and $b $a && $b | 逻辑"与" | |
or ` | ` | $a or $b `$a | |
xor | $a xor $b | 逻辑"异或" | 相同为假,不同为真 |
! | !$a | 逻辑"非" |
其他运算符
运算符 | 名称 | 举例 | 解释 |
---|---|---|---|
?: | 三目运算 | $a > $b ? $a : $b | 如果 $a > $b 是真值则返回 $a (前)如果 $a > $b 是假值则返回 $b (后) |
`` | 反引号(esc键下方) | 自动调用系统命令 | |
@ | 错误屏蔽 | 屏蔽表达式可能发生的错误 |
-
?:
判断条件 ? true : false
<?php $a = 10; $b = 20; $max = $a > $b ? $a : $b; echo $max; //输出结果 20 //$a > $b是假值,返回$b ?>
-
``
<?php $str = "chcp65001&&ipconfig"; echo `$str`; ?>
输出
格式化输出
<?php $str = "ipconfig"; echo '<pre>'.`$str`; ?>
输出效果
-
@
<?php echo $username; //报错 Notice: Undefined variable: username in E:\phpstudy\WWW\test.php on line 2 echo @$username; //不会报错 ?>
流程控制
顺序执行
-
自上而下顺序执行
默认
<?php echo "1"; echo "<br />"; echo "2"; echo "<br />"; echo "3"; echo "<br />"; ?>
分支执行
-
根据表达式的值是否为 True 选择性执行代码
-
主要通过 if 和 switch 实现
-
进行 if 判断的时,候如果表达式不是布尔类型的值,会自动进行类型转换,将其它类型的值转换成布尔值,以下值被认为是
false
,其他大部分的值则被认为是true
bool(false) int(0) float(0) string(0)"" string(1)"0" array(0){} NULL
if 语句
-
语法
if(//判断条件){ //语句块1 }elseif(//判断条件2){ //语句块2 }else{ //语句块3 } //判断条件为True则执行语句块1,否则执行语句块2
如
<?php $score = 99; if(60 <= $score && $score < 90){ echo "ok"; }elseif($score >=90){ echo "nb"; }else{ echo "lj"; } //输出 nb ?>
switch 语句
-
当需要多项分支结构,并且判断条件是具体某个值,此时大多使用 switch 结构
switch(判断条件){ case 值1: 语句块; break; case 值2: 语句块; break; default: //默认,相当于if中的else 语句块; break; }
如
<?php $day = 1; switch($day){ case 1: echo "Monday"; break; case 2: echo "Tuesday"; break; case 8: case 9: echo "gun"; break; } //输出 Monday ?>
-
注意
- 每个 case 语句都需要加一个 break;
- case表达式的值最好是整型或字符串
- 如果某个 case 后没有接语句块,该判断条件要执行的语句块与下一判断条件所要执行的语句块相同
- case 后的语句块不需要用 {} 括起来
循环执行
while 循环
-
语法
while(表达式){ //循环体 }
当表达式为 True 时执行循环体,当循环体执行完一遍时,返回到 while 后的表达式继续判断表达式的值是否为 True ,如果还是 True 则继续循环,直到这个表达式的值为 False ,则该 while 循环结束
-
举例
输出 1 到 100 数字
<?php $i = 1; while($i <= 100){ echo $i."<br />"; $i++; } ?>
do while 循环
-
语法
<?php do{ //循环体 }while(条件) ?>
-
举例
输出 1 到 100 数字
<?php $i = 1; do{ echo $i."<br />"; $i ++; }while($i <= 100) ?>
for 循环
-
语法
for(计数器;判断条件;自增或自减){ //循环体 }
-
举例
输出 1 到 100 数字
<?php for($i=1;$i<=100;$i++){ echo $i."<br />"; } ?>
特殊的流程控制语句
break 语句
- 用于
switch
,while
,do...while
,foreach
等的终端。后面可以接上一些数字表示跳出几层循环。默认不加就是跳出当前循环。
continue
- 只能用于循环语句,轮空本次循环
exit 函数
-
结束当前 PHP 脚本执行,同
die()
语句exit 中可以输入语句进行输出
exit("php is over")