最常见的php面试题
1、表单提交get和post有何区别?
答:get的方式是把数据在地址栏中发送,get传送的数据量较小,不能大于2KB。post传送的数据量较大,一般被默认为不受限制。但理论上,IIS4中最大量为80KB,IIS5中为100KB。
2、用PHP打印出前一天的时间格式是2006-5-10 22:21:21
echo date("Y-m-d H:i:s",time()-(3600*24));或echo date("Y-m-d H:i:s",strtotime("-1 day"));
3、php中include和require的区别?
这两种结构除了在如何处理失败之外完全一样。include() 产生一个警告而 require() 则导致一个致命错误。换句话说,如果你想在遇到丢失文件时停止处理页面就用 require()。include() 就不是这样,脚本会继续运行。
4、echo(),print(),print_r()的区别
echo可以接多个参数,print只能接一个参数,它们都是PHP的语言结构,print_r是递规打印,用来打印数组或对象
5、能够使HTML和PHP分离开使用的模板
smarty,phplib,SmartTemplate
6你如何理解MVC模式?
首先说一下框架,框架:就是别人把一些底层,常用操作.比如数据操作(增,删,改,查)写好.你来直接用.其它的功能要自己来做。
MVC:设计模式,M模型,V显示,C控制.现在许多框架都是基于MVC来做的把逻辑和显示分开.比如你要换页面,只需要改V里面的东西并不需要再去变动程序!(详细的东西可以上网上查一下)
7、如何实现PHP、JSP交互?
PHP提供了支持JAVA的类库文件,或者通过HTTP协议来交互数据
8、使用哪些工具进行版本控制?
VSS,CVS,SVN
9、如何实现字符串翻转?
不考虑中英文混合,不是最优算法,不用php库函数翻转字符串:
function str_to_reverse( $str ){
for($length=0;$str[$length]!=null;$length++){;}
$strlength = $length-1;
unset($length);
for($start=0,$end=$strlength;$start<$end;$start++,$end--){
$temp = $str[$start];
$str[$start] = $str[$end];
$str[$end] = $temp;
}
unset($temp,$start,$end,$strlength);
return $str;
}
10、优化MYSQL数据库的方法。
1) 将where中用的比较频繁的字段建立索引,联合索引。
2) 保证单表数据不超过200W,适时分割表。
3) 避免使用长连接。
4) 修改my.cnf里面的各项参数,比如最大连接数,查询缓存等。根据你的服务器内存来最大化调节那些配置参数。
5) 针对需求,使用正确的表引擎,是myisam或是innodb。
11.用PHP写出显示客户端IP与服务器IP的代码:
echo $_SERVER['REMOTE_ADDR'] //客户端ip
echo $_SERVER['SERVER_ADDR'] //服务器端ip
12、apache+mysql+php实现最大负载的方法
1) 问的太笼统,生成静态html页面,squid反向代理,apache,mysql的负载均衡。
2) 可以采取数据缓存的方法,我们通常在统计数据的时候,需要在原始数据的基础上经过计算等一系列操作,才会得到最终的结果,如果每做一个查询都需要这样一系列操作,当数据量大时,势必会带来很多问题。可以建立一个结果表,写一个脚本,用crontab定时触发脚本去原始表取数据,计算,写入到结果表,前端查询从结果表取数据,这也是比较常用的一种做法。
3) 采用分布式,多个apache,多个mysql,其实就是dns负载均衡,dns根据当前用户解析几个ip的ping值,将用户转移到某一台最快的服务器,或者平均分配。
4 )money不是问题的话,可以考虑F5硬件负载均衡!
5)可以使用Microsoft Windows Server系统的负载均衡设置
13、用户输入文章时,通过选择下拉菜单选定文章分类,写出如何实现这个下拉菜单
<{html_options options=$art_types selected=$customer_id}>
14、PHP文件操作:用户提交内容后,系统生成静态HTML页面;写出实现的基本思路
ob_start();
function
ob_get_contents();
ob_clean();
15、实现中文字串截取无乱码的方法。
这个首先要考虑字符集的问题,UTF-8下一个汉字占3字节,GBK下一个汉字占2字节.可以自己写个函数来处理,别人也写了很多,当然也可以开启mbstring扩展库,使用里面的mb_substr()等函数来截取。当截取字符出现乱码时,是因为汉字被截断了,可以再字符串尾部连上一个chr(0)
16、
$a = "hello";
$b = &$a;
unset($b);
$b = "world";
what is $a?
hello,unset($b)只是释放了$b自己和$a的别名关系,并不会释放$a
$a = 1;
$x = &$a;
$b = $a++;
what is $b?
先执行$b = $a,$a++再进行,所以$b还是1
17、请简单阐述您最得意的开发之作.
自由发挥.
18、谈谈事务处理
可以控制并发操作所产生的数据同步提交、更新所带来的冲突问题.可以进行comit,rollback操作,数据的安全性得到了提高。
19、请说明php中传值与传引用的区别。什么时候传值什么时候传引用?
传址为了在执行函数的同时,同时改变函数参数值,而传值不期望改变。
20、使用五种以上方式获取一个文件的扩展名
function get_ext1($file_name){
return strrchr($file_name, ‘.’);
}
function get_ext2($file_name){
return substr($file_name, strrpos($file_name, ‘.’));
}
function get_ext3($file_name){
return array_pop(explode(‘.’, $file_name));
}
function get_ext4($file_name){
$p = pathinfo($file_name);
return $p['extension'];
}
function get_ext5($file_name){
return strrev(substr(strrev($file_name), 0, strpos(strrev($file_name), ‘.’)));
}
21、使用PHP描述冒泡排序和快速排序算法,对象可以是一个数组
//冒泡排序(数组排序)
function bubble_sort($array)
{
$count = count($array);
if ($count <= 0) return false;
for($i=0; $i<$count; $i++){
for($j=$count-1; $j>$i; $j–){
if ($array[$j] < $array[$j-1]){
$tmp = $array[$j];
$array[$j] = $array[$j-1];
$array[$j-1] = $tmp;
}
}
}
return $array;
}
//快速排序(数组排序)
function quick_sort($array) {
if (count($array) <= 1) return $array;
$key = $array[0];
$left_arr = array();
$right_arr = array();
for ($i=1; $i<count($array); $i++){
if ($array[$i] <= $key)
$left_arr[] = $array[$i];
else
$right_arr[] = $array[$i];
}
$left_arr = quick_sort($left_arr);
$right_arr = quick_sort($right_arr);
return array_merge($left_arr, array($key), $right_arr);
}
22、使用PHP描述顺序查找和二分查找(也叫做折半查找)算法,顺序查找必须考虑效率,对象可以是一个有序数组
//二分查找(数组里查找某个元素)
function bin_sch($array, $low, $high, $k){
if ($low <= $high){
$mid = intval(($low+$high)/2);
if ($array[$mid] == $k){
return $mid;
}elseif ($k < $array[$mid]){
return bin_sch($array, $low, $mid-1, $k);
}else{
return bin_sch($array, $mid+1, $high, $k);
}
}
return -1;
}
//顺序查找(数组里查找某个元素)
function seq_sch($array, $n, $k){
$array[$n] = $k;
for($i=0; $i<$n; $i++){
if($array[$i]==$k){
break;
}
}
if ($i<$n){
return $i;
}else{
return -1;
}
}
23、写一个二维数组排序算法函数,能够具有通用性,可以调用php内置函数
//二维数组排序, $arr是数据,$keys是排序的健值,$order是排序规则,1是升序,0是降序
function array_sort($arr, $keys, $order=0) {
if (!is_array($arr)) {
return false;
}
$keysvalue = array();
foreach($arr as $key => $val) {
$keysvalue[$key] = $val[$keys];
}
if($order == 0){
asort($keysvalue);
}else {
arsort($keysvalue);
}
reset($keysvalue);
foreach($keysvalue as $key => $vals) {
$keysort[$key] = $key;
}
$new_array = array();
foreach($keysort as $key => $val) {
$new_array[$key] = $arr[$val];
}
return $new_array;
}
24、简述如何得到当前执行脚本路径,包括所得到参数。
$_SERVER[‘SCRIPT_URL’]
$_REQUEST
25、如何修改SESSION的生存时间.
ini_set('session.gc_maxlifetime',21600);
26、有一个网页地址 http://www.domain.com/xxx.php,如何得到它的内容?
File_get_content();
27、防止SQL注射漏洞一般用函数。
Addslashes在指定的预定义字符前添加反斜杠
htmlentities() 函数把字符转换为 HTML 实体
28、在PHP中,当前脚本的名称(不包括路径和查询字符串)记录在预定义变量$_SEVER[‘PHP_SELF’]中;而链接到当前页面的URL记录在预定义变量$_SEVER[‘HTTP_REFERE’]中。
29、在HTTP 1.0中,状态码 401 的含义是(4);如果返回“找不到文件”的提示,则可用 header 函数,其语句为(5)。HTTP/1.0 404 Not Found
30、数组函数 arsort 的作用是逆向排序保持索引关系;语句 error_reporting(2047)的作用是返回全部错误。
31、写出一个正则表达式,过虑网页上的所有JS/VBS脚本(即把script标记及其内容都去掉):
/<script [^>].*?>.*?<//script>/si
32、类的属性可以序列化后保存到 session 中,从而以后可以恢复整个类,这要用到的函数是
Serialize();
33、一个函数的参数不能是对变量的引用,除非在php.ini中把(15)设为on.
allow_call_time_pass_reference
34、PHP遍历目录
/**
* 遍历目录,结果存入数组。支持php4及以上。php5以后可用scandir()函数代替while循环。
* @param string $dir
* @return array
*/
function my_scandir($dir)
{
$files = array();
while ( ($file = readdir(opendir($dir))) !== false ) {
if ( $file != “..” && $file != “.” ) {
if ( is_dir($dir . “/” . $file) ) {
$files[$file] = my_scandir($dir . “/” . $file);
}else {
$files[] = $file;
}
}
closedir($handle);
return $files;
}
}
35、php编码转换
iconv("utf-8", "gb2312", $notice);
36、用PHP获取标准URL中文件的后缀名
parse_url($url)
37、长连接与短连接的区别
长连接是相对于通常的短连接而说的,也就是长时间保持客户端与服务端的连接状态。
38、离职原因和为什么加入该公司