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 相关文章推荐
php 数组二分法查找函数代码
Feb 16 PHP
php利用腾讯ip分享计划获取地理位置示例分享
Jan 20 PHP
php根据isbn书号查询amazon网站上的图书信息的示例
Feb 13 PHP
Centos下升级php5.2到php5.4全记录(编译安装)
Apr 03 PHP
php实现搜索一维数组元素并删除二维数组对应元素的方法
Jul 06 PHP
php链表用法实例分析
Jul 09 PHP
10个对初学者非常有用的PHP技巧
Apr 06 PHP
Zend Framework教程之Zend_Helpers动作助手ViewRenderer用法详解
Jul 20 PHP
PHP环形链表实现方法示例
Sep 15 PHP
php用xpath解析html的代码实例讲解
Feb 14 PHP
深入学习微信网址链接解封的防封原理visit_type
Aug 15 PHP
ThinkPHP 5 AJAX跨域请求头设置实现过程解析
Oct 28 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
把77A收信机改造成收音机
2021/03/02 无线电
改德生G88 - 加装等响度低音提升电路
2021/03/02 无线电
php MYSQL 数据备份类
2009/06/19 PHP
PHP自动识别字符集并完成转码详解
2013/08/02 PHP
PHP常用工具类大全附全部代码下载
2015/12/07 PHP
Prototype Number对象 学习
2009/07/19 Javascript
基于Jquery的将DropDownlist的选中值赋给label的实现代码
2011/05/06 Javascript
jquery如何把参数列严格转换成数组实现思路
2013/04/01 Javascript
javascript 实现 秒杀,团购 倒计时展示的记录 分享
2013/07/12 Javascript
js实现页面转发功能示例代码
2013/08/05 Javascript
解析jquery中的ajax缓存问题
2013/12/19 Javascript
按Enter键触发事件的jquery方法实现代码
2014/02/17 Javascript
详解Nodejs基于mongoose模块的增删改查的操作
2016/12/21 NodeJs
利用canvas实现的加载动画效果实例代码
2017/07/05 Javascript
简述jQuery Easyui一些用法
2017/08/01 jQuery
JS实现身份证输入框的输入效果
2017/08/21 Javascript
VueJS 集成 Medium Editor的示例代码 (自定义编辑器按钮)
2017/08/24 Javascript
基于node.js的fs核心模块读写文件操作(实例讲解)
2017/09/10 Javascript
js传递数组参数到后台controller的方法
2018/03/29 Javascript
Express的HTTP重定向到HTTPS的方法
2018/06/06 Javascript
微信小程序动画组件使用解析,类似vue,且更强大
2019/08/01 Javascript
python实现保存网页到本地示例
2014/03/16 Python
Python中计算三角函数之cos()方法的使用简介
2015/05/15 Python
浅谈pandas中DataFrame关于显示值省略的解决方法
2018/04/08 Python
Python获取昨天、今天、明天开始、结束时间戳的方法
2018/06/01 Python
Python实例方法、类方法、静态方法的区别与作用详解
2019/03/25 Python
pymysql模块的使用(增删改查)详解
2019/09/09 Python
Python+OpenCV实现图像的全景拼接
2020/03/05 Python
利用纯html5绘制出来的一款非常漂亮的时钟
2015/01/04 HTML / CSS
英国家电购物网站:Sonic Direct
2019/03/26 全球购物
吸烟检讨书2000字
2014/02/13 职场文书
亮化工程实施方案
2014/03/17 职场文书
党的群众路线教育实践活动通讯稿
2014/09/10 职场文书
党的群众路线个人对照检查材料
2014/09/23 职场文书
2015年计算机教师工作总结
2015/07/22 职场文书
详解Vue slot插槽
2021/11/20 Vue.js