Web---PHP

本贴最后更新于 304 天前,其中的信息可能已经时异事殊
  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 回帖 • 489 关注

相关帖子

回帖

欢迎来到这里!

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

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

推荐标签 标签

  • Google

    Google(Google Inc.,NASDAQ:GOOG)是一家美国上市公司(公有股份公司),于 1998 年 9 月 7 日以私有股份公司的形式创立,设计并管理一个互联网搜索引擎。Google 公司的总部称作“Googleplex”,它位于加利福尼亚山景城。Google 目前被公认为是全球规模最大的搜索引擎,它提供了简单易用的免费服务。不作恶(Don't be evil)是谷歌公司的一项非正式的公司口号。

    49 引用 • 192 回帖
  • 爬虫

    网络爬虫(Spider、Crawler),是一种按照一定的规则,自动地抓取万维网信息的程序。

    106 引用 • 275 回帖
  • 程序员

    程序员是从事程序开发、程序维护的专业人员。

    589 引用 • 3528 回帖
  • V2Ray
    1 引用 • 15 回帖 • 4 关注
  • 国际化

    i18n(其来源是英文单词 internationalization 的首末字符 i 和 n,18 为中间的字符数)是“国际化”的简称。对程序来说,国际化是指在不修改代码的情况下,能根据不同语言及地区显示相应的界面。

    8 引用 • 26 回帖 • 2 关注
  • Hexo

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

    22 引用 • 148 回帖 • 7 关注
  • 资讯

    资讯是用户因为及时地获得它并利用它而能够在相对短的时间内给自己带来价值的信息,资讯有时效性和地域性。

    56 引用 • 85 回帖 • 1 关注
  • H2

    H2 是一个开源的嵌入式数据库引擎,采用 Java 语言编写,不受平台的限制,同时 H2 提供了一个十分方便的 web 控制台用于操作和管理数据库内容。H2 还提供兼容模式,可以兼容一些主流的数据库,因此采用 H2 作为开发期的数据库非常方便。

    11 引用 • 54 回帖 • 670 关注
  • JRebel

    JRebel 是一款 Java 虚拟机插件,它使得 Java 程序员能在不进行重部署的情况下,即时看到代码的改变对一个应用程序带来的影响。

    26 引用 • 78 回帖 • 677 关注
  • Love2D

    Love2D 是一个开源的, 跨平台的 2D 游戏引擎。使用纯 Lua 脚本来进行游戏开发。目前支持的平台有 Windows, Mac OS X, Linux, Android 和 iOS。

    14 引用 • 53 回帖 • 562 关注
  • 酷鸟浏览器

    安全 · 稳定 · 快速
    为跨境从业人员提供专业的跨境浏览器

    3 引用 • 59 回帖 • 49 关注
  • 前端

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

    246 引用 • 1338 回帖
  • 新人

    让我们欢迎这对新人。哦,不好意思说错了,让我们欢迎这位新人!
    新手上路,请谨慎驾驶!

    52 引用 • 228 回帖 • 1 关注
  • jQuery

    jQuery 是一套跨浏览器的 JavaScript 库,强化 HTML 与 JavaScript 之间的操作。由 John Resig 在 2006 年 1 月的 BarCamp NYC 上释出第一个版本。全球约有 28% 的网站使用 jQuery,是非常受欢迎的 JavaScript 库。

    63 引用 • 134 回帖 • 734 关注
  • V2EX

    V2EX 是创意工作者们的社区。这里目前汇聚了超过 400,000 名主要来自互联网行业、游戏行业和媒体行业的创意工作者。V2EX 希望能够成为创意工作者们的生活和事业的一部分。

    16 引用 • 236 回帖 • 248 关注
  • CentOS

    CentOS(Community Enterprise Operating System)是 Linux 发行版之一,它是来自于 Red Hat Enterprise Linux 依照开放源代码规定释出的源代码所编译而成。由于出自同样的源代码,因此有些要求高度稳定的服务器以 CentOS 替代商业版的 Red Hat Enterprise Linux 使用。两者的不同在于 CentOS 并不包含封闭源代码软件。

    240 引用 • 224 回帖 • 3 关注
  • Sublime

    Sublime Text 是一款可以用来写代码、写文章的文本编辑器。支持代码高亮、自动完成,还支持通过插件进行扩展。

    10 引用 • 5 回帖 • 3 关注
  • 禅道

    禅道是一款国产的开源项目管理软件,她的核心管理思想基于敏捷方法 scrum,内置了产品管理和项目管理,同时又根据国内研发现状补充了测试管理、计划管理、发布管理、文档管理、事务管理等功能,在一个软件中就可以将软件研发中的需求、任务、bug、用例、计划、发布等要素有序的跟踪管理起来,完整地覆盖了项目管理的核心流程。

    10 引用 • 15 回帖 • 5 关注
  • TGIF

    Thank God It's Friday! 感谢老天,总算到星期五啦!

    291 引用 • 4495 回帖 • 662 关注
  • JetBrains

    JetBrains 是一家捷克的软件开发公司,该公司位于捷克的布拉格,并在俄国的圣彼得堡及美国麻州波士顿都设有办公室,该公司最为人所熟知的产品是 Java 编程语言开发撰写时所用的集成开发环境:IntelliJ IDEA

    18 引用 • 54 回帖 • 2 关注
  • 黑曜石

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

    A second brain, for you, forever.

    24 引用 • 242 回帖
  • Tomcat

    Tomcat 最早是由 Sun Microsystems 开发的一个 Servlet 容器,在 1999 年被捐献给 ASF(Apache Software Foundation),隶属于 Jakarta 项目,现在已经独立为一个顶级项目。Tomcat 主要实现了 JavaEE 中的 Servlet、JSP 规范,同时也提供 HTTP 服务,是市场上非常流行的 Java Web 容器。

    162 引用 • 529 回帖 • 9 关注
  • Postman

    Postman 是一款简单好用的 HTTP API 调试工具。

    4 引用 • 3 回帖 • 3 关注
  • FlowUs

    FlowUs.息流 个人及团队的新一代生产力工具。

    让复杂的信息管理更轻松、自由、充满创意。

    1 引用 • 4 关注
  • webpack

    webpack 是一个用于前端开发的模块加载器和打包工具,它能把各种资源,例如 JS、CSS(less/sass)、图片等都作为模块来使用和处理。

    42 引用 • 130 回帖 • 253 关注
  • Wide

    Wide 是一款基于 Web 的 Go 语言 IDE。通过浏览器就可以进行 Go 开发,并有代码自动完成、查看表达式、编译反馈、Lint、实时结果输出等功能。

    欢迎访问我们运维的实例: https://wide.b3log.org

    30 引用 • 218 回帖 • 644 关注
  • 996
    13 引用 • 200 回帖 • 6 关注