PHP面试知识点

发布于 2021-09-04 14:32 ,所属分类:软件编程学习资料

这些是 PHP 面试经常被问到的知识点做汇总。仅是针对性指出知识点,相应的还需自己查找相关资料系统学习。我希望各位能不仅仅了解是什么,还要了解为什么,以及背后的原理。

如果你现在处于以下几种状态,本资料非常适合你:

  • 准备换工作,不知道从哪开始准备

  • 技术遇到瓶颈,不知道该学什么

  • 准备学 PHP,但不知道领域有多深

基础篇

  • 了解大部分数组处理函数

  • 字符串处理函数 区别 mb_ 系列函数

  • & 引用,结合案例分析

  • == 与 === 区别

  • isset 与 empty 区别

  • 全部魔术函数理解

  • static、$this、self 区别

  • private、protected、public、final 区别

  • OOP 思想

  • 抽象类、接口 分别使用场景

  • Trait 是什么东西

  • echo、print、print_r 区别 (区分出表达式与语句的区别)

  • __construct 与 __destruct 区别

  • static 作用(区分类与函数内)手册 、SOF

  • __toString () 作用

  • 单引号’与双引号” 区别

  • 常见 HTTP 状态码,分别代表什么含义

  • 301 什么意思 404 呢?

进阶篇

  • Autoload、Composer 原理 PSR-4 、原理

  • Session 共享、存活时间

  • 异常处理

  • 如何 foreach 迭代对象

  • 如何数组化操作对象 $obj [key];

  • 如何函数化对象 $obj (123);

  • yield 是什么,说个使用场景 yield

  • PSR 是什么,PSR-1, 2, 4, 7

  • 如何获取客户端 IP 和服务端 IP 地址

  • 客户端 IP

  • 服务端 IP

  • 了解代理透传 实际 IP 的概念

  • 如何开启 PHP 异常提示

  • php.ini 开启 display_errors 设置 error_reporting 等级

  • 运行时,使用 ini_set (k, v); 动态设置

  • 如何返回一个 301 重定向

  • [WARNING] 一定当心设置 301 后脚本会继续执行,不要认为下面不会执行,必要时使用 die or exit

  • 如何获取扩展安装路径

  • phpinfo (); 页面查找 extension_dir

  • 命令行 php -i |grep extension_dir

  • 运行时 echo ini_get (‘extension_dir’);

  • 字符串、数字比较大小的原理,注意 0 开头的 8 进制、0x 开头 16 进制

  • 字符串比较大小,从左 (高位) 至右,逐个字符 ASCII 比较

  • BOM 头是什么,怎么除去

  • 0xEF,0xBB,0xBF

  • 检测、去除

  • 什么是 MVC

  • 依赖注入实现原理

  • 如何异步执行命令

  • 模板引擎是什么,解决什么问题、实现原理(Smarty、Twig、Blade)

  • 如何实现链式操作 $obj->w ()->m ()->d ();

  • Xhprof 、Xdebug 性能调试工具使用

  • 索引数组 [1, 2] 与关联数组 [‘k1’=>1, ‘k2’=>2] 有什么区别

  • 缓存的使用方式、场景

实践篇

  • 给定二维数组,根据某个字段排序

  • 如何判断上传文件类型,如:仅允许 jpg 上传

  • 不使用临时变量交换两个变量的值 $a=1; $b=2; => $a=2; $b=1;

  • strtoupper 在转换中文时存在乱码,你如何解决?php echo strtoupper (‘ab 你好 c’);

  • Websocket、Long-Polling、Server-Sent Events (SSE) 区别

  • “Headers already sent” 错误是什么意思,如何避免

算法篇

  • 快速排序(手写)

  • 冒泡排序(手写)

  • 二分查找(了解)

  • 查找算法 KMP(了解)

  • 深度、广度优先搜索(了解)

  • LRU 缓存淘汰算法(了解,Memcached 采用该算法)

数据结构篇(了解)

  • 堆、栈特性

  • 队列

  • 哈希表

  • 链表

对比篇

  • Cookie 与 Session 区别

  • GET 与 POST 区别

  • include 与 require 区别

  • include_once 与 require_once 区别

  • Memcached 与 Redis 区别

  • MySQL 各个存储引擎、及区别(一定会问 MyISAM 与 Innodb 区别)

  • HTTP 与 HTTPS 区别

  • Apache 与 Nginx 区别

  • define () 与 const 区别

  • traits 与 interfaces 区别 及 traits 解决了什么痛点?

  • Git 与 SVN 区别

数据库篇

  • MySQL

  • 索引、联合索引(命中条件)

  • 分库分表(水平分表、垂直分表)

  • 分区

  • 会使用 explain 分析 SQL 性能问题,了解各参数含义

  • Slow Log(有什么用,什么时候需要)

  • 重点理解 type、rows、key

  • CRUD

  • JOIN、LEFT JOIN 、RIGHT JOIN、INNER JOIN

  • UNION

  • GROUP BY + COUNT + WHERE 组合案例

  • 常用 MySQL 函数,如:now ()、md5 ()、concat ()、uuid () 等

  • 1:1、1:n、n:n 各自适用场景

  • 了解触发器是什么,说个使用场景

  • 数据库优化手段

  • MSSQL (了解)

  • 查询最新 5 条数据

  • NOSQL

  • 持久化

  • 支持多种数据类型

  • 可利用 CPU 多核心

  • 内存淘汰机制

  • 集群 Cluster

  • 支持 SQL

  • 性能对比

  • 支持事务

  • 应用场景

  • Redis、Memcached、MongoDB

  • 对比、适用场景(可从以下维度进行对比)

  • 你之前为了解决什么问题使用的什么,为什么选它?

服务器篇

  • 查看 CPU、内存、时间、系统版本等信息

  • find 、grep 查找文件

  • awk 处理文本

  • 查看命令所在目录

  • 自己编译过 PHP 吗?如何打开 readline 功能

  • 如何查看 PHP 进程的内存、CPU 占用

  • 如何给 PHP 增加一个扩展

  • 修改 PHP Session 存储位置、修改 INI 配置参数

  • 负载均衡有哪几种,挑一种你熟悉的说明其原理

  • 数据库主从复制 M-S 是怎么同步的?是推还是拉?会不会不同步?怎么办

  • 如何保障数据的可用性,即使被删库了也能恢复到分钟级别。你会怎么做。

  • 数据库连接过多,超过最大值,如何优化架构。从哪些方便处理?

  • 502 大概什么什么原因?如何排查 504 呢?

架构篇

  • 偏运维(了解):

  • 负载均衡(Nginx、HAProxy、DNS)

  • 主从复制(MySQL、Redis)

  • 数据冗余、备份(MySQL 增量、全量 原理)

  • 监控检查(分存活、服务可用两个维度)

  • MySQL、Redis、Memcached Proxy 、Cluster 目的、原理

  • 分片

  • 高可用集群

  • RAID

  • 源代码编译、内存调优

  • 缓存

  • 工作中遇到哪里需要缓存,分别简述为什么

  • 搜索解决方案

  • 性能调优

  • 各维度监控方案

  • 日志收集集中处理方案

  • 国际化

  • 数据库设计

  • 静态化方案

  • 画出常见 PHP 应用架构图

框架篇

  • ThinkPHP(TP)、CodeIgniter(CI)、Zend(非 OOP 系列)

  • Yaf、Phalcon(C 扩展系)

  • Yii、Laravel、Symfony(纯 OOP 系列)

  • Swoole、Workerman (网络编程框架)

  • 对比框架区别几个方向点

  • 是否纯 OOP

  • 类库加载方式(自己写 autoload 对比 composer 标准)

  • 易用性方向(CI 基础框架,Laravel 这种就是高开发效率框架以及基础组件多少)

  • 黑盒(相比 C 扩展系)

  • 运行速度(如:Laravel 加载一大堆东西)

  • 内存占用

设计模式

  • 单例模式(重点)

  • 工厂模式(重点)

  • 观察者模式(重点)

  • 依赖注入(重点)

  • 装饰器模式

  • 代理模式

  • 组合模式

安全篇

  • SQL 注入

  • XSS 与 CSRF

  • 输入过滤

  • Cookie 安全

  • 禁用 mysql_ 系函数

  • 数据库存储用户密码时,应该是怎么做才安全

  • 验证码 Session 问题

  • 安全的 Session ID (让即使拦截后,也无法模拟使用)

  • 目录权限安全

  • 包含本地与远程文件

  • 文件上传 PHP 脚本

  • eval 函数执行脚本

  • disable_functions 关闭高危函数

  • FPM 独立用户与组,给每个目录特定权限

  • 了解 Hash 与 Encrypt 区别

高阶篇

  • PHP 数组底层实现 (HashTable + Linked list)

  • Copy on write 原理,何时 GC

  • PHP 进程模型,进程通讯方式,进程线程区别

  • yield 核心原理是什么

  • PDO prepare 原理

  • PHP 7 与 PHP 5 有什么区别

  • Swoole 适用场景,协程实现方式

前端篇

  • 原生获取 DOM 节点,属性

  • 盒子模型

  • CSS 文件、style 标签、行内 style 属性优先级

  • HTML 与 JS 运行顺序(页面 JS 从上到下)

  • JS 数组操作

  • 类型判断

  • this 作用域

  • .map () 与 this 具体使用场景分析

  • Cookie 读写

  • JQuery 操作

  • Ajax 请求(同步、异步区别)随机数禁止缓存

  • Bootstrap 有什么好处

  • 跨域请求 N 种解决方案

  • 新技术(了解)

  • ES6

  • 模块化

  • 打包

  • 构建工具

  • vue、react、webpack、

  • 前端 mvc

  • 优化

  • 浏览器单域名并发数限制

  • 静态资源缓存 304 (If-Modified-Since 以及 Etag 原理)

  • 多个小图标合并使用 position 定位技术 减少请求

  • 静态资源合为单次请求 并压缩

  • CDN

  • 静态资源延迟加载技术、预加载技术

  • keep-alive

  • CSS 在头部,JS 在尾部的优化(原理)

网络篇

  • IP 地址转 INT

  • 192.168.0.1/16 是什么意思

  • DNS 主要作用是什么?

  • IPv4 与 v6 区别

网络编程篇

  • TCP 三次握手流程

  • TCP、UDP 区别,分别适用场景

  • 有什么办法能保证 UDP 高可用性 (了解)

  • TCP 粘包如何解决?

  • 为什么需要心跳?

  • 什么是长连接?

  • HTTPS 是怎么保证安全的?

  • 流与数据报的区别

  • 进程间通信的几种方式,最快的是哪种?

  • fork () 会发生什么?

API 篇

  • RESTful 是什么

  • 如何在不支持 DELETE 请求的浏览器上兼容 DELETE 请求

  • 常见 API 的 APP_ID APP_SECRET 主要作用是什么?阐述下流程

  • API 请求如何保证数据不被篡改?

  • JSON 和 JSONP 的区别

  • 数据加密和验签的区别

  • RSA 是什么

  • API 版本兼容怎么处理

  • 限流(木桶、令牌桶)

  • OAuth 2 主要用在哪些场景下

  • JWT

  • PHP 中 json_encode ([‘key’=>123]); 与 return json_encode ([]); 区别,会产生什么问题?如何解决

相关资源