设为首页 加入收藏

TOP

PHP程序员面试题参考手册2(二)
2014-11-24 00:10:23 来源: 作者: 【 】 浏览:10
Tags:PHP 程序员 试题 参考 手册
更高,因为
++i少了一个返回i的过程。



119.magic_quotes_gpc()magic_quotes_runtime()的意思是什么?


答:


Magic_quotes_gpc()php配置文件中的,如果设置为on则会自动POST,GET,COOKIE中的字符串进行转义,在之前加\


Magic_quotes_runtime()php中的函数,如果参数为true则会数据库中取出来的单引号、双引号、反斜线自动加上反斜杠进行转义。



120.Echo()print()print_r()的区别?


答:


Echo php语法,可以输出多个变量,不能输出数组。


Print()php中的函数,只能输出简单的变量。


Print_r()php中的函数,可以输出变量也可以输出数组。



121.框架中什么是单一入口和多入口,单一入口的优缺点?


答:


1多入口就是通过访问不同的文件来完成用户请求。


单一入口只web程序所有的请求都指向一个脚本文件的。



2单一入口更容易控制权限,方便对http请求可以进行安全性检查。


缺点:URL看起来不那么美观,特别是对搜索引擎来说不友好。



122.提示类型200404502是什么意思。


答:


200是请求成功,404是文件未找到,502是服务器内部错误。



123.编写一个自定义函数提取这段路径的的后缀名。


答:


“Www/hello/test.php.html a=3&b=4”


Function geturltype($url){


$info=parse_url($url);


Return end(explode(‘.’,$info['path']));


}


124.你对Memcach的理解,优点有哪些?


答:


Memcache是一种缓存技术,在一定的时间内将动态网页经过解析之后保存到文件,下次访问时动态网页就直接调用这个文件,而不必在重新访问数据库。使用memcache做缓存的好处是:提高网站的访问速度,减轻高并发时服务器的压力。


Memcache的优点:稳定、配置简单、多机分布式存储、速度快。







125.对关系型数据库而言,索引是相当重要的概念,请回答有关索引几个问题:


a) 索引的目的是什么


b) 索引对数据库系统的负面影响是什么


c) 为数据表建立索引的原则有哪些


d) 什么情况下不宜建立索引


答:


索引的目的:


1、快速访问数据表中的特定信息,提高检索速度


2、创建唯一性索引,保证数据库表中每一行数据的唯一性


3、加速表和表之间的连接


4、使用分组和排序子句进行数据检索时,可以显著减少查询中分组和排序的时间


负面影响:创建索引和维护索引需要耗费时间,这个时间随着数据量的增加而增加;索引需要占用物理空间,不光是表需要占用数据空间,每个索引也需要占用物理空间;当对表进行增、删、改的时候索引也要动态维护,这样就降低了数据的维护速度。


建立索引的原则:


1、在最频繁使用的、用以缩小查询范围的字段上建立索引


2、在平频繁使用的、需要排序的字段上建立索引


什么情况下不宜建立索引:


1、对于查询中很少涉及的列或者重复值比较多的列,不宜建立索引


2、对于一些特殊的数据类型,不宜建立索引,比如文本字段(text)等。



126.web应用中,数据库的读取频率远高于写入频率, 如何优化MySQL而应对此种情景


答:


使用memcache缓存技术,将动态数据缓存到文件,访问动态页面时直接调用缓存文件,而不必重新访问数据库,这样就减少了查询数据库的次数。


如果网站的访问量很大,可以把数据库读写服务器分开,使用多态服务器去处理数据库查询,使用较少的服务器去处理数据库的写入和修改。



127.include与require的区别


答:


Php在遇到include时就重新解释一次,如果一个页面中出现10次include,php就重新解释10次,而php遇到require时只解释一次,即使页面中出现多次require,php也直解释一次。


使用require包含文件时,被包含的文件当成了当前文件的一个组成部分,如果被包含的文件中有语法错误或者文件不存在,程序就提示错误信息,并结束执行。


使用include包含文件时,相当于指定了文件的路径,被包含的文件中有语法错误或者文件不存在时,页面只是给出警告信息,不响应程序本身的执行。



128.PHP字符串中单引号与双引号的区别


答:


单引号不能解释变量,而双引号可以解释变量。


单引号不能转义字符,在双引号中可以转义字符。





129.php5中魔术方法有哪几个 并说明其用法


答:


__construct实例化对象时自动调用的方法。


__destruct销毁对象时自动调用的方法。


__set当对一个不存在的变量设置值的时候自动调用的方法。


__get当调用一个不存在的变量的时候自动调用的方法。


__autoload 当实例化类一个不存在的类的时候会自动调用的方法。


__isset 当对一个不存在的变量使用isset方法时自动调用的方法


__unset 当对一个不存在的变量使用unset方法时自动调用的方法。


__call 当调用一个不存在的方法时自动调用的方法。


__clone 克隆一个对象。


__tostring 当输出一个对象时自动调用的方法。



130.php中,模板引擎的目的是什么 你用过哪些模板引擎


答:


使用模板引擎的目的是使程序的逻辑代码和html界面代码分离开,是程序的结构更清晰。


使用过的模板引擎:Smarty、ThinkPHP的ThinkTemplate


131.使用版本控制工具的目的是什么 你用过哪些版本控制工具


答:


使用版本控制器的目的是:


实现开发团队并行开发,提高开发效率,对于软件开发进程中文件或目录的发展过程提供有效的追踪手段,保证在需要时可以回到旧版本,避免文件的丢失、修改的丢失和覆盖,通过对版本库的访问控制避免未经授权的访问和修改,达到有效保护企业软件资产和知识产权的目的。


使用过的版本控制工具:SVN



132.指出以下代码片段中的SQL注入漏洞以及解决方法(magic_quotes_gpc = off)
答:


mysql_query(“select id,title from content where catid=’{$_GET[catid]}’ and title like ’%$_GET[keywords]%’”, $link);


注入漏洞主要存在用户提交的数据上,这里的注入漏洞主要是$_GET[catid]和$_GET[keyword]


解决注入漏洞:


$_GET[catid]=intval($_GET[catid]);


$sql=”select id,title from content where catid=’{$_GET[catid]}’ and title like ’%$_GET[keywords]%”;


$sql=addslashes($sql);


Mysql_query($sql);






133.分别指出php.ini中 magic_quotes_gpc, magic_quotes_runtime两项参数的作用.


答:


Magic_quotes_gpc的作用是在POST、GET、COOKIE数据上使用addslashes()自动转义。


Magic_quotes_runtime参数的作用是设置状态,

首页 上一页 1 2 3 下一页 尾页 2/3/3
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇介绍一下白盒测试中的六种覆盖方.. 下一篇电子通信研究生就业指导(电子 通..

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·Sphinx : 高性能SQL (2025-12-24 10:18:11)
·Pandas 性能优化 - (2025-12-24 10:18:08)
·MySQL 索引 - 菜鸟教 (2025-12-24 10:18:06)
·Shell 基本运算符 - (2025-12-24 09:52:56)
·Shell 函数 | 菜鸟教 (2025-12-24 09:52:54)