PHP 10个常见面试题及答案

PHP 10个常见面试题及答案1 PHP 的基础知识点 PHP 中类的继承属于单继承 一个子类只能继承一个父类 可见性为 publicprotec 的属性和方法可以被继承 继承的方法或属性可以被重写 可见性越来越大 PHP 中的变量名区分大小写 但类名 函数名不区分大小写 2 error reporting 函数的作用 error reporting 函数的作用是临时设置脚本执行过程中的错

1. PHP的基础知识点

PHP中类的继承属于单继承,一个子类只能继承一个父类。可见性为public protected的属性和方法可以被继承。
继承的方法或属性可以被重写,可见性越来越大。

PHP中的变量名区分大小写,但类名、函数名不区分大小写。

2. error_reporting()函数的作用

error_reporting()函数的作用是临时设置脚本执行过程中的错误报告级别。

error_reporting(E_ALL ^ E_NOTICE);   // 除了E_NOTICE之外,报告所有的错误

使用 error_reporting(0) 或者在函数前面加 @,可以抑制错误信息输出,以防止错误消息泄露敏感信息。

3. HTTP状态码

在HTTP1.1中,状态码401的含义是未经授权;如果想返回“找不到文件”,可使用header函数,语句为:header(“HTTP/1.1 404 Not Found”);

4. require和include的区别

include 引入文件,如果引入的文件发生错误,会产生一条警告信息,后续的代码会继续执行。

require引入文件,会更加严谨一些,如果引入的文件发生错误,会抛出一个致命的错误,并中断后续代码的执行。因此我们常常用require引入一个非常重要的文件。

5. 存储引擎 MyISAM 和 InnoDB的区别

MyISAM适合于一些需要大量查询的应用,但其对于有大量写操作并不是很好,MyISAM不支持事务、外键和行锁。MyISAM的每个数据表包括三个文件,分别是表的结构、表的索引和表的数据,表的索引和表的数据是分开存储的。

InnoDB在写操作比较多的时候会更优秀,InnoDB支持事务、外键和行锁。InnoDB的数据表包括两个文件,表的索引和数据存储在同一个文件中,默认是共享表空间,即所有数据表的索引和数据存储在同一个文件中,但也可以设置为独立表空间(若要对数据表采用分区技术,必须设置为独立表空间)。

6. 如何得到当前PHP脚本的路径(包括所有参数)?

echo “http://”.$_SERVER[‘HTTP_HOST’].$_SERVER[‘REQUEST_URI’];
echo ‘http://’.$_SERVER[‘HTTP_HOST’].$_SERVER[‘PHP_SELF’].’?’.$_SERVER[‘QUERY_STRING’];

7. 在php中不使用第三个变量,如何实现交换两个变量的值?



8. 自定义一个PHP函数,要求用冒泡排序对数组进行升序排列

=$arr[$j+1]){ $temp=$arr[$j+1]; $arr[$j+1]=$arr[$j]; $arr[$j]=$temp; } } } return $arr; }

9. 如何将a.txt文件里的内容追加到b.txt文件中?

file_put_contents(‘b.txt’, file_get_contents(‘a.txt’), FILE_APPEND);

10. 表单提交方式中的get和post有什么区别?

    get是表单的默认提交方式,会把数据附加到表单的action属性所指向的URL中,在URL中可见,安全性较差;post会把数据放到http的包体中,用户一般看不到,安全性较好。
    get传递的数据量受URL长度的限制,故数据量较小,一般只有几kb;而post传递的数据量受php.ini的限制,数据量较大,如果有文件上传的话,表单的提交方式一定要用post。
    get传递的数据会被缓存下来,可能有安全性问题,而post方式没有这个问题。
    get传递的数据通过$_GET[]获取,post传递的数据通过$_POST[]获取。

























































版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/173334.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月27日 上午9:01
下一篇 2026年3月27日 上午9:01


相关推荐

  • 【保姆级教程】:开源 Qwen3 本地化部署实操详细教程

    【保姆级教程】:开源 Qwen3 本地化部署实操详细教程

    2026年3月12日
    5
  • 阿里面试失败后,一气之下我图解了Java中18把锁「建议收藏」

    目录乐观锁和悲观锁独占锁和共享锁互斥锁和读写锁公平锁和非公平锁可重入锁自旋锁分段锁锁升级(无锁|偏向锁|轻量级锁|重量级锁)锁优化技术(锁粗化、锁消除)乐观锁和悲观锁悲观锁悲观锁对应于生活中悲观的人,悲观的人总是想着事情往坏的方向发展。举个生活中的例子,假设厕所只有一个坑位了,悲观锁上厕所会第一时间把门反锁上,这样其他人上厕所只能在门外等候,这种状态就是「阻塞」了。回到代码世界中,一个共享数据加了悲观锁,那线程每次想操作这个数据前都会假设其他线程.

    2022年4月18日
    41
  • 利用HashSet给list去重[通俗易懂]

    利用HashSet给list去重[通俗易懂]如果有一个string的list要去重,那么可以用以下代码:List<String>orgIds=……..//orgIds即可能存在重复数据的String的集合//利用HashSet去重Set<String>set=newHashSet<String>(orgIds);orgIds=newArrayList<String…

    2022年5月25日
    73
  • Python实战异步爬虫(协程)+分布式爬虫(多进程)

    Python实战异步爬虫(协程)+分布式爬虫(多进程)引言 我们在写爬虫时常会遇到这样的问题 当需要爬取多个 URL 时 写一个普通的基于 requests 库的爬虫程序爬取时间会很长 因为是顺序请求网页的 而网页请求和获得响应过程比较耗费时间 程序不得不等待获得当前网页响应后才能进行下一个 URL 的爬取 使得总耗时较多 对于这样的多任务 可以使用基于多进程 multiprocess 和基于 Asyncio 库的异步 协程 爬虫增强并发性 加速爬虫 T

    2026年3月19日
    2
  • linux怎么查看系统环境变量路径,Linux系统中的环境变量该如何设置与查看

    linux怎么查看系统环境变量路径,Linux系统中的环境变量该如何设置与查看今天小编要跟大家分享的文章是关于Linux系统中的环境变量该如何设置与查看。大家都知道,在Linux系统中,有环境变量和Shell变量这两种变量。环境变量是在程序及其子程序中全局可用的,常常用来储存像默认的文本编辑器或者浏览器,以及可执行文件的路径等等这样的信息。而Shell变量仅在当前Shell中可用,可以用来存储当前用户的ID等信息。那么什么是环境变量,什么是Shell变量…

    2022年10月1日
    5
  • 「VS Code」Visual Studio Code 菜鸟教程:从入门到精通

    「VS Code」Visual Studio Code 菜鸟教程:从入门到精通VisualStudio 或简称为 VSCode 是我最喜欢的代码编辑器 我希望能有更多人享受到 VSCode 的便捷与强大 然而已存教程不足以成为我们了解 VSCode 的窗口 很多具有广泛使用场景的功能 比如命令窗口和终端 这些教程都没有涉猎 该种情况促成了本文的诞生 本文希望 哪怕是从未使用过 VSCode 的读者 也能在阅读本文后便精通使用 VSCode

    2026年3月20日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号