归纳整理39道PHP面试题
发布时间:2022-08-10 12:01:37 所属栏目:PHP教程 来源:互联网
导读:PHP常见面试题 1.详述一次完整的HTTP请求过程 这个问题的核心是域名解析和服务器(nginx)解析这两部分,基本上这两部分详细阐述就可以了。 步骤一、解析URL 浏览器会解析当前的URL数据,判断此URL是否为合法的链接。如果是合法链接则正常的向下一步骤前进。
|
PHP常见面试题 1.详述一次完整的HTTP请求过程 这个问题的核心是域名解析和服务器(nginx)解析这两部分,基本上这两部分详细阐述就可以了。 步骤一、解析URL 浏览器会解析当前的URL数据,判断此URL是否为合法的链接。如果是合法链接则正常的向下一步骤前进。如果不是合法的链接,则会执行搜索功能,例如执行百度、360、Google搜索等。 步骤二、解析域名 服务器是以ip的形式存在的。而域名需要解析到ip上,解析IP会有三个小的步骤: 1)、从浏览器自身的缓存中解析此域名数据 2)、从本地电脑的HOST文件中解析域名 3)、通过DNS服务器解析域名 步骤三、拿信息 这个步骤我们拿到了URL的信息,主要是IP和端口信息。 步骤四、封包并进行三次握手 浏览器将请求信息进行打包,通过TCP的三次握手将数据传递至服务器。 步骤五、服务器解析、处理、返回数据 服务器通过种种层级、方式拿到传递的数据,对数据进行分析、处理,最后返回响应类MIME类型数据。正常状态码为200,非正常的错误码有404、500、501等等 步骤六、浏览器获得、渲染、展现数据 浏览器从服务器拿到数据、通过加载资源、渲染页面等操作,将页面展现给用户。 2. SESSION 与 COOKIE的区别是什么,请从协议,产生的原因与作用说明? 1)、http无状态协议,不能区分用户是否是从同一个网站上来的,同一个用户请求不同的页面不能看做是同一个用户。 2)、SESSION存储在服务器端,COOKIE保存在客户端。Session比较安全,cookie用某些手段可以修改,不安全。Session依赖于cookie进行传递。 禁用cookie后,session不能正常使用。Session的缺点:保存在服务器端,每次读取都从服务器进行读取,对服务器有资源消耗。Session保存在服务器端的文件或数据库中,默认保存在文件中,文件路径由php配置文件的session.save_path指定。Session文件是公有的。 3.HTTP 状态中302、403、 500代码含义? 一二三四五原则: 一. 消息系列 二 成功系列 三. 重定向系列 四. 请求错误系列 五. 服务器端错误系列 302:临时转移成功,请求的内容已转移到新位置 403:禁止访问 500:服务器内部错误 401代表未授权。 4. Linux 下建立压缩包,解压缩包的命令 Tar.gz: 打包: tar czf file.tar.gz file.txt 解压: tar xzf file.tar.gz Bz2: 打包: bzip2 [-k] 文件 解压: bunzip2 [-k] 文件 Gzip(只对文件,不保留原文件) 打包: gzip file1.txt 解压: gunzip file1.txt.gz Zip: -r 对目录 打包: zip file1.zip file1.txt 解压: unzip file1.zip 5. 请写出数据类型(int char varchar datetime text)的意思;请问 varchar 和 char有什么区别? Int 整数 char 定长字符 Varchar 变长字符 Datetime 日期时间型 Text 文本型 Varchar 与char的区别 char是固定长度的字符类型,分配多少空间,就占用多长空间。 Varchar是可变长度的字符类型,内容有多大就占用多大的空间,能有效节省空间。 由于varchar类型是可变的,所以在数据长度改变的时,服务器要进行额外的操作,所以效率比char类型低。 6. MyISAM 和 InnoDB 的基本区别?索引结构如何实现? MyISAM类型不支持事务,表锁,易产生碎片,要经常优化,读写速度较快,而InnoDB类型支持事务,行锁,有崩溃恢复能力。读写速度比MyISAM慢。 创建索引:alert table tablename add index (`字段名`) 7. 不使用cookie向客户端发送一个cookie. 理解:session_start()开启时,生成一个常量 SID,当COOKIE开启时,这个常量为空,当COOKIE关闭时,这个常量中存储了PHPSESSID的值。通过在URL后加一个SID参数来传递SESSIONID的值,从而使客户端页面可以使用SESSION里面的值。 当客户端开启COOKIE和服务器端开启SESSION时。 浏览器第一次请求,服务器会向浏览器端发送一个COOKIE里面存储SESSIONID. 当浏览器第二次请求时,会把已存在 8. isset() 和 empty() 区别 Isset判断变量是否存在,可以传入多个变量,若其中一个变量不存在则返回假,empty判断变量是否为空为假,只可传一个变量,如果为空为假则返回真。 9.持久化redis有几种方式? 答:主要有两种方式: 1) 快照持久化 在redis配置文件中已经自动开启了, 格式是:save N M 表示在N秒之内,redis至少发生M次修改则redis抓快照到磁盘。 当然我们也可以手动执行save或者bgsave(异步)命令来做快照 2)append only file AOF持久化 总共有三种模式,如 appendfsync everysec默认的是每秒强制写入磁盘一次 appendfsync always 每次执行写操作的时候就强制写入磁盘 appendfsync no 完全取决于os,性能最好但是持久化没法保证 其中第三种模式最好。redis默认的也是采取第三种模式。 10.mysql存储引擎 答:常用的主要分为两种,一种是innodb,一种是myisam,两者的主要区别是 1)myisam不支持事务处理,而innoDB支持事务处理 2)myisam 不支持外键,innoDB支持外键 3)myisam支持全文检索,而innoDB在MySQL5.6版本之后才支持全文检索 4)数据的存储形式不一样,mysiam表存放在三个文件:结构、索引、数据,innoDB存储把结构存储为一个文件,索引和数据存储为一个文件 5)myisam在查询和增加数据性能更优于innoDB,innoDB在批量删除方面性能较高。 6)myisam支持表锁,而innoDB支持行锁 11.sql注入是什么及如何预防sql注入? 答:SQL注入攻击指的是用户或者黑客通过构建特殊的输入作为参数传入我们的Web应用程序端,而这些输入大都是SQL语法里的一些组合,通过执行SQL语句进而执行攻击者所要的操作,其主要原因是程序员没有细致地过滤用户输入的数据,致使非法数据侵入系统而造成的。因此我们在做开发过程中一定要预防sql注入,主要从两方面着手: 1)占位符的方式,就是对sql语句进行预处理,然后执行sql语句 2)通过addslashes或者mysql_real_escape_string这两个函数对用户输入的值进行转义处理,把一些特殊的字符转义掉。 12.有用过预处理么? 答:用过,PDO类中,有个prepare方法可以实现预处理,PDOStament类中 的excute方法可以执行预处理,预处理的参数分为两种,一种是:字符串占位符,另一种是?占位符,:字符串占位符在执行预处理传递参数时传入的是关联数组,而?占位符传递的是索引数组。两者不能混合使用,但一般推荐使用:字符串占位符。 (编辑:鄂州站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
站长推荐
热点阅读


