更高,因为++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.提示类型200、404、502是什么意思。
答:
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参数的作用是设置状态,