代码如下:
<?php
/**
* php 面试题
* edit www.
* at 2013-05-13
*/
functiongbk_strrev($str){//----gbk中文字符串翻转-----
$len=strlen($str);
for($i=0;$i<$len;$i++){
$char=$str{0};
if(ord($char)>127){
$i++;
if($i<$len){
$arr[]=substr($str,0,2);
$str=substr($str,2);
}
}else{
$arr[]=$char;
$str=substr($str,1);
}
}
returnimplode(array_reverse($arr));
}
$str=’中文.look!’;
echo gbk_strrev($str);
functionutf8_strrev($string){//-----utf8中文翻转--------
$index=0;
$length=strlen($string);
while($first_b=substr($string,$index,1)){
if(ord($first_b)>224){
$arr[]=substr($string,$index,3);
$index+=3;
}elseif(ord($first_b)>192){
$arr[]=substr($string,$index,2);
$index+=2;
}else{
$arr[]=substr($string,$index,1);
$index+=1;
}
}
returnimplode(array_reverse($arr));
}
$str=’中文.look!’;
echo utf8_strrev($str);
functiongbk_substr($str,$length){//-----gbk截取中文字符串--------
$index=0;
$result=’’;
for($i=0;$i<$length;$i++){
$first_b=substr($str,$index,1);
if(ord($first_b)>127){
$result.= substr($str,$index,2);
$index+=2;
}else{
$result.= substr($str,$index,1);
$index+=1;
}
}
return$result;
}
$str = "你好china";
echo gbk_substr($str, 5);
functionutf8_substr($string,$length){//-----------utf8编码截取中文字符串-------------
$index=0;
$result=’’;
for($i=0;$i<$length;$i++){
$first_b=substr($string,$index,1);
if(ord($first_b)>224){
$result.= substr($string,$index,3);
$index+=3;
}elseif(ord($first_b>192)){
$result.= substr($string,$index,2);
$index+=2;
}else{
$result.= substr($string,$index,1);
$index+=1;
}
}
return$result;
}
$str = "你好china";
echo (utf8_substr($str, 3));
functionscan_dirs($path){//-----遍历目录------------
$path_source=opendir($path);
while(($file=readdir($path_source))!==false){
//if(is_dir($path.’/’.$file)&&$file!= ’.’&&$file !=’..’){
if(is_dir($path. ’/’ . $file) && $file != ’.’ && $file != ’..’) {
echo$path.’/’.$file,’<br>’;
scan_dirs($path.’/’.$file);
}else{
echo$path.’/’.$file,’<br>’;
}
}
}
$dir_name = ’E:/amp/apache/htdocs/mvc’;
scan_dirs($dir_name);
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){
$arr=explode()(’.’, $file_name);
return array_pop($arr);
}
function get_ext4($file_name){
$p = pathinfo($file_name);
return$p[’dirname’].’------’.$p[’basename’].’------’.$p[’extension’];
}
function get_ext5($file_name){
return strrev(substr(strrev($file_name), 0,strpos(strrev($file_name), ’.’)));
}
echoget_ext5(’E:/amp/apache/htdocs/mvc/init.html’);
functionmaopao($arr){//------冒泡排序法------------
$flag=false;
$count= count($arr);
for($i=0;$i<$count-1;$i++){
for($j=0;$j<$count-1-$i;$j++){
if($arr[$j]>$arr[$j+1]){
$tmp=$arr[$j];
$arr[$j]=$arr[$j+1];
$arr[$j+1]=$tmp;
$flag=true;
}
}
if($flag){
$flag=false;
}else{
break;
}
}
return$arr;
}
$arr=array(12,78,49,68,59,67,93,34,46,33);
var_dump(maopao($arr));
functionxuanze($arr){//---------选择排序----------
for($i=0;$i<count($arr);$i++){
$minIndex=$i;
$minVal=$arr[$i];
for($j=$i+1;$j<count($arr);$j++){
if($minVal>$arr[$j]){
$minVal=$arr[$j];
$minIndex=$j;
}
}
$tmp=$arr[$i];
$arr[$i]=$arr[$minIndex];
$arr[$minIndex]=$tmp;
}return$arr;
}
$arr=array(12,78,49,68,59,67,93,34,46,33);
var_dump(xuanze($arr));
functioninsertSort($arr){//------------插入排序法---------
for($i=1;$i<count($arr);$i++){
$insertVal=$arr[$i];
$insertIndex=$i-1;
while($insertIndex>=0&&$insertVal<=$arr[$insertIndex]){
$arr[$insertIndex+1]=$arr[$insertIndex];
$insertIndex--;
}
$arr[$insertIndex+1]=$insertVal;
}
return$arr;
}
$arr=array(12,78,49,68,59,67,93,34,46,33);
var_dump(insertSort($arr));
function quickSort($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);
}
$arr=array(12,78,49,68,59,67,93,34,46,33);
var_dump(quickSort($arr));
function seqSch($arr, $num){//---顺序查找-----
$flag=false;
for($i=0;$i<count($arr);$i++){
if($arr[$i]==$num){
echo ’找到了,下标为:’.$i;
$flag=true;
}
}
if(!$flag){
echo ’找不到’;
}
}
$arr=array(12,78,49,68,59,67,93,34,46,33);
seqSch($arr,34);
functionerFen($arr,$num,$leftIndex,$rightIndex){//----二分查找---前提数组比为有序数组---
if($leftIndex>=$rightIndex){return’找不到’;}
$midIndex=floor(($leftIndex+$rightIndex)/2);
$midValue=$arr[$midIndex];
if($midValue>$num){
returnerFen($arr,$num,$leftIndex,$midIndex-1);
}elseif($midValue<$num){
returnerFen($arr,$num,$midIndex+1,$rightIndex);
}else{
return$midIndex;
}
}
$arr=array(3,5,7,8,9,23,26,36);
$leftIndex=0;
$rightIndex=count($arr);
var_dump(erFen($arr,36,$leftIndex,$rightIndex));
?>
在PHP中,当前脚本的名称(不包括路径和查询字符串)记录在预定义变量(1)中;而链接到当前页面的URL记录在预定义变量(2)中。
echo $_SERVER['PHP_SELF']; echo $_SERVER["HTTP_REFERER"];
执行程序段<?php echo 8%(-2) ?>将输出(3)。
0
在HTTP 1.0中,状态码 401 的含义是(4);如果返回“找不到文件”的提示,则可用 header 函数,其语句为(5)。
(4)未授权 (5) header("HTTP/1.0 404 Not Found");
数组函数 arsort 的作用是(6);语句 error_reporting(2047)的作用是(7)。
(6)对数组进行逆向排序并保持索引关系 (7)All errors and warnings
PEAR中的数据库连接字符串格式是(8)。
写出一个正则表达式,过虑网页上的所有JS/VBS脚本(即把标记及其内容都去掉):(9)。
/<[^>].*?>.*?<\/>/si
以Apache模块的方式安装PHP,在文件http.conf中首先要用语句(10)动态装载PHP模块,然后再用语句(11)使得Apache把所有扩展名为php的文件都作为PHP脚本处理。
(10) LoadModule php5_module "D:/xampp/apache/bin/php5apache2.dll" (11) AddType application/x-httpd-php-source .phps AddType application/x-httpd-php .php .php5 .php4 .php3 .phtml
语句 include 和 require 都能把另外一个文件包含到当前文件中,它们的区别是(12);为了避免多次包含同一文件,可以用语句(13)来代替它们。
(12) 发生异常时include产生警告require产生致命错误 (13) require_once()/include_once()
类的属性可以序列化后保存到 session 中,从而以后可以恢复整个类,这要用到的函数是(14)。
serialize() /unserialize()
一个函数的参数不能是对变量的引用,除非在php.ini中把(15)设为on.
allow_call_time_pass_reference
SQL 中LEFT JOIN的含义是(16)。 如果 tbl_user记录了学生的姓名(name)和学号(ID), tbl_score记录了学生(有的学生考试以后被开除了,没有其记录)的学号(ID)和考试成绩(score)以及考试科目(subject), 要想打印出各个学生姓名及对应的的各科总成绩,则可以用SQL语句(17)。
(16) 自然左外连接 (17) select name , count(score) as sum_score from tbl_user left join tbl_score on tbl_user.ID=tbl_score.ID group by tbl_user.ID
在PHP中,heredoc是一种特殊的字符串,它的结束标志必须(18)。
结束标识符所在的行不能包含任何其它字符除";"
写一个函数,能够遍历一个文件夹下的所有文件和子文件夹。
* 遍历目录,结果存入数组。支持php4及以上。php5以后可用scandir()函数代替while循环。
* @param string $dir
* @return array
*/
my_scandir($dir)
{
$files = array();
if ( $handle = opendir($dir) )
{
while ( ($file = readdir($handle)) !== false )
{
if ( $file != ".." && $file != "." )
{
if ( is_dir($dir . "/" . $file) )
{
$files[$file] = rec_scandir($dir . "/" . $file);
}
else
{
$files[] = $file;
}
}
}
closedir($handle);
return $files;
}
}
简述论坛中无限分类的实现原理。
设计一个网页,使得打开它时弹出一个全屏的窗口,该窗口中有一个文本框和一个按钮。用户在文本框中输入信息后点击按钮就可以把窗口关闭,而输入的信息却在主网页中显示。
面试题1
1、 用PHP打印出前一天的时间格式是2006-5-10 22:21:21
2、 echo(),print(),print_r()的区别
3、 能够使HTML和PHP分离开使用的模板
4、 如何实现PHP、JSP交互?
5、 使用哪些工具进行版本控制?
6、 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) 写出以下程序的输出结果 $c?4:5; echo $a; ?>
2) 写出以下程序的输出结果
面试题4
一. 简答题
1. 请说明php中传值与传引用的区别。什么时候传值什么时候传引用?
2. 在PHP中error_reporting这个函数有什么作用?
3. 请写一个函数验证电子邮件的格式是否正确
4. 简述如何得到当前执行脚本路径,包括所得到参数。说明:例如有一个脚本 www.,传给他的参数有参数1,参数2,参数3…. 传递参数的方法有可能是GET有可能是POST,那么现在请写出类似
http://www./script.php? 参数1=值1&参数2=值2..... 的结果
5.如何修改SESSION的生存时间.
6..有一个网页地址 http://www./xxx.php,如何得到它的内容?
7. 有一个一维数组,里面存储整形数据,请写一个函数,将他们按从大到小的顺序排列。要求执行效率高。并说明如何改善执行效率。(该函数必须自己实现,不能使用php函数)
8. 请举例说明在你的开发过程中用什么方法来加快页面的加载速度。
二. 数据库设计题:
请设计一套图书馆借书管理系统的数据库表结构;可以记录基本的用户信息、图书信息、借还书信息;数据表的个数不超过6个;请画表格描述表结构(需要说明每个字段的字段名、字段类型、字段含义描述);在数据库设计中应:
1.保证每个用户的唯一性;
2.保证每种图书的唯一性;每种图书对应不等本数的多本图书;保证每本图书的唯一性;
3.借书信息表中,应同时考虑借书行为与还书行为,考虑借书期限;
4.保证借书信息表与用户表、图书信息表之间的参照完整性;
5.限制每个用户最大可借书的本数
6.若有新用户注册或新书入库,保证自动生成其唯一性标识
7.为以下的一系列报表需求提供支持:(无特定说明,不需编写实现语句,而需在数据库设计中,保证这些报表可以用最多一条SQL语句实现)
a) 日统计报表:当日借书本数、当日还书本数报表;
b) 实时报表: i. 当前每种书的借出本数、可借本数; ii. 当前系统中所有超期图书、用户的列表及其超期天数iii. 当前系统中所有用户借书的本数,分用户列出(包括没有借书行为的用户);请编写实现此需求的SQL语句:数据库应用:请撰写一系列的SQL语句,分别描述完整的借书行为与还书行为;并保证这一系列的SQL语句的执行完整性下题是测验能力之最重要测试,如不能完成我们将无法给出评判结果!所以请写出详细的回答,并保证答案是可以执行的程序。在两日内将结果通过电子邮件寄到邮箱结合第二题中你的设计,用一种数据库实现,要求使用三层结构或者多层结构,要求采用面向对象的思想进行编程,有可能的话,设计一套模板机制来实现之。
功能:
列出当前借出图书的情况 ,按日期排列编号用户姓名书名书的编号借出日期
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 ....WHERE ________