Heim >php教程 >php手册 >PHP的面试题集

PHP的面试题集

WBOY
WBOYOriginal
2016-06-13 12:36:271126Durchsuche

面试题1
1、用PHP打印出前一天的时间格式是2006-5-10 22:21:21
2、echo(),print(),print_r()的区别
3、能够使HTML和PHP分离开使用的模板
4、如何实现PHP、JSP交互?
5、使用哪些工具进行版本控制?
6、如何实现字符串翻转?
7、优化MYSQL数据库的方法。
8、谈谈事务处理
9、apache+mysql+php实现最大负载的方法
10、实现中文字串截取无乱码的方法。

面试题2
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?

2.
$a = 1;
$x = &$a;
$b = $a++; 
what is $b?


3.
$x = empty($array);
what is $x?   true    or    false


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






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




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



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





8.用PHP写出显示客户端IP与服务器IP的代码:


面试题3
一、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; 

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

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


二、PHP文件操作 

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

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


三、PHP程序 

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

$b=201; 

$c=40; 

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

echo $a; 

?> 


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

 

$str="cd"; 

$$str="hotdog"; 

$$str.="ok"; 

echo $cd; 

?> 


面试题4
一. 简答题 
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 
……


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

2.执行程序段将输出(3)。 

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

面试题6

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

面试题7

1- 给你三个数,写程序求出其最大值。
2- 谈谈asp,php,jsp的优缺点
3- 谈谈对mvc的认识
4- 写出发贴数最多的十个人名字的SQL,利用下表:
   members(id,username,posts,pass,email)

面试题8
1-如何通过javascript判断一个窗口是否已经被屏蔽。
2-写出session的运行机制
3-有一数组 $a=array(4,3,8,9,2);请将其重新排序,按从小到大的顺序列出。
4-防止SQL注射漏洞一般用_____函数。
5-查询在线人数,并能处理异常掉线的SQL 

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn