Web---PHP

本贴最后更新于 319 天前,其中的信息可能已经时异事殊
  1. PHP 学习 PHP 教程 | 菜鸟教程 (runoob.com)

  2. PHP,有两种在浏览器输出文本的基础指令:echo 和 print。

  3. function 关键字是用来定义函数的

  4. echo "
    "; 函数换行

  5. image

  6. global 在 function 函数定义里引用全局变量

  7. PHP 将所有全局变量存储在一个名为 $GLOBALS[index] 的数组中。

  8. Static 作用域

    当一个函数完成时,它的所有变量通常都会被删除。然而,有时候您希望某个局部变量不要被删除。

    要做到这一点,请在您第一次声明变量时使用 static 关键字:static $x=0;

  9. array() 创建数组。 eg:cars[0]`​=Volvo

  10. PHP 支持以下几种数据类型:

    • String(字符串)
    • Integer(整型)
    • Float(浮点型)
    • Boolean(布尔型)
    • Array(数组)
    • Object(对象)
    • NULL(空值)
    • Resource(资源类型)
  11. var_dump() 函数用于输出变量的相关信息。

    --$x = 5985; int(5985)

    --$b = 3.1; float(3.1)

    --cars); array(3) { [0]=> string(5) "Volvo" [1]=> string(3) "BMW" [2]=> string(6) "Toyota" }

  12. NULL 值表示变量没有值。NULL 是数据类型为 NULL 的值。

  13. var/public/private/protected 定义变量

    --其中 public 可以在全局变量下进行使用

    --private 只能在内部类的选择器中进行使用 不允许子类访问

    --protected 允许子类访问

  14. get_object_vars — 获取指定对象的属性 eg:get_object_vars(object $object​): array

  15. PHP __construct():构造函数/方法

    #创建构造函数的语法格式如下: public function \_\_construct(参数列表){ ... ... }

    #注意:如果显式地声明构造函数,那么它的访问权限必须是 public,而且构造函数是在实例 化时自动调用的,我们不需要手动调用。

  16. get_resource_type() 函数可以返回资源(resource)类型:
    get_resource_type(resource $handle): string

  17. PHP 类型比较

    虽然 PHP 是弱类型语言,但也需要明白变量类型及它们的意义,因为我们经常需要对 PHP 变量进行比较,包含松散和严格比较。

    • 松散比较:使用两个等号 == 比较,只比较值,不比较类型。
    • 严格比较:用三个等号 === 比较,除了比较值,也比较类型。

    例如,"42" 是一个字符串而 42 是一个整数。FALSE 是一个布尔值而 "FALSE" 是一个字符串。

  18. Bool 类型 PHP 之 Bool 类型_env bool-CSDN 博客

  19. strlen() 函数返回字符串的长度(字节数)。

    --echo strlen("Hello world!"); ---12

  20. strpos() 函数用于在字符串内查找一个字符或一段指定的文本。

    image

  21. PHP 运算符

    ---- ~x 取反

    ~1=-2; ~0=-1;
    <?php $x = 2; echo ~$x; ?>

    -3(结果)

    a . b 并置 连接两个字符串 " Hi" . "Ha" HiHa

    ---- 整除运算符 intdiv(),该函数返回值为第一个参数除于第二个参数的值并取整(向下取整)

    PHP 递增/递减运算符

    运算符 名称 描述
    ++ x 预递增 x 加 1,然后返回 x
    x ++ 后递增 返回 x,然后 x 加 1
    -- x 预递减 x 减 1,然后返回 x
    x -- 后递减 返回 x,然后 x 减 1

    PHP 逻辑运算符

    运算符 名称 描述 实例
    x and y 如果 x 和 y 都为 true,则返回 true x=6
    y=3
    (x < 10 and y > 1) 返回 true
    x or y 如果 x 和 y 至少有一个为 true,则返回 true x=6
    y=3
    (x==6 or y==5) 返回 true
    x xor y 异或 如果 x 和 y 有且仅有一个为 true,则返回 true x=6
    y=3
    (x==6 xor y==3) 返回 false
    x && y 如果 x 和 y 都为 true,则返回 true x=6
    y=3
    (x < 10 && y > 1) 返回 true
    x || y 如果 x 和 y 至少有一个为 true,则返回 true x=6
    y=3
    (x==5 || y==5) 返回 false
    ! x 如果 x 不为 true,则返回 true x=6
    y=3
    !(x==y) 返回 true

    PHP 数组运算符

    运算符 名称 描述
    x + y 集合 x 和 y 的集合
    x == y 相等 如果 x 和 y 具有相同的键/值对,则返回 true
    x === y 恒等 如果 x 和 y 具有相同的键/值对,且顺序相同类型相同,则返回 true
    x != y 不相等 如果 x 不等于 y,则返回 true
    x <> y 不相等 如果 x 不等于 y,则返回 true
    x !== y 不恒等 如果 x 不等于 y,则返回 true

    组合比较符(PHP7+)

    格式如下:

    \$c \= \$a <\=> \$b;

    解析如下:

    • 如果** b , 则 $c 的值为 1。
    • 如果 b, 则 $c 的值为 0
    • 如果 KaTeX parse error: Expected 'EOF', got '&' at position 3: a &̲lt;** **b, 则 $c 的值为 -1
  22. date("H") 当前时间

  23. PHP - if...elseif....else 语句

    在若干条件之一成立时执行一个代码块,请使用 if....elseif...else 语句。.

    语法

    if (条件) { if 条件成立时执行的代码; } elseif (条件) { elseif 条件成立时执行的代码; } else { 条件不成立时执行的代码; }
  24. PHP Switch 语句

    如果您希望有选择地执行若干代码块之一,请使用 switch 语句。

    语法

    参数说明:

    • expression​ 是要被比较的表达式。
    • case value:​ 是可能的值,如果 expression​ 的值等于某个 case​ 的值,就执行相应的代码块。
    • break;​ 用于终止 switch​ 语句,防止继续执行下一个 case​。
    • default:​ 是可选的,用于指定当没有匹配的 case​ 时执行的代码块。
  25. 获取数组的长度 - count() 函数

    count() 函数用于返回数组的长度(元素的数量):

    实例

    运行返值:3

  26. 遍历关联数组

    遍历并打印关联数组中的所有值,您可以使用 foreach 循环,如下所示:

    实例

    "35","Ben"=>"37","Joe"=>"43"); foreach($age as $x=>$x_value) { echo "Key=" . $x . ", Value=" . $x_value; echo "
    "; } ?>

    运行结果:

    Key=Peter, Value=35
    Key=Ben, Value=37
    Key=Joe, Value=43

  27. foreach 循环

    foreach 循环用于遍历数组。

  28. urldecode 函数
    url 解码是 % + ascii 的十六进制如:
    例一:%25 :25 就是十六进制的 % ,整个解码就是 %
    例二:%61 :61 是十六进制的 a : 整个解码就是 a

  29. id 万能密码

    /?id=' or ''='
  30. strpos() 函数

    echo strpos("I love php, I love php too!","php") -----7

    strpos 匹配,若返回位置为 0,不进入 if 语句

  31. image

    字符串与数字进行比较,从前往后一个字符一个字符进行比较,当与被比较者(数字)不一致时,后面字符全部舍去。

    第五个 0*10 的多少次方,科学计数法,前面都是 0 记为 true

  32. PHP extract() 函数

    -实例

    将键值 "Cat"、"Dog" 和 "Horse" 赋值给变量 b 和 $c:

    "Cat","b" => "Dog", "c" => "Horse"); extract($my_array); echo "\$a = $a; \$b = $b; \$c = $c"; ?>

    -结果b = Dog; $c = Horse

  33. parse_str() 函数

    -实例

    "; echo $age; ?>

    -结果:Peter
    43

  34. strrev() 函数

    -实例

    -结果:!iahgnahS evol I

  35. str_rot13() 函数

    str_rot13(string): 对字符串执行 ROT13 编码。

  36. ord() 函数

    ord() 函数是 chr() 函数(对于 8 位的 ASCII 字符串)或 unichr() 函数(对于 Unicode 对象)的配对函数,它以一个字符(长度为 1 的字符串)作为参数,返回对应的 ASCII 数值,或者 Unicode 数值,如果所给的 Unicode 字符超出了你的 Python 定义范围,则会引发一个 TypeError 的异常。

    • ord(string): 返回字符串首个字符的 ASCII 值

    语法

    以下是 ord() 方法的语法:

    ord(c)

    参数

    • c -- 字符。

    返回值

    返回值是对应的十进制整数。


    实例

    以下展示了使用 ord() 方法的实例:

    ord('a')97>>> ord('b')98>>> ord('c')99

  37. chr() 函数

    • chr(): 从指定的 ASCII 值返回对应的字符

    从不同的 ASCII 值返回字符:

    <?php echo chr(61) . "<br>"; // 十进制 = echo chr(061) . "<br>"; // 八进制值 1 echo chr(0x61) . "<br>"; // 十六进制值 a ?>
  38. PHP 序列化和反序列化

    CTF 题目时绕过的方法就是:先序列化字符串,然后使序列化后字符串中属性的个数大于真实对象中属性的个数,即可绕过

    1、序列化
    将一个对象转换为字符串
    2、反序列化
    将一个字符串恢复成对象

    深度剖析 PHP 序列化和反序列化 - 悠悠 uusama - 博客园 (cnblogs.com)

    PHP 序列化与反序列化(__sleep 与__wakeup)_php7.4.33 反序列化 wakeup-CSDN 博客

    $number = 34; $str = 'uusama'; $bool = true; $null = NULL; $arr = array('a' => 1, 'b' => 2); $cc = new CC('uu', true); var_dump(serialize($number)); var_dump(serialize($str)); var_dump(serialize($bool)); var_dump(serialize($null)); var_dump(serialize($arr)); var_dump(serialize($cc));

    输出结果为:

    string(5) "i:34;" string(13) "s:6:"uusama";" string(4) "b:1;" string(2) "N;" string(30) "a:2:{s:1:"a";i:1;s:1:"b";i:2;}" string(52) "O:2:"CC":2:{s:4:"data";s:2:"uu";s:8:" CC pass";b:1;}"

    所以序列化对于不同类型得到的字符串格式为:

    • String​ : s:size:value;
    • Integer​ : i:value;
    • Boolean​ : b:value;(保存 1 或 0)
    • Null​ : N;
    • Array​ : a:size:
    • Object​ : O:strlen(object name):object name:object size:
  39. PHP2 是服务器端脚本语言,主要用于处理和生成网页的内容,当用户访问一个网站时,PHP 脚本会在服务器上执行,生成动态的 HTML 页面,然后将页面发送给用户的浏览器进行显示。

    按照这个思路找到 php 脚本的路径,保存在什么文件;

    php 文件源代码通常在 phps 文件

    常见的 PHP 脚本通常是保存在以 .php为扩展名的文件上。这些文件可以存储在 web 服务器的文档根目录中,以便通过浏览器访问和执行;经典的示例文件名:可能是 index.php script.php

    【攻防世界】PHP2_攻防世界 php2-CSDN 博客 url 解码

  40. 执行文件读取功能

    https://www.php.net/manual/zh/wrappers.php.php

    convert.base64-encode 执行 Base64 编码功能~

    /resource=/var/www/html/flag 填写 flag.php 所在的地址,本题在源码的第 5 行有提示地址为 language in /var/www/html/index.php on line ;且需要注意注意源码第 23 行的内容(@include($lan.".php"); ),在上传参数时代码会附带后缀.php,所以此处不需要写为 '/var/www/html/flag.php'~
    https://blog.csdn.net/weixin_42789937/article/details/127956777

  41. _COOKIE['language'];

    在 cookie 中的内容 language 会被传到变量KaTeX parse error: Expected 'EOF', got '&' at position 42: …so/search?q=lan&̲spm=1001.2101.3…lan.".php");** 被调用与执行,因此 cookie 变量中很适合写入读取 flag.php 的 payload~

  42. PHP isset() 函数

    isset() 函数用于检测变量是否已设置并且非 NULL。

    如果已经使用 unset() 释放了一个变量之后,再通过 isset() 判断将返回 FALSE。

    若使用 isset() 测试一个被设置成 NULL 的变量,将返回 FALSE。

    同时要注意的是 null 字符("\0")并不等同于 PHP 的 NULL 常量。

    Web 安全攻防世界 02 fileclude(ctf)_fileinclude 攻防世界-CSDN 博客

  43. PHP intval() 函数

    intval() 函数用于获取变量的整数值。

    intval() 函数通过使用指定的进制 base 转换(默认是十进制),返回变量 var 的 integer 数值。 intval() 不能用于 object,否则会产生 E_NOTICE 错误并返回 1。

    intval(‘1e5’)就是 10000 ,科学计数法表示的 1e7/8/9 可以满足上述三个条件。

  • PHP

    PHP(Hypertext Preprocessor)是一种开源脚本语言。语法吸收了 C 语言、 Java 和 Perl 的特点,主要适用于 Web 开发领域,据说是世界上最好的编程语言。

    167 引用 • 408 回帖 • 485 关注

相关帖子

回帖

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • Sillot

    Insights(注意当前设置 master 为默认分支)

    汐洛彖夲肜矩阵(Sillot T☳Converbenk Matrix),致力于服务智慧新彖乄,具有彖乄驱动、极致优雅、开发者友好的特点。其中汐洛绞架(Sillot-Gibbet)基于自思源笔记(siyuan-note),前身是思源笔记汐洛版(更早是思源笔记汐洛分支),是智慧新录乄终端(多端融合,移动端优先)。

    主仓库地址:Hi-Windom/Sillot

    文档地址:sillot.db.sc.cn

    注意事项:

    1. ⚠️ 汐洛仍在早期开发阶段,尚不稳定
    2. ⚠️ 汐洛并非面向普通用户设计,使用前请了解风险
    3. ⚠️ 汐洛绞架基于思源笔记,开发者尽最大努力与思源笔记保持兼容,但无法实现 100% 兼容
    29 引用 • 25 回帖 • 133 关注
  • jsDelivr

    jsDelivr 是一个开源的 CDN 服务,可为 npm 包、GitHub 仓库提供免费、快速并且可靠的全球 CDN 加速服务。

    5 引用 • 31 回帖 • 108 关注
  • C++

    C++ 是在 C 语言的基础上开发的一种通用编程语言,应用广泛。C++ 支持多种编程范式,面向对象编程、泛型编程和过程化编程。

    108 引用 • 153 回帖
  • 互联网

    互联网(Internet),又称网际网络,或音译因特网、英特网。互联网始于 1969 年美国的阿帕网,是网络与网络之间所串连成的庞大网络,这些网络以一组通用的协议相连,形成逻辑上的单一巨大国际网络。

    98 引用 • 367 回帖
  • MongoDB

    MongoDB(来自于英文单词“Humongous”,中文含义为“庞大”)是一个基于分布式文件存储的数据库,由 C++ 语言编写。旨在为应用提供可扩展的高性能数据存储解决方案。MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。它支持的数据结构非常松散,是类似 JSON 的 BSON 格式,因此可以存储比较复杂的数据类型。

    91 引用 • 59 回帖
  • Visio
    1 引用 • 2 回帖 • 2 关注
  • Docker

    Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的操作系统上。容器完全使用沙箱机制,几乎没有性能开销,可以很容易地在机器和数据中心中运行。

    497 引用 • 934 回帖
  • Electron

    Electron 基于 Chromium 和 Node.js,让你可以使用 HTML、CSS 和 JavaScript 构建应用。它是一个由 GitHub 及众多贡献者组成的活跃社区共同维护的开源项目,兼容 Mac、Windows 和 Linux,它构建的应用可在这三个操作系统上面运行。

    15 引用 • 136 回帖 • 1 关注
  • 小说

    小说是以刻画人物形象为中心,通过完整的故事情节和环境描写来反映社会生活的文学体裁。

    32 引用 • 108 回帖
  • 前端

    前端技术一般分为前端设计和前端开发,前端设计可以理解为网站的视觉设计,前端开发则是网站的前台代码实现,包括 HTML、CSS 以及 JavaScript 等。

    246 引用 • 1338 回帖
  • OkHttp

    OkHttp 是一款 HTTP & HTTP/2 客户端库,专为 Android 和 Java 应用打造。

    16 引用 • 6 回帖 • 88 关注
  • CSS

    CSS(Cascading Style Sheet)“层叠样式表”是用于控制网页样式并允许将样式信息与网页内容分离的一种标记性语言。

    198 引用 • 543 回帖 • 2 关注
  • ZeroNet

    ZeroNet 是一个基于比特币加密技术和 BT 网络技术的去中心化的、开放开源的网络和交流系统。

    1 引用 • 21 回帖 • 649 关注
  • Pipe

    Pipe 是一款小而美的开源博客平台。Pipe 有着非常活跃的社区,可将文章作为帖子推送到社区,来自社区的回帖将作为博客评论进行联动(具体细节请浏览 B3log 构思 - 分布式社区网络)。

    这是一种全新的网络社区体验,让热爱记录和分享的你不再感到孤单!

    134 引用 • 1127 回帖 • 110 关注
  • Mobi.css

    Mobi.css is a lightweight, flexible CSS framework that focus on mobile.

    1 引用 • 6 回帖 • 766 关注
  • 叶归
    13 引用 • 59 回帖 • 22 关注
  • Redis

    Redis 是一个开源的使用 ANSI C 语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value 数据库,并提供多种语言的 API。从 2010 年 3 月 15 日起,Redis 的开发工作由 VMware 主持。从 2013 年 5 月开始,Redis 的开发由 Pivotal 赞助。

    284 引用 • 248 回帖
  • Thymeleaf

    Thymeleaf 是一款用于渲染 XML/XHTML/HTML5 内容的模板引擎。类似 Velocity、 FreeMarker 等,它也可以轻易的与 Spring 等 Web 框架进行集成作为 Web 应用的模板引擎。与其它模板引擎相比,Thymeleaf 最大的特点是能够直接在浏览器中打开并正确显示模板页面,而不需要启动整个 Web 应用。

    11 引用 • 19 回帖 • 395 关注
  • NGINX

    NGINX 是一个高性能的 HTTP 和反向代理服务器,也是一个 IMAP/POP3/SMTP 代理服务器。 NGINX 是由 Igor Sysoev 为俄罗斯访问量第二的 Rambler.ru 站点开发的,第一个公开版本 0.1.0 发布于 2004 年 10 月 4 日。

    315 引用 • 547 回帖 • 1 关注
  • 黑曜石

    黑曜石是一款强大的知识库工具,支持本地 Markdown 文件编辑,支持双向链接和关系图。

    A second brain, for you, forever.

    25 引用 • 254 回帖
  • 宕机

    宕机,多指一些网站、游戏、网络应用等服务器一种区别于正常运行的状态,也叫“Down 机”、“当机”或“死机”。宕机状态不仅仅是指服务器“挂掉了”、“死机了”状态,也包括服务器假死、停用、关闭等一些原因而导致出现的不能够正常运行的状态。

    13 引用 • 82 回帖 • 77 关注
  • NetBeans

    NetBeans 是一个始于 1997 年的 Xelfi 计划,本身是捷克布拉格查理大学的数学及物理学院的学生计划。此计划延伸而成立了一家公司进而发展这个商用版本的 NetBeans IDE,直到 1999 年 Sun 买下此公司。Sun 于次年(2000 年)六月将 NetBeans IDE 开源,直到现在 NetBeans 的社群依然持续增长。

    78 引用 • 102 回帖 • 713 关注
  • 服务器

    服务器,也称伺服器,是提供计算服务的设备。由于服务器需要响应服务请求,并进行处理,因此一般来说服务器应具备承担服务并且保障服务的能力。

    125 引用 • 585 回帖 • 1 关注
  • 书籍

    宋真宗赵恒曾经说过:“书中自有黄金屋,书中自有颜如玉。”

    84 引用 • 414 回帖
  • Hexo

    Hexo 是一款快速、简洁且高效的博客框架,使用 Node.js 编写。

    22 引用 • 148 回帖 • 9 关注
  • V2Ray
    1 引用 • 15 回帖 • 4 关注
  • Maven

    Maven 是基于项目对象模型(POM)、通过一小段描述信息来管理项目的构建、报告和文档的软件项目管理工具。

    188 引用 • 319 回帖 • 237 关注