您的位置:首页 > 职场人生

php面试题

2014-04-18 14:00 281 查看
面试题一

 

1、表单提交get和post有何区别?

答:get的方式是把数据在地址栏中发送,get传送的数据量较小,不能大于2KB。post传送的数据量较大,一般被默认为不受限制。但理论上,IIS4中最大量为80KB,IIS5中为100KB。

2、用PHP打印出前一天的时间格式是2006-5-1022:21:21

echo date("Y-m-dH:i:s",time()-(3600*24));或echodate("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系统的负载均衡设置

 

面试题二

1、PHP/MySQL编程

 

1) 某内容管理系统中,表message有如下字段

id 文章id

title 文章标题

content 文章内容

category_id 文章分类id

hits 点击量

 

创建上表,写出MySQL语句

 

2)同样上述内容管理系统:表comment记录用户回复内容,字段如下

comment_id 回复id

id 文章id,关联message表中的id

comment_content 回复内容

 

现通过查询数据库需要得到以下格式的文章标题列表,并按照回复数量排序,回复最高的排在最前面

 

文章id 文章标题点击量回复数量

 

 

 

用一个SQL语句完成上述查询,如果文章没有回复则回复数量显示为0

 

 

3) 上述内容管理系统,表category保存分类信息,字段如下

 

category_id int(4) not null auto_increment;

categroy_name varchar(40) not null;

 

用户输入文章时,通过选择下拉菜单选定文章分类

 

写出如何实现这个下拉菜单

 

 

2、PHP文件操作

 

1)

上述内容管理系统:用户提交内容后,系统生成静态HTML页面;写出实现的基本思路

ob_start();

 

 

 

3、实现中文字串截取无乱码的方法。

这个首先要考虑字符集的问题,UTF-8下一个汉字占3字节,GBK下一个汉字占2字节.可以自己写个函数来处理,别人也写了很多,当然也可以开启mbstring扩展库,使用里面的mb_substr()等函数来截取。当截取字符出现乱码时,是因为汉字被截断了,可以再字符串尾部连上一个chr(0)

 

 

var $empty       = '';

var $null        = NULL;

var $bool        = FALSE;

var $notSet;

var $array       = array();

 

面试题三

 

1.

$a = "hello";

$b = &$a;

unset($b);

$b = "world";

what is $a?

hello,unset($b)只是释放了$b自己和$a的别名关系,并不会释放$a

 

2.

$a = 1;

$x = &$a;

$b = $a++;

what is $b?

1,先执行$b = $a,$a++再进行,所以$b还是1

 

3.

$x = empty($array);

what is $x?   true   or    false

true,$array是空数组

 

4.您是否用过版本控制软件? 如果有您用的版本控制软件的名字是?

CVS:winCVS,是一个CVS的客户端

VSS,微软的产品,比较适合中小型项目,只支持单人checkout

 

 

5.您是否用过模板引擎? 如果有您用的模板引擎的名字是?

SMARTY,php官方推荐的模板引擎,它是编译型模板,与phplib不太相同,功能强大,30多种标签,支持cache

 

 

6.请简单阐述您最得意的开发之作.

hdwiki,开源项目,mediawiki的使用性国人很不适应,代码修改起来也比较困难.hdwiki比较适合目前的国人使用.

 

 

7.对于大流量的网站,您采用什么样的方法来解决访问量问题?

1 squid反向代理

 

 

8、谈谈事务处理

可以控制并发操作所产生的数据同步提交、更新所带来的冲突问题.可以进行comit,rollback操作,数据的安全性得到了提高。

 

 

 

 

2) 简单描述用户修改以发布内容的实现流程和基本思路

 

 

9、PHP程序

 

1) 写出以下程序的输出结果

<?

 

$b=201;

 

$c=40;

 

$a=$b>$c?4:5;

 

echo $a;

 

?>

4

 

2) 写出以下程序的输出结果

 

<?

 

$str="cd";

 

$$str="hotdog";

 

$$str.="ok";

 

echo $cd;

 

?>

 

hotdogok

面试题四

 

一. 简答题

1. 请说明php中传值与传引用的区别。什么时候传值什么时候传引用?

2. 在PHP中error_reporting这个函数有什么作用?

3. 请写一个函数验证电子邮件的格式是否正确

4. 简述如何得到当前执行脚本路径,包括所得到参数。

说明:例如有一个脚本www.domain.com,传给他的参数有参数1,参数2,参数3….

传递参数的方法有可能是GET有可能是POST,那么现在请写出类似
http://www.domain.com/script.php? 参数1=值1&参数2=值2..... 的结果
5.如何修改SESSION的生存时间.

6..有一个网页地址 http://www.domain.com/xxx.php,如何得到它的内容?

7. 有一个一维数组,里面存储整形数据,请写一个函数,将他们按从大到小的顺序排列。要求执行效率高。并说明如何改善执行效率。(该函数必须自己实现,不能使用php函数)

8. 请举例说明在你的开发过程中用什么方法来加快页面的加载速度。

 

 

二. 数据库设计题:

请设计一套图书馆借书管理系统的数据库表结构;可以记录基本的用户信息、图书信息、借还书信息;数据表的个数不超过6个;请画表格描述表结构(需要说明每个字段的字段名、字段类型、字段含义描述);

 

在数据库设计中应:

1.保证每个用户的唯一性;

2.保证每种图书的唯一性;每种图书对应不等本数的多本图书;保证每本图书的唯一性;

3.借书信息表中,应同时考虑借书行为与还书行为,考虑借书期限;

4.保证借书信息表与用户表、图书信息表之间的参照完整性;

5.限制每个用户最大可借书的本数

6.若有新用户注册或新书入库,保证自动生成其唯一性标识

7.为以下的一系列报表需求提供支持:

(无特定说明,不需编写实现语句,而需在数据库设计中,保证这些报表可以用最多一条SQL语句实现)

a) 日统计报表:当日借书本数、当日还书本数报表;

b) 实时报表:

i. 当前每种书的借出本数、可借本数;

ii. 当前系统中所有超期图书、用户的列表及其超期天数

iii. 当前系统中所有用户借书的本数,分用户列出(包括没有借书行为的用户);请编写实现此需求的SQL语句:

 

数据库应用:

请撰写一系列的SQL语句,分别描述完整的借书行为与还书行为;并保证这一系列的SQL语句的执行完整性

下题是测验能力之最重要测试,如不能完成我们将无法给出评判结果!所以请写出详细的回答,并保证答案是可以执行的程序。在两日内将结果通过电子邮件寄到hr@88keke.com邮箱

 

结合第二题中你的设计,用一种数据库实现,要求使用三层结构或者多层结构,要求采用面向对象的思想进行编程,有可能的话,设计一套模板机制来实现之。

 

功能:列出当前借出图书的情况 ,按日期排列

 

编号用户姓名书名书的编号借出日期

1. 张进大染坊 12576587 2004-9-1

2. 刘兴西游记 32131098 2004-9-2

……

 

 

面试题五

 

1.在PHP中,当前脚本的名称(不包括路径和查询字符串)记录在预定义变量(1)中;而链接到当前页面的URL记录在预定义变量(2)中。

 

2.执行程序段<?php echo 8%(-3) ?>将输出(2)。

 

3.在HTTP 1.0中,状态码 401 的含义是(4);如果返回“找不到文件”的提示,则可用header 函数,其语句为(5)。

 

4.数组函数 arsort 的作用是(6);语句 error_reporting(2047)的作用是(7)。

 

5.PEAR中的数据库连接字符串格式是(8)。

 

 

6.写出一个正则表达式,过虑网页上的所有JS/VBS脚本(即把script标记及其内容都去掉):(9)。

 

7.以Apache模块的方式安装PHP,在文件http.conf中首先要用语句(10)动态装载PHP模块,然后再用语句(11)使得Apache把所有扩展名为php的文件都作为PHP脚本处理。

 

 

8.语句 include 和 require 都能把另外一个文件包含到当前文件中,它们的区别是(12);为了避免多次包含同一文件,可以用语句(13)来代替它们。

 

9.类的属性可以序列化后保存到 session 中,从而以后可以恢复整个类,这要用到的函数是(14)。

 

10.一个函数的参数不能是对变量的引用,除非在php.ini中把(15)设为on.

 

11.SQL 中LEFT JOIN的含义是(16)。如果 tbl_user记录了学生的姓名(name)和学号(ID),tbl_score记录了学生(有的学生考试以后被开除了,没有其记录)的学号(ID)和考试成绩(score)以及考试科目(subject),要想打印出各个学生姓名及对应的的各科总成绩,则可以用SQL语句(17)。

 

12.在PHP中,heredoc是一种特殊的字符串,它的结束标志必须(18)。

 

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

 

14.简述论坛中无限分类的实现原理。

 

15.设计一个网页,使得打开它时弹出一个全屏的窗口,该窗口中有一个文本框和一个按钮。用户在文本框中输入信息后点击按钮就可以把窗口关闭,而输入的信息却在主网页中显示。

 

16.有一表 menu(mainmenu,submenu,url),请用递归法写出一树形菜单,将所有的menu列出来。

 

面试题六

 

1- 给你三个数,写程序求出其最大值。

2- 谈谈asp,php,jsp的优缺点

3- 谈谈对mvc的认识

4- 写出发贴数最多的十个人名字的SQL,利用下表:

  members(id,username,posts,pass,email)

5-如何通过javascript判断一个窗口是否已经被屏蔽。

6-写出session的运行机制

7-有一数组 $a=array(4,3,8,9,2);请将其重新排序,按从小到大的顺序列出。

8-防止SQL注射漏洞一般用_____函数。

9-查询在线人数,并能处理异常掉线的SQL

....WHERE ________<now()

 

面试题七

 

一、基础题1. 写出如下程序的输出结果

<?

$str1 = null;

$str2 = false;

echo $str1==$str2 ? ‘相等’ : ‘不相等’;

 

$str3 = ”;

$str4 = 0;

echo $str3==$str4 ? ‘相等’ : ‘不相等’;

 

$str5 = 0;

$str6 = ‘0′;

echo $str5===$str6 ? ‘相等’ : ‘不相等’;

?>

 

相等相等不相等

2. 写出如下程序的输出结果

<?

$a1 = null;

$a2 = false;

$a3 = 0;

$a4 = ”;

$a5 = ‘0′;

$a6 = ‘null’;

$a7 = array();

$a8 = array(array());

 

echo empty($a1) ? ‘true’ : ‘false’;

echo empty($a2) ? ‘true’ : ‘false’;

echo empty($a3) ? ‘true’ : ‘false’;

echo empty($a4) ? ‘true’ : ‘false’;

echo empty($a5) ? ‘true’ : ‘false’;

echo empty($a6) ? ‘true’ : ‘false’;

echo empty($a7) ? ‘true’ : ‘false’;

echo empty($a8) ? ‘true’ : ‘false’;

?>

True true true true true false true false

3. 写出如下程序的输出结果

<?

$test = ‘aaaaaa’;

$abc = & $test;

unset($test);

 

echo $abc;

?>

aaaaaa

 

4. 写出如下程序的输出结果

<?$count = 5;

function get_count(){

static $count = 0;

return $count++;

}

 

echo $count;

++$count;

echo get_count();

echo get_count();

?>

501

 

5. 写出如下程序的输出结果

<?

$GLOBALS['var1'] = 5;

$var2 = 1;

function get_value(){

global $var2;

$var1 = 0;

return $var2++;

}

get_value();

 

echo $var1;

echo $var2;

?>

52

 

6. 写出如下程序的输出结果

<?

function get_arr($arr){

unset($arr[0]);

}

$arr1 = array(1, 2);

$arr2 = array(1, 2);

 

get_arr(&$arr1);

get_arr($arr2);

 

echo count($arr1);

echo count($arr2);

?>

7. 使用五种以上方式获取一个文件的扩展名

 

要求:dir/upload.image.jpg,找出 .jpg 或者 jpg ,

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

 

二、算法题

1. 使用PHP描述冒泡排序和快速排序算法,对象可以是一个数组

 

2. 使用PHP描述顺序查找和二分查找(也叫做折半查找)算法,顺序查找必须考虑效率,对象可以是一个有序数组

 

3. 写一个二维数组排序算法函数,能够具有通用性,可以调用php内置函数

【附答案】(以下答案不一定是最好的,只是一个简单的参考)

 

一、基础题

 

1. 相等相等不相等

2. true true true true true false truefalse

3. aaaaaa

4. 5 0 1

5. 5 2

6. 1 2

7. 使用五种以上方式获取一个文件的扩展名

 

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), ‘.’)));

}

 

二、算法题

 

1. 使用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);

}

2. 使用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;

}

}

3. 写一个二维数组排序算法函数,能够具有通用性,可以调用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;

}

 

一份php面试题(附答案)

2007-06-25 10:36

考的很基础,但基础不牢,有一批不会做。像在HTTP1.0中,状态码 401 的含义,error_reporting(2047)这些不知道。但用2047似乎有点儿变态,太不易读。

 

如果可以参考手册~~~~

 

* 1.在PHP中,当前脚本的名称(不包括路径和查询字符串)记录在预定义变量(echo $_SERVER['PHP_SELF'];)中;而链接到当前页面的URL记录在预定义变量(echo$_SERVER["HTTP_REFERER"];)中。

2.执行程序段<?php echo 8%(-2) ?>将输出(0)。

3.在HTTP 1.0中,状态码 401 的含义是(未授权);如果返回“找不到文件”的提示,则可用 header 函数,其语句为(header(“HTTP/1.0404
Not Found”);)。

4.数组函数 arsort 的作用是(对数组进行逆向排序并保持索引关系);语句 error_reporting(2047)的作用是(All errorsand warnings)。

5.PEAR中的数据库连接字符串格式是(8)。

6.写出一个正则表达式,过虑网页上的所有JS/VBS脚本(即把script标记及其内容都去掉):(/<script[^>].*?>.*?<\/script>/si)。

7.以Apache模块的方式安装PHP,在文件http.conf中首先要用语句(LoadModule  )动态装载PHP模块,然后再用语句(11)使得Apache把所有扩展名为php的文件都作为PHP脚本处理。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: