吐血整理40+个PHP面试题附答案(实战经验)php教程

1、什么事面向对象?主要特征是什么?

面向对象是程序的一种设计方式,它利于提高程序的重用性,使程序结构更加清晰。主要特征:封装、继承、多态。

2、SESSION与COOKIE的区别是什么,请从协议,产生的原因与作用说明

B、SESSION存储在服务器端,COOKIE保存在客户端。Session比较安全,cookie用某些手段可以修改,不安全。Session依赖于cookie进行传递。

禁用cookie后,session不能正常使用。Session的缺点:保存在服务器端,每次读取都从服务器进行读取,对服务器有资源消耗。Session保存在服务器端的文件或数据库中,默认保存在文件中,文件路径由php配置文件的session.save_path指定。Session文件是公有的。

3、HTTP状态中302、403、500代码含义?

一二三四五原则:(即一:消息系列;二:成功系列;三:重定向系列;四:请求错误系列;五:服务器端错误系列。)

302:临时转移成功,请求的内容已转移到新位置

403:禁止访问

500:服务器内部错误

4、请写出数据类型(intcharvarchardatetimetext)的意思;请问varchar和char有什么区别?

5、MyISAM和InnoDB的基本区别?索引结构如何实现?

A、MyISAM类型不支持事务,表锁,易产生碎片,要经常优化,读写速度较快,适合用于频繁查询的应用;

B、InnoDB类型支持事务,行锁,有崩溃恢复能力,读写速度比MyISAM慢,适合于插入和更新操作比较多的应用,空间占用大,不支持全文索引等。创建索引:alerttabletablenameaddindex索引名(`字段名`)

6、isset()和empty()区别

sset判断变量是否存在,可以传入多个变量,若其中一个变量不存在则返回假;empty判断变量是否为空为假,只可传一个变量,如果为空为假则返回真。

7、请说明PHP中传值与传引用的区别。什么时候传值什么时候传引用?

按值传递:函数范围内对值的任何改变在函数外部都会被忽略

按引用传递:函数范围内对值的任何改变在函数外部也能反映出这些修改

优缺点:按值传递时,php必须复制值。特别是对于大型的字符串和对象来说,这将会是一个代价很大的操作。按引用传递则不需要复制值,对于性能提高很有好处。

8、在PHP中error_reporting这个函数有什么作用?

设置PHP的报错级别并返回当前级别。

9、说说你对缓存技术的了解?

10、现在编程中经常采取MVC三层结构,请问MVC分别指哪三层,有什么优点?

MVC三层分别指:业务模型、视图、控制器,由控制器层调用模型处理数据,然后将数据映射到视图层进行显示,优点是:①可以实现代码的重用性,避免产生代码冗余;②M和V的实现代码分离,从而使同一个程序可以使用不同的表现形式

11、AJAX的优势是什么?

ajax是异步传输技术,可以通过javascript实现,也可以通过JQuery框架实现,实现局部刷新,减轻了服务器的压力,也提高了用户体验。

12、在程序的开发中,如何提高程序的运行效率?

A、优化SQL语句,查询语句中尽量不使用select*,用哪个字段查哪个字段;少用子查询可用表连接代替;少用模糊查询;

B、数据表中创建索引;

C、对程序中经常用到的数据生成缓存。

13、对于大流量的网站,您采用什么样的方法来解决访问量问题

A、有效使用缓存,增加缓存命中率

B、使用负载均衡

C、对静态文件使用cdn进行存储和加速

D、想法减少数据库的使用

E、查看出现统计的瓶颈在哪里

F、反向代理

14、语句include和require的区别是什么为避免多次包含同一文件,可用什么语句代替它们

区别:

在失败的时候:

include产生一个warning,而require产生直接产生错误中断

require在运行前载入

include在运行时载入

代替:

require_once

include_once

15、foo()和@foo()之间有什么区别

@代表所有warning忽略

16、简述php的垃圾收集机制。

答案:php中的变量存储在变量容器zval中,zval中除了存储变量类型和值外,还有is_ref和refcount字段。refcount表示指向变量的元素个数,is_ref表示变量是否有别名。如果refcount为0时,就回收该变量容器。如果一个zval的refcount减1之后大于0,它就会进入垃圾缓冲区。当缓冲区达到最大值后,回收算法会循环遍历zval,判断其是否为垃圾,并进行释放处理。

17、如何实现PHP的安全最大化?怎样避免SQL注入漏洞和XSS跨站脚本攻击漏洞?

答:基本原则:不对外界展示服务器或程序设计细节(屏蔽错误),不相信任何用户提交的数据(过滤用户提交)。

18、echo、print_r、print、var_dump区别

echo:语句结构;

print:是函数,有返回值

print_r:能打印数组,对象

var_dump:能打印对象数组,并且带数据类型

19、写出smarty模板的特点

速度快,编译型,缓存技术,插件机制,强大的表现逻辑

20、PHP如何实现页面跳转

方法一:php函数跳转,缺点,header头之前不能有输出,跳转后的程序继续执行,可用exit中断执行后面的程序。

htmlspecialchars或者htmlentities

23、什么是CSRF攻击?XSS攻击?如何防范?

CSRF,跨站请求伪造,攻击方伪装用户身份发送请求从而窃取信息或者破坏系统。

讲述基本原理:用户访问A网站登陆并生成了cookie,再访问B网站,如果A网站存在CSRF漏洞,此时B网站给A网站的请求(此时相当于是用户访问),A网站会认为是用户发的请求,从而B网站就成功伪装了你的身份,因此叫跨站脚本攻击。

CSRF防范:

A、合理规范api请求方式,GET,POST

B、对POST请求加token令牌验证,生成一个随机码并存入session,表单中带上这个随机码,提交的时候服务端进行验证随机码是否相同。

XSS,跨站脚本攻击。

防范:不相信任何输入,过滤输入。

24、安全对一套程序来说至关重要,请说说在开发中应该注意哪些安全机制?

A、防远程提交;B、防SQL注入,对特殊代码进行过滤;C、防止注册机灌水,使用验证码。

25、对json数据格式的理解?

JSON(javascriptobjectNotation)是一种轻量级的数据交换格式,json数据格式固定,可以被多种语言用作数据的传递。

26、什么是事务?及其特性?

答:事务:是一系列的数据库操作,是数据库应用的基本逻辑单位。

事务特性:

A、原子性:即不可分割性,事务要么全部被执行,要么就全部不被执行。B、一致性或可串性。事务的执行使得数据库从一种正确状态转换成另一种正确状态C、隔离性。在事务正确提交之前,不允许把该事务对数据的任何改变提供给任何其他事务,D、持久性。事务正确提交后,其结果将永久保存在数据库中,即使在事务提交后有了其他故障,事务的处理结果也会得到保存。

或者这样理解:

事务就是被绑定在一起作为一个逻辑工作单元的SQL语句分组,如果任何一个语句操作失败那么整个操作就被失败,以后操作就会回滚到操作前状态,或者是上有个节点。为了确保要么执行,要么不执行,就可以使用事务。要将有组语句作为事务考虑,就需要通过ACID测试,即原子性,一致性,隔离性和持久性。

27、什么是锁?

答:数据库是一个多用户使用的共享资源。当多个用户并发地存取数据时,在数据库中就会产生多个事务同时存取同一数据的情况。若对并发操作不加控制就可能会读取和存储不正确的数据,破坏数据库的一致性。

加锁是实现数据库并发控制的一个非常重要的技术。当事务在对某个数据对象进行操作前,先向系统发出请求,对其加锁。加锁后事务就对该数据对象有了一定的控制,在该事务释放锁之前,其他的事务不能对此数据对象进行更新操作。

基本锁类型:锁包括行级锁和表级锁

28、索引的作用?和它的优点缺点是什么?

答:索引就一种特殊的查询表,数据库的搜索引擎可以利用它加速对数据的检索。它很类似与现实生活中书的目录,不需要查询整本书内容就可以找到想要的数据。索引可以是唯一的,创建索引允许指定单个列或者是多个列。缺点是它减慢了数据录入的速度,同时也增加了数据库的尺寸大小。

29、如何通俗地理解三个范式?

第一范式:1NF是对属性的原子性约束,要求属性具有原子性,不可再分解;第二范式:2NF是对记录的惟一性约束,要求记录有惟一标识,即实体的惟一性;第三范式:3NF是对字段冗余性的约束,即任何字段不能由其他字段派生出来,它要求字段没有冗余。

30、主键、外键和索引的区别?

定义:主键--唯一标识一条记录,不能有重复的,不允许为空外键--表的外键是另一表的主键,外键可以有重复的,可以是空值索引--该字段没有重复值,但可以有一个空值

作用:主键--用来保证数据完整性外键--用来和其他表建立联系用的索引--是提高查询排序的速度

个数:主键--主键只能有一个外键--一个表可以有多个外键索引--一个表可以有多个唯一索引

31、简述private、protected、public修饰符的访问权限。

private:私有成员,在类的内部才可以访问。protected:保护成员,该类内部和继承类中可以访问。public:公共成员,完全公开,没有访问限制。

32、堆和栈的区别?

A、堆是程序运行期间动态分配的内存空间,你可以根据程序的运行情况确定要分配的堆内存的大小;B、栈是编译期间就分配好的内存空间,因此你的代码中必须就栈的大小有明确的定义。

33、常用的魔术方法有哪些?举例说明

答:php规定以两个下划线(__)开头的方法都保留为魔术方法,所以建议大家函数名最好不用__开头,除非是为了重载已有的魔术方法。

__construct()实例化类时自动调用。__destruct()类对象使用结束时自动调用。__set()在给未定义的属性赋值的时候调用。__get()调用未定义的属性时候调用。__isset()使用isset()或empty()函数时候会调用。__unset()使用unset()时候会调用。__sleep()使用serialize序列化时候调用。__wakeup()使用unserialize反序列化的时候调用。__call()调用一个不存在的方法的时候调用。__callStatic()调用一个不存在的静态方法是调用。__toString()把对象转换成字符串的时候会调用。比如echo。__invoke()当尝试把对象当方法调用时调用。__set_state()当使用var_export()函数时候调用。接受一个数组参数。__clone()当使用clone复制一个对象时候调用。

34、$this和self、parent这三个关键词分别代表什么?在哪些场合下使用?

$this当前对象self当前类parent当前类的父类

$this在当前类中使用,使用->调用属性和方法self也在当前类中使用,不过需要使用::调用parent在类中使用

35、作用域操作符::如何使用?都在哪些场合下使用?

调用类常量调用静态方法

36、__autoload()方法的工作原理是什么?

答:使用这个魔术函数的基本条件是类文件的文件名要和类的名字保持一致。

当程序执行到实例化某个类的时候,如果在实例化前没有引入这个类文件,那么就自动执行__autoload()函数。

这个函数会根据实例化的类的名称来查找这个类文件的路径,当判断这个类文件路径下确实存在这个类文件后

就执行include或者require来载入该类,然后程序继续执行,如果这个路径下不存在该文件时就提示错误。

使用自动载入的魔术函数可以不必要写很多个include或者require函数。

37、简述高并发网站解决方案。

A、前端优化(CND加速、建立独立图片服务器)B、服务端优化(页面静态化、并发处理[异步|多线程]、队列处理)C、数据库优化(数据库缓存[Memcachaed|Redis]、读写分离、分库分表、分区)D、Web服务器优化(负载均衡、反向代理)38、PHP遍历文件夹下所有文件

phpindx.php

A、从命令行运行php非常简单。但有些注意事项需要各位了解下,诸如$_SESSION之类的服务器变量是无法在命令行中使用的,其他代码的运行则和web服务器中完全一样;B、在命令行中执行php文件的好处之一就是可以通过脚本实现一些计划任务(crontab)的执行,而无须通过web服务器。

延伸1:php-v显示当前PHP版本php-m显示当前php加载的有效模块php-i输出无html格式的phpinfophp--rffunction

A、使用$argvor$argc参数接收

A、PHP脚本的执行效率

a、代码脚本里计时;

B、数据库SQL的效率

a、sql的explain(mysql),启用slowquerylog记录慢查询;

b、通常还要看数据库设计是否合理,需求是否合理等。

41、对于大流量的网站,您采用什么样的方法来解决各页面访问量统计问题。

A、确认服务器是否能支撑当前访问量;B、优化数据库访问;C、禁止外部访问链接(盗链),比如图片防盗链;D、控制文件下载,尤其是大文件;E、使用不同主机分流(负载均衡);F、使用浏览统计软件,了解访问量,有针对性的进行优化。

42、MySQL数据库作发布系统的存储,一天五万条以上的增量,预计运维三年,怎么优化?

A、设计良好的数据库结构,允许部分数据冗余,尽量避免join查询,提高效率;B、选择合适的表字段数据类型和存储引擎,适当的添加索引;C、mysql库主从读写分离;D、找规律分表,减少单表中的数据量提高查询速度;E、添加缓存机制,比如memcached,redis等;F、不经常改动的页面,生成静态页面;G、书写高效率的SQL。比如SELECT*FROMTABEL改为SELECTfield_1,field_2,field_3FROMTABLE。

43、Mysql的存储引擎,myisam和innodb的区别。

A、MyISAM类型不支持事务处理等高级处理,而InnoDB类型支持;

B、MyISAM类型的表强调的是性能,其执行速度比InnoDB类型更快;

C、InnoDB不支持FULLTEXT类型的索引;

D、InnoDB中不保存表的具体行数,也就是说,执行selectcount(*)fromtable时,InnoDB要扫描一遍整个表来计算有多少行,但是MyISAM只要简单的读出保存好的行数即可;

E、对于AUTO_INCREMENT类型的字段,InnoDB中必须包含只有该字段的索引,但是在MyISAM表中,可以和其他字段一起建立联合索引;

F、DELETEFROMtable时,InnoDB不会重新建立表,而是一行一行的删除;

G、LOADTABLEFROMMASTER操作对InnoDB是不起作用的,解决方法是首先把InnoDB表改成MyISAM表,导入数据后再改成InnoDB表,但是对于使用的额外的InnoDB特性(例如外键)的表不适用;

H、MyISAM支持表锁,InnoDB支持行锁。

MyISAM:成熟、稳定、易于管理,快速读取。一些功能不支持(事务等),表级锁。InnoDB:支持事务、外键等特性、数据行锁定。空间占用大,不支持全文索引等。

其他,主要是一些面试后的个人看法和玄学了:

1.很多在职的同学觉得请假面试麻烦,其实现在很多公司都有安排晚上面试和周末面试专场的,提前沟通好就行了,请假的话一天面试三家应该不是问题。

2.投递公司的顺序建议,首先是一两家公司预热一下,然后比较心仪的很有把握的公司,然后才是非常心仪的公司,最后是选择性的面试。安排这个顺序主要是,虽然可能你业务很厉害,但是进入面试状态时需要一个过程的,面试预热很有必要,这里顺便强调下面试提前准备,比如看下面试题,复习下技术书籍都很有必要的。提前选择比较心仪的很有把握的公司,主要是为了拿到offer,一是做自我价值验证,二是心中有底气。

3.调整好心态,其实有些offer是带有运气成分的,毕竟对于有些体量公司来说,面试常有,编制不常有,所以拿不到offer也不要气馁。

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

THE END
1.试举例简要说明如何开发新用户。[主观题] 试举例简要说明如何开发新用户。答案每种产品都有吸引新用户、增加用户数量的潜力使那些尚未使用本行业产品的人开始使用把潜在顾客转变为现实顾客。一个制造商可从三个方面找到新用户:通过市场渗透战略.转变未使用者如香水企业可设法说服不用香水的女性使用香水;通过市场开发战略进入新的细分市场如说服男性使用...https://www.shangxueba.cn/daxue/in7gg7a2.html
2.试举例简要说明如何开发新用户。试举例简要说明如何开发新用户。 参考答案:每种产品都有吸引新用户、增加用户数量的潜力、使那些尚未使用本行业产品的人开始使用,把潜在顾客转变为现实顾客。一个制造商可... 点击查看答案http://www.ppkao.com/wangke/daan/25b4cb79802b4c09a0d198068f2d5aa3
3.《软件工程导论》考研复试整理脚本必须从用户的观点来描述每个重要的功能序列,因此,脚本应该能够说明系统的一类重要功能或具体的使用方法。 【第5版】8、为什么说参数化类有助于提高可重用性? 在实际的应用程序中,有一些软件元素,从逻辑功能看,彼此是相同的,所不同的主要是处理的对象类型不同。参数化类就是使用一个或者多个类型去参数化一个类...https://www.jianshu.com/p/050697c84836
4.嵌入式开发学习总结——Linux服务器配置hzy428910interfaces = 192.168.16.177/24 //举例说明 wins support = yes //设置将samba服务器作为wins服务器,默认不使用 //wins服务器由微软开发,功能是将NetBIOS名称转换为对应的ip地址 username map = /etc/samba/smbusers //去掉前面的;号,用于用户映射 http://blog.chinaunix.net/uid-29709024-id-4310660.html
5.一文详解:如何找准产品各阶段的北极星指标如果你要开发一款APP,需要经历从想法-商业价值闭环-功能梳理-产品设计-产品架构-产品开发-产品测试-产品上线的过程。 又或者你要开一家特色面馆,需要经历从学会几道招牌面-客群筛选-选址租店面-设计装修-试营业-改善味道-正式营业的过程。 这个过程基本没有用户的参与,因此也不会使用6个标准来评判这个过程的北极星...https://www.niaogebiji.com/article-80463-1.html
6.Java语言程序设计试卷6套12、下列哪些语句关于内存回收的说明是正确的? (正确答案:B) A、程序员必须创建一个线程来释放内存; B、内存回收程序负责释放无用内存 C、内存回收程序允许程序员直接释放内存 D、内存回收程序可以在指定的时间释放内存对象 13、在 Java 中,用 package 语句说明一个包时,该包的层次结构必须是___。(正确答案:B...https://developer.aliyun.com/article/1431557
7.齐了!Data+AI的技术大佬1、了解新一代数据质量审查工具,让人快速看清数据质量,让机器自动发现问题 2、了解如何才能把数据采集的效率做好 谢凝 华为 技术专家 个人介绍:华为翻译中心技术专家,华为机器翻译产品和数据负责人,中国翻译协会翻译技术委员会副主任委员。于2006年加入华为,有丰富的机器翻译产品开发和数据构建经验。 https://hub.baai.ac.cn/view/32597
1.四种用户增长方法论渠道合作:与其他有用户流量的渠道合作,如与网红、博主合作,让他们推荐产品;或者与其他应用、网站进行合作,通过在对方平台上展示自己的产品或服务,如应用内的交叉推广,获取新用户。 四、数据驱动的用户增长 用户行为分析 收集用户数据:通过产品内置的分析工具(如 Google Analytics for websites、Firebase for mobile apps...https://blog.csdn.net/chc340121/article/details/144086771
2.APP用户增长策略:从零到无限大的秘密武器——APP用户增长技巧...1、明确目标:确定您的APP的目标是什么,是希望吸引新用户?还是希望提高现有用户的活跃度?明确目标有助于制定更具体、更有针对性的策略。 2、定位用户:了解您的目标用户是谁,并深入了解他们的需求和痛点,这有助于您在APP中提供更好的用户体验,从而吸引更多用户。 https://www.wenanmiao.com/24397.html
3.中等职业学校汽车运用与维修专业课程标准本课程是中等职业学校汽车运用与维修专业的一门专业核心课程。其功能是使学生掌握汽车发动机和底盘机械结构方面必要的基础理论知识和基本技能。它是汽车运用与维修专业的基础课程,也是学生学习其它后续专业课程作铺垫。 1.2设计思路 本课程的总体设计思路是遵循学以致用原则,参照汽车维修工国家职业标准,根据工作任务与职业能...http://qpzx.qpedu.cn/jhkx/kcgl/kcbz/249092.htm
4.听说科技隐私权政策听说科技希望通过本政策向您说明听说科技在向您提供产品或服务过程中可能会收集的信息(包括收集方式)、收集这些信息的用途、听说科技及您如何保护这些信息的安全等, 您使用听说科技产品或服务时,听说科技有权用数字代码、通用唯一标识符、cookies或其他技术确定进入服务的计算机以及其他智能或非智能终端设备。 听说科技有可...https://www.waiyutong.org/Policy/privacyPolicy.html
5.2022软件测试面试题大全(整理版)1000+面试题附答案详解,最全面...11、写出5个Loadrunner中常用函数,并对其中2个举例说明用法。 12、简述LoadRunner的工作原理? 13、什么是集合点?设置集合点有什么意义? LoadRunner 中设置集合点的函数是哪个? 14、HTML-based script与URL based script的脚本有什么区别? 15、如何设置LaodRunner才能让集合点只对一半的用户生效? https://maimai.cn/article/detail?fid=1700715497&efid=tA7eC1eCPIrzCZI7LISXLQ
6.史上最全软件笔试题目及答案Alpha测试(α测试)是由一个用户在开发环境下进行的测试,也可以是公司内部的用户在模拟实际操作环境下进行的受控测试,Alpha测试不能由程序员或测试员完成。Alpha测试发现的错误,可以在测试现场立刻反馈给开发人员,由开发人员及时分析和处理。目的是评价软件产品的功能、可使用性、可靠性、性能和支持。尤其注重产品的界面...https://www.yjbys.com/qiuzhizhinan/show-502047.html
7.和你有关!《上海市加快经济恢复和重振行动方案》百问百答来了...目前上海市通信管理局督促行业推出惠企政策,督促各基础运营企业为新老中小企业用户提供免费体验、免费升速、资费优惠等不同的宽带和专线优惠政策,鼓励基础电信企业设计推广适合中小企业经营发展的产品和应用。在前期疫情期间推出免费提供在线会议、企业上云服务等帮扶措施的基础上,推动各企业将现有优惠措施延长至2022年10月...https://web.shobserver.com/staticsg/res/html/web/newsDetail.html?id=494188
8.需求分析报告(通用12篇)5)能够举例说明生物和生物之间的关系,包括种内关系和种间关系。 6)知道什么是种群,认识到种群的数量变化规律。 7)了解种群数量变化规律对人类生产实践活动的重要意义。 教学重点: 1)非生物环境(水、阳光、温度)对生物的影响。 2)保护色、警戒色、拟态等适应的方式。 https://www.ruiwen.com/word/xuqiufenxibaogao.html
9.开发者个人信息保护合规指引开发者接入穿山甲平台SDK产品前,应当详细阅读理解并同意穿山甲平台的用户服务协议、穿山甲平台隐私政策、《开发者个人信息保护合规指引》、具体SDK产品的隐私政策及其《SDK合规使用说明》等协议规范(前述协议规范以下统称为“平台规范”),并依据相关内容对开发者APP收集、存储、使用、共享等处理个人信息的情况及《隐私政策...https://www.pangle.cn/en/support/doc/60cee2eeecf02000460af4fb
10.第四章项目基本设置·REDCap最终用户指南(中文版)·看云当对话框出现时,即使在不是第一个表单的表单上输入新数据(即创建记录时),用户也会发现这种对纵向或多表单项目的干扰 8.10 数据输入触发器(在“项目设置”选项卡上的其他自定义设置中) 输入网址,无论何时创建或修改数据输入表或调查记录。REDCap将把数据发布到指定的位置。 8.11 数据输入触发器说明 数据输入触发器...https://www.kancloud.cn/xjtu_sph/redcap_user_guide/1345446