PHP的面试题集


Posted in PHP onNovember 19, 2006

面试题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.执行程序段<?php echo 8%(-3) ?>将输出(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 

PHP 相关文章推荐
ftp类(myftp.php)
Oct 09 PHP
php字符编码转换之gb2312转为utf8
Oct 28 PHP
php顺序查找和二分查找示例
Mar 27 PHP
浅谈PHP解析URL函数parse_url和parse_str
Nov 11 PHP
php用户注册信息验证正则表达式
Nov 12 PHP
PHP实现操作redis的封装类完整实例
Nov 14 PHP
简单了解将WordPress中的工具栏移到底部的小技巧
Dec 31 PHP
PHP模板引擎Smarty中变量的使用方法示例
Apr 11 PHP
详解PHP防止盗链防止迅雷下载的方法
Apr 26 PHP
PHP+原生态ajax实现的省市联动功能详解
Aug 15 PHP
php实现的中秋博饼游戏之掷骰子并输出结果功能详解
Nov 06 PHP
PHP html_entity_decode()函数讲解
Feb 25 PHP
php+mysql实现无限级分类 | 树型显示分类关系
Nov 19 #PHP
PHP生成静态页面详解
Nov 19 #PHP
smarty实例教程
Nov 19 #PHP
PHP编程中八种常见的文件操作方式
Nov 19 #PHP
PHP初学入门
Nov 19 #PHP
PHP5新特性: 更加面向对象化的PHP
Nov 18 #PHP
Windows中安装Apache2和PHP4权威指南
Nov 18 #PHP
You might like
php中explode与split的区别介绍
2012/10/03 PHP
php清除和销毁session的方法分析
2015/03/19 PHP
PHP实现网站访问量计数器
2017/10/27 PHP
PHP实现随机发扑克牌
2020/04/22 PHP
DOMAssitant最新版 DOMAssistant 2.5发布
2007/12/25 Javascript
网站导致浏览器崩溃的原因总结(多款浏览器) 推荐
2010/04/15 Javascript
js 点击按钮弹出另一页,选择值后,返回到当前页
2010/05/26 Javascript
解决jquery1.9不支持browser对象的问题
2013/11/13 Javascript
脚本合并提升javascript性能示例
2014/02/24 Javascript
JavaScript保留两位小数的2个自定义函数
2014/05/05 Javascript
javascript实现在网页中运行本地程序的方法
2016/02/03 Javascript
自己动手制作基于jQuery的Web页面加载进度条插件
2016/06/03 Javascript
对象转换为原始值的实现方法
2016/06/06 Javascript
文本框只能输入数字的实现方法(兼容IE火狐)
2016/06/25 Javascript
AngularJS打开页面隐藏显示表达式用法示例
2016/12/25 Javascript
JSON在Javascript中的使用(eval和JSON.parse的区别)详细解析
2017/09/05 Javascript
AngularJS中重新加载当前路由页面的方法
2018/03/09 Javascript
微信小程序实现跑马灯效果完整代码(附效果图)
2018/05/30 Javascript
Vue.js中的高级面试题及答案
2020/01/13 Javascript
extjs图表绘制之条形图实现方法分析
2020/03/06 Javascript
微信小程序分享小程序码的生成(带参数)以及参数的获取
2020/03/25 Javascript
浅谈JS for循环中使用break和continue的区别
2020/07/21 Javascript
Django框架中的对象列表视图使用示例
2015/07/21 Python
Python松散正则表达式用法分析
2016/04/29 Python
Python实现网络端口转发和重定向的方法
2016/09/19 Python
Python数据拟合与广义线性回归算法学习
2017/12/22 Python
详解Python中的四种队列
2018/05/21 Python
tensorflow 2.0模式下训练的模型转成 tf1.x 版本的pb模型实例
2020/06/22 Python
python使用建议与技巧分享(二)
2020/08/17 Python
Python如何实现单例模式
2016/06/03 面试题
出纳的岗位职责
2013/11/09 职场文书
实习会计求职自荐信范文
2014/03/10 职场文书
我的中国梦演讲稿初中篇
2014/08/19 职场文书
党员学习党的群众路线思想汇报(5篇)
2014/09/10 职场文书
2014年内部审计工作总结
2014/12/09 职场文书
感动中国何玥观后感
2015/06/02 职场文书