PHP 面试题二

1、抓取远程图片到本地,你会用什么函数?

fsockopen, A

2、用最少的代码写一个求3值最大值的函数.

function get_max($a,$b,$c) {
    return ($a > $b ? $a : $b) > $c ? ($a > $b ? $a : $b) : $c;
}

4、javascript能否定义二维数组,如果不能你如何解决?

javascript不支持二维数组定义,可以用arr[0] = new array()来解决

5、假设a.html和b.html在同一个文件夹下面,用javascript实现当打开a.html五秒钟后,自动跳转到b.html。

function test(){
    window.location = "b.html";
    window.close();
}
setTimeout( "test()",5000 ); //5秒钟后自动执行test()

8、写一个函数,能够遍历一个文件夹下的所有文件和子文件夹。

    <?php
     function my_dir($dir){
         $files=array();
         //注意这里要加一个@,不然会有warning错误提示
         if(@$handle=opendir($dir)){
             
             while(($file=readdir($handle))!==false){
                 //排除根目录;
                 if($file!=".." && $file!="."){
                
                     //如果是子文件夹,就进行递归 ;不是就将文件的名字存入数组;
                     if(is_dir($dir."/".$file)){
                         $files[$file]=my_dir($dir."/".$file);
                     }else{
                         $files[]=$file;
                     }
  
                 }
             }
             closedir($handle);
             return $files;
         }
     }
    //以下是测试
     $array=my_dir('C:/test');
     var_dump($array);

9、把 John 新增到 users 阵列?

$users[] = 'join';   
array_push($users, 'john');

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

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

16、写一个函数,尽可能高效的,从一个标准 url 里取出文件的扩展名

例如: http://www.sina.com.cn/abc/de/fg.php?id=1 需要取出 php 或 .php

<?php
function getExt($url){
    $arr  = parse_url($url);  // 解析url为数组
    $file = basename($arr['path']);  // $arr['path'] = "/abc/de/fg.php";
    $ext  = explode(".",$file);      // $file = "fg.php"; explode拆分字符串,返回一个数组
    return $ext[1];
}

17、使用五种以上方式获取一个文件的扩展名;要求:dir/upload.image.jpg,找出 .jpg 或者 jpg ,

必须使用PHP自带的处理函数进行处理,方法不能明显重复,可以封装成函数,比如 get_ext1($file_name), get_ext2($file_name)

// 方法1:
function get_ext1($file_name){ return strrchr($file_name, '.'); } // 方法2: function get_ext2($file_name){ return substr($file_name, strrpos($file_name, '.')); } // 方法3: function get_ext3($file_name){ return array_pop(explode('.', $file_name)); } // 方法4: function get_ext4($file_name){ $p = pathinfo($file_name); return $p['extension']; } // 方法5: function get_ext5($file_name){ return strrev(substr(strrev($file_name), 0, strpos(strrev($file_name), '.')));
}
18、以下代码的输出结果是?
$str1 = null;
$str2 = false;
echo $str1 == $str2 ? '相等' : '不相等'; // 相等
;
$str4 = 0;
echo $str3 == $str4 ? '相等' : '不相等';     // 相等

$str5 = 0;
$str6 = ’0′;
echo $str5 === $str6 ? '相等' : '不相等';   //  不相等

19、MySQL数据库中的字段类型varchar和char的主要区别是什么?那种字段的查找效率要高,为什么?

Varchar是变长,节省存储空间,char是固定长度。
查找效率: char类型快,因为varchar是非定长,必须先查找长度,然后进行数据的提取,比char定长类型多了一个步骤,所以效率低一些

20、PHP 数组排序

sort() - 以升序对数组排序
rsort() - 以降序对数组排序
asort() - 根据值,以升序对关联数组进行排序
ksort() - 根据键,以升序对关联数组进行排序
arsort() - 根据值,以降序对关联数组进行排序
krsort() - 根据键,以降序对关联数组进行排序

21、一群猴子排成一圈,按1,2,…,n依次编号。然后从第1只开始数,数到第m只,把它踢出圈,从它后面再开始数,再数到第m只,在把它踢出去…,如此不停的进行下去,直到最后只剩下一只猴子为止,那只猴子就叫做大王。要求编程模拟此过程,输入m、n, 输出最后那个大王的编号

方法1:
function King($n,$m) { 
    $res=0; 
    for($i=2; $i<=$n; $i++) {
        $res=($res+$m)%$i; 
    }
    return $res+1; 
} 
$leader = King(13,34);
echo $leader;

//方法2,定义函数
function getKing($monkeys , $m , $current = 0){
    $number = count($monkeys);
    $num = 1;
    if(count($monkeys) == 1){
      echo '<font color="red">编号为'.$monkeys[0].'的猴子成为猴王了!</font>';
      return;
    }else{
  while($num++ < $m){
    $current++;
    $current = $current%$number;
  }
  echo "编号为".$monkeys[$current]."的猴子被踢掉了...<br/>";
  array_splice($monkeys , $current , 1);
  getKing($monkeys, $m , $current);
  }
}
$n=13; //总共猴子数目
$m = 34; //数到第几只的那只猴子被踢出去
$monkeys = range(1,$n); //将猴子编号放入数组中
getKing($monkeys , $m); //调用函数    

28、使用过Memcache缓存吗,如果使用过,能够简单的描述一下它的工作原理吗?

Memcahce是把所有的数据保存在内存当中,采用hash表的方式,每条数据又key和value组成,每个key是独一无二的,当要访问某个值的时候先按照找到值,然后返回结果。
Memcahce采用LRU算法来逐渐把过期数据清除掉。

21、16.请描述出两点以上XHTML和HTML最显著的区别

(1)XHTML必须强制指定文档类型DocType,HTML不需要

(2)XHTML所有标签必须闭合,HTML比较随意

22、写一个排序算法,可以是冒泡排序或者是快速排序,假设待排序对象是一个维数组。

//冒泡排序(数组排序)

function bubbleSort($arr){

  // 统计所有元素

  $len = count($arr);

  for($i = 0; $i < $len; $i++) {

    for($k = $i+1; $k < $len; $k++) {

      if($arr[$i] > $arr[$k]) {

        $t = $arr[$k];

        $arr[$k] = $arr[$i];

        $arr[$i] = $t;

      }

    }

  }

  return $arr;

}

23、写出三种以上MySQL数据库存储引擎的名称(提示:不区分大小写)

MyISAM、InnoDB、BDB(Berkeley DB)、Merge、Memory(Heap)、Example、Federated、Archive、CSV、Blackhole、MaxDB 等等十几个引擎

24、求两个日期的差数,例如2007-2-5 ~ 2007-3-6 的日期差数

方法1:
function get_days($date1, $date2) {
    $time1 = strtotime($date1);
    $time2 = strtotime($date2);
    return ($time2-$time1)/86400;
}
echo get_days(’2007-2-5′, ’2007-3-6′);
方法2:
$temp = explode('-', '2007-2-5');
$time1 = mktime(0, 0, 0, $temp[1], $temp[2], $temp[0]);
$temp = explode('-', '2007-3-6');
$time2 = mktime(0, 0, 0, $temp[1], $temp[2], $temp[0]);
echo ($time2-$time1)/86400;
方法3:
echo abs(strtotime("2007-2-1")-strtotime("2007-3-1"))/60/60/24 计算时间差

25、请写一个函数,实现以下功能:字符串“open_door” 转换成 “OpenDoor”、”make_by_id” 转换成 ”MakeById”。

// 方法一
function str_explode($str){
    $str_arr=explode("_", $str);
    $str_implode=implode(" ",$str_arr);  
    $str_implode=implode("",explode("",ucwords($str_implode)));
    return $str_implode;
}
$strexplode = str_explode("make_by_id");
print_r($strexplode);
// 方法二 $str = "make_by_id!"; $expStr = explode("_", $str); for($i=0;$i<count($expStr);$i++){   echo ucwords($expStr[$i]); }
// 方法三 echo str_replace(' ', '', ucwords(str_replace('_', ' ', 'open_door')));// 替换掉_后,首字母大写,替换掉空格

26、一个表中的Id有多个记录,把所有这个id的记录查出来,并显示共有多少条记录数,用SQL语句及视图、

存储过程分别实现。

DELIMITER //

create procedure proc_countNum(in columnId int,out rowsNo int)

begin

select count(*) into rowsNo from member where member_id=columnId;

end

call proc_countNum(1,@no);

select @no;

方法:视图:

create view v_countNum as select member_id,count(*) as countNum from member group by

member_id

select countNum from v_countNum where member_id=1

27、js中网页前进和后退的代码

前进: history.forward();=history.go(1);

后退: history.back();=history.go(-1); 

28、下列代码输出什么?

echo count(null); // 0

echo count(' '); // 1

echo count(false); // 1

echo count('abc'); // 1

count — 计算数组中的单元数目或对象中的属性个数
int count ( mixed$var [, int $mode ] ), 如果 var 不是数组类型或者实现了 Countable 接口的对象,将返回1,有一个例外,如果 var 是 NULL 则结果是 0。
对于对象,如果安装了 SPL,可以通过实现 Countable 接口来调用 count()。该接口只有一个方法 count(),此方法返回 count() 函数的返回值。

32. php class中static,public,private,protected的区别?

static 静态,类名可以访问

public 表示全局,类内部外部子类都可以访问;

private  表示私有的,只有本类内部可以使用;

protected 表示受保护的,只有本类或子类或父类中可以访问;

33. HTTP协议中GET、POST和HEAD的区别?

HEAD: 只请求页面的首部。

GET: 请求指定的页面信息,并返回实体主体。

POST: 请求服务器接受所指定的文档作为对所标识的URI的新的从属实体。

(1)HTTP 定义了与服务器交互的不同方法,最基本的方法是 GET 和 POST。事实上 GET 适用于多数请求,而保留 POST 仅用于更新站点。

(2)在FORM提交的时候,如果不指定Method,则默认为GET请 求,Form中提交的数据将会附加在url之后,以?分开与url分开。字母数字字符原样发送,但空格转换为“+“号,其它符号转换为%XX,其中XX为 该符号以16进制表示的ASCII(或ISO Latin-1)值。GET请求请提交的数据放置在HTTP请求协议头中,而POST提交的数据则放在实体数据中;

GET方式提交的数据最多只能有1024字节,而POST则没有此限制。

(3)GET 这个是浏览器用语向服务器请求最常用的方法。POST这个方法也是用来传送数据的,但是与GET不同的是,使用POST的时候,数据不是附在URI后面传 递的,而是要做为独立的行来传递,此时还必须要发送一个Content_length标题,以标明数据长度,随后一个空白行,然后就是实际传送的数据。网 页的表单通常是用POST来传送的

fsockopen, A

2、用最少的代码写一个求3值最大值的函数.

function get_max($a,$b,$c) {
    return ($a > $b ? $a : $b) > $c ? ($a > $b ? $a : $b) : $c;
}

4、javascript能否定义二维数组,如果不能你如何解决?

javascript不支持二维数组定义,可以用arr[0] = new array()来解决

5、假设a.html和b.html在同一个文件夹下面,用javascript实现当打开a.html五秒钟后,自动跳转到b.html。

function test(){
    window.location = "b.html";
    window.close();
}
setTimeout( "test()",5000 ); //5秒钟后自动执行test()

8、写一个函数,能够遍历一个文件夹下的所有文件和子文件夹。

    <?php
     function my_dir($dir){
         $files=array();
         //注意这里要加一个@,不然会有warning错误提示
         if(@$handle=opendir($dir)){
             
             while(($file=readdir($handle))!==false){
                 //排除根目录;
                 if($file!=".." && $file!="."){
                
                     //如果是子文件夹,就进行递归 ;不是就将文件的名字存入数组;
                     if(is_dir($dir."/".$file)){
                         $files[$file]=my_dir($dir."/".$file);
                     }else{
                         $files[]=$file;
                     }
  
                 }
             }
             closedir($handle);
             return $files;
         }
     }
    //以下是测试
     $array=my_dir('C:/test');
     var_dump($array);

9、把 John 新增到 users 阵列?

$users[] = 'join';   
array_push($users, 'john');

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

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

16、写一个函数,尽可能高效的,从一个标准 url 里取出文件的扩展名

例如: http://www.sina.com.cn/abc/de/fg.php?id=1 需要取出 php 或 .php

<?php
function getExt($url){
    $arr  = parse_url($url);  // 解析url为数组
    $file = basename($arr['path']);  // $arr['path'] = "/abc/de/fg.php";
    $ext  = explode(".",$file);      // $file = "fg.php"; explode拆分字符串,返回一个数组
    return $ext[1];
}

17、使用五种以上方式获取一个文件的扩展名;要求:dir/upload.image.jpg,找出 .jpg 或者 jpg ,

必须使用PHP自带的处理函数进行处理,方法不能明显重复,可以封装成函数,比如 get_ext1($file_name), get_ext2($file_name)

// 方法1:
function get_ext1($file_name){ return strrchr($file_name, '.'); } // 方法2: function get_ext2($file_name){ return substr($file_name, strrpos($file_name, '.')); } // 方法3: function get_ext3($file_name){ return array_pop(explode('.', $file_name)); } // 方法4: function get_ext4($file_name){ $p = pathinfo($file_name); return $p['extension']; } // 方法5: function get_ext5($file_name){ return strrev(substr(strrev($file_name), 0, strpos(strrev($file_name), '.')));
}
18、以下代码的输出结果是?
$str1 = null;
$str2 = false;
echo $str1 == $str2 ? '相等' : '不相等'; // 相等
;
$str4 = 0;
echo $str3 == $str4 ? '相等' : '不相等';     // 相等

$str5 = 0;
$str6 = ’0′;
echo $str5 === $str6 ? '相等' : '不相等';   //  不相等

19、MySQL数据库中的字段类型varchar和char的主要区别是什么?那种字段的查找效率要高,为什么?

Varchar是变长,节省存储空间,char是固定长度。
查找效率: char类型快,因为varchar是非定长,必须先查找长度,然后进行数据的提取,比char定长类型多了一个步骤,所以效率低一些

20、PHP 数组排序

sort() - 以升序对数组排序
rsort() - 以降序对数组排序
asort() - 根据值,以升序对关联数组进行排序
ksort() - 根据键,以升序对关联数组进行排序
arsort() - 根据值,以降序对关联数组进行排序
krsort() - 根据键,以降序对关联数组进行排序

21、一群猴子排成一圈,按1,2,…,n依次编号。然后从第1只开始数,数到第m只,把它踢出圈,从它后面再开始数,再数到第m只,在把它踢出去…,如此不停的进行下去,直到最后只剩下一只猴子为止,那只猴子就叫做大王。要求编程模拟此过程,输入m、n, 输出最后那个大王的编号

方法1:
function King($n,$m) { 
    $res=0; 
    for($i=2; $i<=$n; $i++) {
        $res=($res+$m)%$i; 
    }
    return $res+1; 
} 
$leader = King(13,34);
echo $leader;

//方法2,定义函数
function getKing($monkeys , $m , $current = 0){
    $number = count($monkeys);
    $num = 1;
    if(count($monkeys) == 1){
      echo '<font color="red">编号为'.$monkeys[0].'的猴子成为猴王了!</font>';
      return;
    }else{
  while($num++ < $m){
    $current++;
    $current = $current%$number;
  }
  echo "编号为".$monkeys[$current]."的猴子被踢掉了...<br/>";
  array_splice($monkeys , $current , 1);
  getKing($monkeys, $m , $current);
  }
}
$n=13; //总共猴子数目
$m = 34; //数到第几只的那只猴子被踢出去
$monkeys = range(1,$n); //将猴子编号放入数组中
getKing($monkeys , $m); //调用函数    

28、使用过Memcache缓存吗,如果使用过,能够简单的描述一下它的工作原理吗?

Memcahce是把所有的数据保存在内存当中,采用hash表的方式,每条数据又key和value组成,每个key是独一无二的,当要访问某个值的时候先按照找到值,然后返回结果。
Memcahce采用LRU算法来逐渐把过期数据清除掉。

21、16.请描述出两点以上XHTML和HTML最显著的区别

(1)XHTML必须强制指定文档类型DocType,HTML不需要

(2)XHTML所有标签必须闭合,HTML比较随意

22、写一个排序算法,可以是冒泡排序或者是快速排序,假设待排序对象是一个维数组。

//冒泡排序(数组排序)

function bubbleSort($arr){

  // 统计所有元素

  $len = count($arr);

  for($i = 0; $i < $len; $i++) {

    for($k = $i+1; $k < $len; $k++) {

      if($arr[$i] > $arr[$k]) {

        $t = $arr[$k];

        $arr[$k] = $arr[$i];

        $arr[$i] = $t;

      }

    }

  }

  return $arr;

}

23、写出三种以上MySQL数据库存储引擎的名称(提示:不区分大小写)

MyISAM、InnoDB、BDB(Berkeley DB)、Merge、Memory(Heap)、Example、Federated、Archive、CSV、Blackhole、MaxDB 等等十几个引擎

24、求两个日期的差数,例如2007-2-5 ~ 2007-3-6 的日期差数

方法1:
function get_days($date1, $date2) {
    $time1 = strtotime($date1);
    $time2 = strtotime($date2);
    return ($time2-$time1)/86400;
}
echo get_days(’2007-2-5′, ’2007-3-6′);
方法2:
$temp = explode('-', '2007-2-5');
$time1 = mktime(0, 0, 0, $temp[1], $temp[2], $temp[0]);
$temp = explode('-', '2007-3-6');
$time2 = mktime(0, 0, 0, $temp[1], $temp[2], $temp[0]);
echo ($time2-$time1)/86400;
方法3:
echo abs(strtotime("2007-2-1")-strtotime("2007-3-1"))/60/60/24 计算时间差

25、请写一个函数,实现以下功能:字符串“open_door” 转换成 “OpenDoor”、”make_by_id” 转换成 ”MakeById”。

// 方法一
function str_explode($str){
    $str_arr=explode("_", $str);
    $str_implode=implode(" ",$str_arr);  
    $str_implode=implode("",explode("",ucwords($str_implode)));
    return $str_implode;
}
$strexplode = str_explode("make_by_id");
print_r($strexplode);
// 方法二 $str = "make_by_id!"; $expStr = explode("_", $str); for($i=0;$i<count($expStr);$i++){   echo ucwords($expStr[$i]); }
// 方法三 echo str_replace(' ', '', ucwords(str_replace('_', ' ', 'open_door')));// 替换掉_后,首字母大写,替换掉空格

26、一个表中的Id有多个记录,把所有这个id的记录查出来,并显示共有多少条记录数,用SQL语句及视图、

存储过程分别实现。

DELIMITER //

create procedure proc_countNum(in columnId int,out rowsNo int)

begin

select count(*) into rowsNo from member where member_id=columnId;

end

call proc_countNum(1,@no);

select @no;

方法:视图:

create view v_countNum as select member_id,count(*) as countNum from member group by

member_id

select countNum from v_countNum where member_id=1

27、js中网页前进和后退的代码

前进: history.forward();=history.go(1);

后退: history.back();=history.go(-1); 

28、下列代码输出什么?

echo count(null); // 0

echo count(' '); // 1

echo count(false); // 1

echo count('abc'); // 1

count — 计算数组中的单元数目或对象中的属性个数
int count ( mixed$var [, int $mode ] ), 如果 var 不是数组类型或者实现了 Countable 接口的对象,将返回1,有一个例外,如果 var 是 NULL 则结果是 0。
对于对象,如果安装了 SPL,可以通过实现 Countable 接口来调用 count()。该接口只有一个方法 count(),此方法返回 count() 函数的返回值。

32. php class中static,public,private,protected的区别?

static 静态,类名可以访问

public 表示全局,类内部外部子类都可以访问;

private  表示私有的,只有本类内部可以使用;

protected 表示受保护的,只有本类或子类或父类中可以访问;

33. HTTP协议中GET、POST和HEAD的区别?

HEAD: 只请求页面的首部。

GET: 请求指定的页面信息,并返回实体主体。

POST: 请求服务器接受所指定的文档作为对所标识的URI的新的从属实体。

(1)HTTP 定义了与服务器交互的不同方法,最基本的方法是 GET 和 POST。事实上 GET 适用于多数请求,而保留 POST 仅用于更新站点。

(2)在FORM提交的时候,如果不指定Method,则默认为GET请 求,Form中提交的数据将会附加在url之后,以?分开与url分开。字母数字字符原样发送,但空格转换为“+“号,其它符号转换为%XX,其中XX为 该符号以16进制表示的ASCII(或ISO Latin-1)值。GET请求请提交的数据放置在HTTP请求协议头中,而POST提交的数据则放在实体数据中;

GET方式提交的数据最多只能有1024字节,而POST则没有此限制。

(3)GET 这个是浏览器用语向服务器请求最常用的方法。POST这个方法也是用来传送数据的,但是与GET不同的是,使用POST的时候,数据不是附在URI后面传 递的,而是要做为独立的行来传递,此时还必须要发送一个Content_length标题,以标明数据长度,随后一个空白行,然后就是实际传送的数据。网 页的表单通常是用POST来传送的