php 面试题

泡过江湖 分享 时间: 收藏本文

【简介】感谢网友“泡过江湖”参与投稿,下面是小编给大家带来的php 面试题(共8篇),以供大家参考,我们一起来看看吧!

篇1:php经典面试题

1、用PHP打印出前一天的时间格式是-02-10 22:21:21(2分)

echo date('Y-m-d H:i:s', strtotime('-1 day'));

或者

$yesterday = time - (24 * 60 * 60);

echo 'today:'.date('Y-m-d H:i:s').“n”;

echo 'yesterday:'. date('Y-m-d H:i:s', $yesterday).“n”;

2、echo(),print(),print_r()的区别(3分)

echo是PHP语句, print和print_r是函数,语句没有返回值,函数可以有返回值(即便没有用)

print只能打印出简单类型变量的值(如int,string)

print_r可以打印出复杂类型变量的值(如数组,对象)

echo -- 输出一个或者多个字符串

3、能够使HTML和PHP分离开使用的模板(1分)

smarty,Heyes Template Class等

5、使用哪些工具进行版本控制?(1分)

CVS和SVN,SVN号称下一代CVS,功能强大,不过CVS是老牌,市占率很高.我一直用SVN,题目是问用什么工具呃,这个可能需要这么回答:CVS Server on Apache作服务端,WinCVS作客户端;Subversion on Apache/DAV 做服务端,TortoiseSVN做客户端,或者Subclipse做客户端.

6、如何实现字符串翻转?(3分)

strrev()

或者

$str = “abcdefg”;

function strrevv($str)

{

$len=strlen($str);

$newstr = '';

for($i=$len;$i>=0;$i--)

{

$newstr .= $str{$i};

}

return $newstr;

}

$showstr = strrevv($str);

echo $showstr.“

”;

---------------------------------------------------------------

7、优化MYSQL数据库的方法。(4分,多写多得)

(1).选取最适用的字段属性,应该尽量把字段设置为NOT NULL,这样在将来执行查询的时候,数据库不用去比较NULL值。

(2).使用连接(JOIN)来代替子查询(Sub-Queries)

(3).使用联合(UNION)来代替手动创建的临时表

(4).尽量少使用 LIKE 关键字和通配符

(5).使用事务和外键

或者

(1).数据库设计方面,这是DBA和Architect的责任,设计结构良好的数据库,必要的时候,去正规化(英文是这个:denormalize,中文翻译成啥我不知道),允许部分数据冗余,避免JOIN操作,以提高查询效率

(2).系统架构设计方面,表散列,把海量数据散列到几个不同的表里面.快慢表,快表只留最新数据,慢表是历史存档.集群,主服务器Read & write,从服务器read only,或者N台服务器,各机器互为Master

(3).(1)和(2)超越PHP Programmer的要求了,会更好,不会没关系.检查有没有少加索引

(4).写高效的SQL语句,看看有没有写低效的SQL语句,比如生成笛卡尔积的全连接啊,大量的Group By和order by,没有limit等等.必要的时候,把数据库逻辑封装到DBMS端的存储过程里面.缓存查询结果,explain每一个sql语句

(5).所得皆必须,只从数据库取必需的数据,比如查询某篇文章的评论数,select count(*) ... where article_id = 就可以了,不要先select * ... where article_id = 然后msql_num_rows.只传送必须的SQL语句,比如修改文章的时候,如果用户只修改了标题,那就... set title = where article_id = 不要set content = (大文本)

(6).必要的时候用不同的存储引擎.比如InnoDB可以减少死锁.HEAP可以提高一个数量级的查询速度

8、PHP的意思(送1分)

Hypertext Preprocessor

9、MYSQL取得当前时间的函数是?,格式化日期的函数是(2分)

now(), DATE_FORMAT(date,format)

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

mb_substr()

---------------------------------------------------------------

11、您是否用过版本控制软件? 如果有您用的版本控制软件的名字是?(1分)

TortoiseSVN-1.2.6 svn-1.2.3

12、您是否用过模板引擎? 如果有您用的模板引擎的名字是?(1分)

smarty

13、请简单阐述您最得意的开发之作(4分)

这个自己想,因为你不再是菜鸟,每个人都有不同的思路,思路也会随之自己的知识而改变……

14、对于大流量的网站,您采用什么样的方法来解决访问量问题?(4分)

首先,确认服务器硬件是否足够支持当前的流量

其次,优化数据库访问。

第三,禁止外部的盗链。

第四,控制大文件的下载。

第五,使用不同主机分流主要流量

第六,使用流量分析统计软件。

-----------------------------------------------------------------

15、用PHP写出显示客户端IP与服务器IP的代码1分)

//显示客户端I

function get_client_ip() {#

if(getenv('HTTP_CLIENT_IP')) {

$client_ip = getenv('HTTP_CLIENT_IP');

} elseif(getenv('HTTP_X_FORWARDED_FOR')) {

$client_ip = getenv('HTTP_X_FORWARDED_FOR');

} elseif(getenv('REMOTE_ADDR')) {

$client_ip = getenv('REMOTE_ADDR');

} else {

$client_ip = $HTTP_SERVER_VAR['REMOTE_ADDR'];

}

return $client_ip;

}

//服务器IP

function get_server_ip(){

if (isset($_SERVER))

{

if($_SERVER['SERVER_ADDR']) $huoqu_ip=$_SERVER['SERVER_ADDR'];

else $huoqu_ip=$_SERVER['LOCAL_ADDR'];

}

else

{

$huoqu_ip=getenv('SERVER_ADDR');

}

return $huoqu_ip;

}

16、语句include和require的区别是什么?为避免多次包含同一文件,可用(?)语句代替它们? (2分)

require()和include()除了怎样处理失败之外在各方面都完全一样。include()产生一个警告而require()则导致一个致命错误。

换句话说,如果你想在丢失文件时停止处理页面,用require()。include() 就不是这样,脚本会继续运行。

require()无论如何都会包含文件,而include()可以有选择地包含.www.

代替用

include_once

require_once

17、如何修改SESSION的生存时间(1分).(没有测试)

$savePath = “./session_save_dir/”;

$lifeTime = 24 * 3600;

session_save_path($savePath);

session_set_cookie_params($lifeTime);

session_start();

18、有一个网页地址, 比如PHPma主页: www.phpma.com,如何得到它的内容?($1分)

file_get_contents($url)

19、在HTTP 1.0中,状态码401的含义是(?);如果返回“找不到文件”的提示,则可用 header 函数,其语句为(?);(2分)

未授权(Unauthorized)

Header(“http/1.0 403 Forbidden”);

经典面试题(PHP基础型II)附答案来源:本站编辑 作者:phpma 时间:2009-02-13 Tag:PHP 经典面试题 (基础型II) 附答案 点击: 44 求职与招聘 往往少不了面试与笔试,作为一个php程序员、多多少少都会有类似的经历……以下是本人收集并整理的PHP面试题目,希望对同行们有所帮助,找到一份合适的php开发工作!(共三节)

以下是面试的题目(一), 下一篇:经典面试题(PHP基础型III)附答案 PHP已经赋予答案:

12、在PHP中,heredoc是一种特殊的字符串,它的结束标志必须?(1分)

在大部分语言里,双引号是字符串,单引号是字符。但是在PHP里,字符串的表现形式有3种。即:

单引号

双引号

定界符(heredoc syntax)

看见了吧,单引号居然可以用来表示字符串。那么如果我想表示单引号怎么办?和大多数语言一样,使用转义符号吧。即反斜线“”.那么使用单引号和双引号有什么区别呢?我的观点是没有多大区别。唯一的区别就是双引号可以应用更多的转义符。

让我们定界符吧。它的语法是“<<<”。用法是在其后提供一个标识符,然后在标识符后提供字符串,再在字符串后提供此标识符来结尾。例如:

$str = <<

Hello, this is an example for HEREDOC Syntax.

Please attention to it.

EOD;

echo $str;

?>注意,这里的提供的标志符是EOD,中间的是字符串。

<<

结束标志必须顶格写,并且要有分号结束

13、谈谈asp,php,jsp的优缺点(1分)--(具体请自己搜索)

14、谈谈对mvc的认识(1分)

MVC(Model/View/Controller)模式包括三类对象。Model是应用对象,View是它在屏幕上的表示,

Controller定义用户界面对用户输入的响应方式。

模型-视图-控制器(MVC)是80年代Smalltalk-80出现的一种软件设计模式,现在已经被广泛的使用。

1)模型(Model)

模型是应用程序的主体部分。模型表示业务数据,或者业务逻辑.

2)视图(View)

视图是应用程序中用户界面相关的部分,是用户看到并与之交互的界面。

3)控制器(controller)

控制器工作就是根据用户的输入,控制用户界面数据显示和更新model对象状态。

-------------------------------------------------------------------

15、写出发贴数最多的十个人名字的SQL,利用下表:members(id,username,posts,pass,email)(2分)

select members.username

from members

order by posts DESC

limit 10

16. 请说明php中传值与传引用的区别。什么时候传值什么时候传引用?(2分)

按值传递:函数范围内对值的任何改变在函数外部都会被忽略

按引用传递:函数范围内对值的任何改变在函数外部也能反映出这些修改 PHPma

优缺点:按值传递时,php必须复制值。特别是对于大型的字符串和对象来说,这将会是一个代价很大的操作。

按引用传递则不需要复制值,对于性能提高很有好处。

17. 在PHP中error_reporting这个函数有什么作用? (1分)

用来配置错误信息回报的等级

18. 请写一个函数验证电子邮件的格式是否正确 (2分)

//if the email address is valid, return true,else return false

function validateEmail($email)

{

if(eregi('^[_a-z0-9-]+(.[_a-z0-9-]+)*@[a-z0-9-]+(.[a-z0-9-]+)*$',$email) ){

return true;

}else{

return false;

}

}

19. 简述如何得到当前执行脚本路径,包括所得到参数。(2分)

echo $_SERVER['SCRIPT_FILENAME'].“?”.$_SERVER['QUERY_STRING'];

20.如何修改SESSION的生存时间. (1分)

setcookie()

session_set_cookie_params($lifeTime)

--------------------------------------------------------------------

21、JS表单弹出对话框函数是?获得输入焦点函数是? (2分)

alert(),prompt(),confirm()

focus()

22、JS的转向函数是?怎么引入一个外部JS文件?(2分)

window.location.href

23、foo()和@foo()之间有什么区别?(1分)

PHP 支持一个错误控制运算符:@。当将其放置在一个 PHP 表达式之前,该表达式可能产生的任何错误信息都被忽略掉。

注意: @ 运算符只对表达式有效。对新手来说一个简单的规则就是:如果能从某处得到值,就能在它前面加上 @ 运算符。例如,可以把它放在变量,函数和include()调用,常量,等等之前。不能把它放在函数或类的定义之前,也不能用于条件结构例如 if 和 foreach 等。

24、如何声明一个名为”myclass”的没有方法和属性的类? (1分)

class myclass{};

25、如何实例化一个名为”myclass”的对象?(1分)

$newmyclass = new myclass();

26、你如何访问和设置一个类的属性? (2分)

通过-〉

$newmyclass = new myclass();

$temp=$newmyclass->testvalue;

$newmyclass->testvalue=“a”;

27、mysql_fetch_row() 和mysql_fetch_array之间有什么区别? (1分)

mysql_fetch_row -- 从结果集中取得一行作为枚举数组

mysql_fetch_array -- 从结果集中取得一行作为关联数组,或数字数组,或二者兼有

--------------------------------------------------------------------

28、GD库是做什么用的? (1分)

GD库提供了一系列用来处理图片的API,使用GD库可以处理图片,或者生成图片。

在网站上GD库通常用来生成缩略图或者用来对图片加水印或者对网站数据生成报表。

29、指出一些在PHP输入一段HTML代码的办法。(1分)

print(“

”);

echo “

”;

30、下面哪个函数可以打开一个文件,以对文件进行读和写操作?(1分)(c)

(a) fget() (b) file_open() (c) fopen() (d) open_file()

31、下面哪个选项没有将 john 添加到users 数组中? (1分) (b)(c)(d)

(a) $users[] = ‘john’;

(b) array_add($users,’john’);//这个选项不敢确定,但是测试着没有这个函数

(c) array_push($users,‘john’);

(d) $users ||= ‘john’;

32、下面的程序会输入是否?(1分)

$num = 10;

function multiply(){

$num = $num * 10;

}

multiply();

echo $num;

?>

否,局部变量

33、使用php写一段简单查询,查出所有姓名为“张三”的内容并打印出来 (2分)

表名User

Name Tel Content Date

张三 13333663366 大专毕业 -10-11

张三 13612312331 本科毕业 2006-10-15

张四 021-55665566 中专毕业 2006-10-15

请根据上面的题目完成代码:

$mysql_db=mysql_connect(“local”,“root”,“pass”);

@mysql_select_db(“DB”,$mysql_db);

$result=mysql_query(“select * from User where Name='张三'”);

while($row=mysql_fetch_array($result))

{

echo $row['Name'].$row['Tel'].$row['Content'].$row['Date'];

echo “

”;

}

34、如何使用下面的类,并解释下面什么意思?(3)

class test{

function Get_test($num){

$num=md5(md5($num).“En”);

return $num;

}

}

双重md5加密

$testObject = new test();

$encryption = $testObject->Get_test(“xiaotian_ls”);

经典面试题(PHP基础型III)PHP来源:本站编辑 作者:phpma 时间:2009-02-13 Tag:经典面试题(PHP基础型III)PHP 点击: 31 求职与招聘 往往少不了面试与笔试,作为一个php程序员、多多少少都会有类似的经历……以下是本人收集并整理的PHP面试题目,希望对同行们有所帮助,找到一份合适的php开发工作!(共三节)

以下是经典面试题(PHP基础型III)附答案 PHP已经赋予答案:

35、写出 SQL语句的格式 : 插入 ,更新 ,删除 (4分)

表名User

Name Tel Content Date

张三 13333663366 大专毕业 2006-10-11

张三 13612312331 本科毕业 2006-10-15

张四 021-55665566 中专毕业 2006-10-15

(a) 有一新记录(小王 13254748547 高中毕业 -05-06)请用SQL语句新增至表中

INSERT INTO User('Name','Tel','Content','Date') VALUES('小王','13254748547','高中毕业','2007-05-06')

(b) 请用sql语句把张三的时间更新成为当前系统时间

UPDATE User SET Date=DATE_FORMAT(NOW(),'%Y-%m-%d') WHERE Name='张三'

(c) 请写出删除名为张四的全部记录

DELETE FROM User WHERE Name='张四'

36、请写出数据类型(int char varchar datetime text)的意思; 请问varchar和char有什么区别(2分)

char 固定长度的字符,不足的长度用空格补上;varchar好象没有这个类型,

37、MySQ自增类型(通常为表ID字段)必需将其设为(?)字段(1分)

38、写出以下程序的输出结果 (1分)

$b=201;

$c=40;

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

echo $a;

?>

答案:4

39、检测一个变量是否有设置的函数是否?是否为空的函数是?(2分)

isset();empty();

-----------------------------------------------------------------------------

40、取得查询结果集总数的函数是?(1分)

mysql_fetch_array();

41、$arr = array('james', 'tom', 'symfony'); 请打印出第一个元素的值 (1分)

echo $arr['0'];

42、请将41题的数组的值用','号分隔并合并成字串输出(1分)

$arr_im = implode(“,”,$arr);

print_r($arr_im);

43、$a = 'abcdef'; 请取出$a的值并打印出第一个字母(1分)

$a = 'abcdef';

echo $a;

$a_exp = substr($a,0,1);

echo “

”;

echo $a_exp;

44、PHP可以和sql server/oracle等数据库连接吗?(1分)

当然可以

45、请写出PHP5权限控制修饰符(3分)

PHP5引入了访问修饰,被放在属性和方法声明的前面用以控制它们的可见性。PHP5中支持以下三种不同的访问修饰:

1、默认的是public(公共),即当你没有为属性和方法指定访问修饰时就默认为public的。而这些public的项目在类内类外都可以访问。

2、private(私有)访问修饰,意味着被修饰的项只能在类中被访问。如果你没使用__get()和__set(),就最好给每个属性都加上private修饰。也可以给方法加private修饰,例如一些只在类中才用到的函数。private修饰的项不能被继承(更多详细内容会在本章后续部分提到)。

3、protected(保护)修饰的项能在类及其子类中访问。同样更多详细内容会在本章后续部分提到。现在暂时可以把protected看成界于public和private之间的修饰。

46、请写出php5的构造函数和析构函数(2分)

如果你在一个类中声明一个函数,命名为__construct,这个函数将被当成是一个构造函数并在建立一个对象实例时被执行. 清楚地说,__是两个下划线. 就像其它任何函数一样,构造函数可能有参数或者默认值. 你可以定义一个类来建立一个对象并将其属性全放在一个语句(statement)中.

你也可以定义一个名为__destruct的函数,PHP将在对象被销毁前调用这个函数. 它称为析构函数.

------------------------------------------------------------------------------

47、以下请用PHPMYADMIN完成--(没有测试)

(一)创建新闻发布系统,表名为message有如下字段 (3分)

id 文章id

title 文章标题

content 文章内容

category_id 文章分类id

hits 点击量

(二)同样上述新闻发布系统:表comment记录用户回复内容,字段如下 (4分)

comment_id 回复id

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

comment_content 回复内容

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

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

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

select message.id,message.title, message.hits sum(select count(0) from comment where message.id=comment.id) as comsums from message comment order by comsums;

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

category_id int(4) not null auto_increment;

categroy_name var40) not null;

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

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

//以下使用的adodb

$cnn =& NewADOConnection('mysql');

$cnn ->Connect($db_hostspec, $db_username, $db_password, $db_database);

$cnn ->SetFetchMode(ADODB_FETCH_ASSOC);

if (!$cnn) message(“无法连接数据库 $db_database”);

$sql = “SELECT * FROM `category` WHERE 1;

$rst =& $cnn ->Execute($sql);

if (!$rst) die($cnn ->ErrorMsg());

$arr_categroy = $rst ->GetArray();

[php经典面试题]

篇2:php面试题

PHP是一个基于服务端来创建动态网站的脚本语言,您可以用PHP和HTML生成网站主页。unjs网为您带来php面试题。一起来看看。

大公司的PHP面试题:

1. 禁用COOKIE 后 SEESION 还能用吗?

2. 抓取远程图片到本地,你会用什么函数?

4. 你觉得在pV10W的时候, 同等配置下,LUNIX 比WIN快多少?

5. 简述pOST 和GET传输的最大容量分别是多少?

6. 用最少的代码写一个求3值最大值的函数.

php面试题目:

1、用PHP打印出前一天的时间格式是2006-5-10 22:21:21(2分)

$a = date(”Y-m-d H:i:s“, strtotime(”-1 day“));

print_r($a);

2、echo(),print(),print_r()的区别(3分)

echo 和print不是一个函数,是一个语言结构

int print(string $arg), 只有一个参数

echo arg1,arg1,arg2; 可以输出多个参数,返回void

echo和print只能打印出string,不能打印出结构

print_r能打印出结构

比如

$arr = array(”key“=>”value“);

print_r($arr);

3、能够使HTML和PHP分离开使用的模板(1分)

smarty,phplib

4、使用哪些工具进行版本控制?(1分)

svn,git,cvs

5、如何实现字符串翻转?(3分)

英文:

strrev($a)

中文或其他文字:

中文:GB2312, 代码是使用GB2312编码

function reverse($str)

{

$ret = ”“;

len=mbstrwidth(len=mbstrwidth(str,”GB2312“);

for(i=0;i=0;i< len;len;i++)

{

arr[]=mbsubstr(arr[]=mbsubstr(str, $i, 1, ”GB2312“);

}

return implode(”“, array_reverse($arr));

}

print_r(reverse(”你好“));

---------------------------------------------------------------

6、优化MYSQL数据库的方法。(4分,多写多得)

语句方面:

1 使用索引,增加查询效率

2 优化查询语句,提高索引命中率

数据库涉及方面:

1 构造分库分表,提高数据库的存储和扩展能力

2 根据需要使用不同的存储引擎

7、PHP的意思(送1分)

超级文本预处理语言

Hypertext PreProcessor

8、MYSQL取得当前时间的函数是?,格式化日期的函数是(2分)

CURRENT_TIMESTAMP()

DATE_FORMAT()

select DATE_FORMAT(”-11-21 10:10:10“, ”%Y-%m-%d“);

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

mb_substr($str, 1, 1, ”GB2312“);

---------------------------------------------------------------

10、您是否用过版本控制软件? 如果有您用的版本控制软件的名字是?(1分)

svn

git

11、您是否用过模板引擎? 如果有您用的模板引擎的名字是?(1分)

smarty

12、请简单阐述您最得意的开发之作(4分)

XXX

13、对于大流量的网站,您采用什么样的方法来解决访问量问题?(4分)

1 有效使用缓存,增加缓存命中率

2 使用负载均衡

3 对静态文件使用CDN进行存储和加速

4 想法减少数据库的使用

5 查看出现统计的瓶颈在哪里

-----------------------------------------------------------------

14、用PHP写出显示客户端IP与服务器IP的代码1分)

$_SERVER[”REMOTE_ADDR“]

$_SERVER[”SERVER_ADDR“]

15、语句include和require的区别是什么?为避免多次包含同一文件,可用(?)语句代替它们? (2分)

在失败的时候:

include产生一个warning,而require产生直接产生错误中断

require在运行前载入

include在运行时载入

require_once

include_once

16、如何修改SESSION的生存时间(1分).

session_set_cookie_params

17、有一个网页地址, 比如PHP研究室主页: www.phpv.net/,如何得到它的内容?($1分)

file_get_contents

curl

18、在HTTP 1.0中,状态码401的含义是(?);如果返回“找不到文件”的提示,则可用 header 函数,其语句为(?);(2分)

未授权

header(”HTTP/1.0 404 Not Found“);

fast CGI中:

header(”Status: 404 Not Found“);

19、在PHP中,heredoc是一种特殊的字符串,它的结束标志必须?(1分)

成对出现

$a = <

good test

EOD;

20、谈谈asp,php,jsp的优缺点(1分)

asp是需要依赖IIS,是微软开发的语言

php和jsp可以依赖apache或者 nginx等其他服务器

[php面试题]

篇3:php常见面试题

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

答:echo $_SERVER['PHP_SELF']; echo $_SERVER[”HTTP_REFERER“];

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

答:0

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

答:(4)未授权 (5) header(”HTTP/1.0 404 Not Found“);

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

答:(6)对数组进行逆向排序并保持索引关系 (7)All errors and warnings

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

答:/<[^>].*?>.*?/si

6.以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

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

答:(12) 发生异常时include产生警告require产生致命错误 (13) require_once/include_once()

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

答:serialize() /unserialize()

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

答:allow_call_time_pass_reference

10.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

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

答:结束标识符所在的行不能包含任何其它字符除”;“

12.用PHP打印出前一天的时间格式是-5-10 22:21:21

答:echo date('Y-m-d H:i:s', strtotime('-1 day'));

13.echo(),print(),print_r()的区别

答:echo是语言结构,无返回值;print功能和echo基本相同,不同的是print是函数,有返回值;print_r是递归打印,用于输出数组对象

14.如何实现字符串翻转?

答:.用strrev函数呗,不准用PHP内置的就自己写:

strrev($str)

{

$len=strlen($str);

$newstr = '';

for($i=$len;$i>=0;$i--)

{

$newstr .= $str{$i};

}

return $newstr;

}

15.实现中文字串截取无乱码的方法。

答:mb_substr()

16.使用php写一段简单查询,查出所有姓名为“张三”的内容并打印出来

表名User

Name Tel Content Date

张三 13333663366 大专毕业 2006-10-11

张三 13612312331 本科毕业 2006-10-15

张四 021-55665566 中专毕业 2006-10-15

答:SELECT Name,Tel,Content,Date FROM User WHERE Name='张三'

17.如何使用下面的类,并解释下面什么意思?

class test

{

Get_test($num)

{

$num=md5(md5($num).”En“);

return $num;

}

}

答:用法:

$get_test = new test();

$result = $get_test->Get_test(2);

将$num变量进行两次md5后返回,第2次的md5中的参数,在第一次md5($num)后多加了En

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

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

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

1)

get_ext1($file_name)

{

return strrchr($file_name, '.');

}

2)

get_ext2($file_name)

{

return substr($file_name, strrpos($file_name, '.'));

}

3)

get_ext3($file_name)

{

return array_pop(explode('.', $file_name));

}

4)

get_ext4($file_name)

{

$p = pathinfo($file_name);

return $p['extension'];

}

5)

get_ext5($file_name)

{

return strrev(substr(strrev($file_name), 0, strpos(strrev($file_name), '.')));

}

19.如何修改SESSION的生存时间

这个函式库让你处理和显示各式格式的图档,它的另一个常见用途是制作所图档。GD 以外的另一个选择是 ImageMagick,但这个函式库并不内建于 PHP 之中,必须由系统管理员安装在伺服器上答:其实 Session 还提供了一个函数 session_set_cookie_params(); 来设置 Session 的生存期的,该函数必须在 session_start() 函数调用之前调用:

// 保存一天

$lifeTime = 24 * 3600;

session_set_cookie_params($lifeTime);

session_start();

$_SESSION[”admin“] = true;

?>

20. 请写一个函数,实现以下功能: 字符串“open_door” 转换成 “OpenDoor”、”make_by_id” 转换成 ”MakeById”。30.请举例说明在你的开发过程中用什么方法来加快页面的加载速度

A.生成静态HTML

B.生成xml

C.可不用数据库的尽量不用数据库把变量参数存于文本.

D.用ZEND加速

答:

Function test($str){

$arr1=explode('_',$str);

//$arr2=array_walk($arr1,ucwords( ));

$str = implode(' ',$arr1);

return ucwords($str);

}

$aa='open_door';

echo test($aa);

?>

21. 如何用php的环境变量得到一个网页地址的内容?ip地址又要怎样得到?

答:$_SERVSR[‘REQUEST_URI’]

$_SERVER[‘REMOTE_ADDR’]

22.求两个日期的差数,例如-2-5 ~ 2007-3-6 的日期差数

答:(strtotime(‘2007-3-6’)-strtotime(‘2007-2-5’))/3600*24

23.表中有A B C三列,用SQL语句实现:当A列大于B列时选择A列否则选择B列,当B列大于C列时选择B列否则选择C列。

答:select case when A>B then A else B end,

case when B>C then B else C end

From test

24.请简述项目中优化sql语句执行效率的方法,从哪些方面,sql语句性能如何分析?

答:(1)选择最有效率的表名顺序

(2)WHERE子句中的连接顺序

(3)SELECT子句中避免使用‘*’

(4)用Where子句替换HAVING子句

(5)通过内部函数提高SQL效率

(6)避免在索引列上使用计算。

(7)提高GROUP BY 语句的效率, 可以通过将不需要的记录在GROUP BY 之前过滤掉。

25.mysql_fetch_row() 和 mysql_fetch_array() 有什么分别?

mysql_fetch_row() 把数据库的一列储存在一个以零为基数的阵列中,第一栏在阵列的索引 0,第二栏在索引 1,如此类推。mysql_fetch_assoc() 把数据库的一列储存在一个关联阵列中,阵列的索引就是栏位名称,例如我的数据库查询送回“first_name”、“last_name”、“email”三个栏位,阵列的索引便是“first_name”、“last_name”和“email”。mysql_fetch_array() 可以同时送回 mysql_fetch_row() 和 mysql_fetch_assoc() 的值。

26.下面的代码用来做什么?请解释。

$date='08/26/';print ereg_replace(”([0-9]+)/([0-9]+)/([0-9]+)“,”\\2/\\1/\\3“,$date);

这是把一个日期从 MM/DD/YYYY 的格式转为 DD/MM/YYYY 格式。我的一个好朋友告诉我可以把这个正规表达式拆解为以下的语句,对于如此简单的表示是来说其实无须拆解,纯粹为了解说的方便:

// 对应一个或更多 0-9,后面紧随一个斜号$regExpression = ”([0-9]+)/“;// 应一个或更多 0-9,后面紧随另一个斜号$regExpression .= ”([0-9]+)/“;// 再次对应一个或更多 0-9$regExpression .= ”([0-9]+)“;至于 \\2/\\1/\\3 则是用来对应括号,第一个括号对的是月份,

27.GD 函式库用来做什么?

答:这个函式库让你处理和显示各式格式的图档,它的另一个常见用途是制作所图档。GD 以外的另一个选择是 ImageMagick,但这个函式库并不内建于 PHP 之中,必须由系统管理员安装在伺服器上

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

答:要用到服务器资源时才打开,及时关闭服务器资源,数据库添加索引,页面可生成静态,图片等大文件单独服务器。使用代码优化工具啦

29.防止SQL注射漏洞一般用__addslashes___函数。

30.PHP中传值和传引用、传地址的区别是什么?

答:传值是把实参的值赋值给行参 那么对行参的修改,不会影响实参的值

传地址 是传值的一种特殊方式,只是他传递的是地址,不是普通的如int 那么传地址以后,实参和行参都指向同一个对象

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

答:获取open()的返回值,如果是null,就是屏蔽了

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

答:首先,确认服务器硬件是否足够支持当前的流量

其次,优化数据库访问。

第三,禁止外部的盗链。

第四,控制大文件的下载。

第五,使用不同主机分流主要流量

第六,使用流量分析统计软件

[php常见面试题]

篇4:php常用面试题及答案

1、谈对mvc的认识?

答:由模型(Model),视图(View),控制器(Controller)完成的应用程序

由模型发出要实现的功能到控制器,控制器接收组织功能传递给视图;

2、写出发贴数最多的十个人名字的SQL,利用下表:members(id,username,posts,pass,email)

答:SELECT * FROM `members` ORDER BY posts DESC limit 0,10;

3、GD库是做什么用的?

答:gd库提供了一系列用来处理图片的功能,使用GD库可以处理图片,或者生成图片。

在网站上GD库通常用来生成缩略图或者用来对图片加水印或者对网站数据生成报表。

4、请写出数据类型(int char varchar datetime text)的意思; 请问varchar和char有什么别?

答:int是数字类型,char固定长度字符串,varchar实际长度字符串,datetime日期时间型,text文本字符串

char的场地固定为创建表设置的长度,varchar为可变长度的字符

5、以下程序的输出结果?

$b=201;

$c=40;

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

echo $a;

?>

答:4

6、检测一个变量是否有设置的函数是?是否为空的函数是?

答:isset($str),empty($str);

7、得查询结果集总数的函数是?

答:mysql_num_rows($result);

8、$arr = array(‘james’, ‘tom’, ‘symfony’); 请打印出第一个元素的值?

答:echo $arr[0];

9、===”是什么?试举一个“==”是真但“===”是假的例子。

“===”是既可以返回布尔值“假”,也可以返回一个不是布尔值但却可以赋与“假”值的函式,strpos() 和 strrpos() 便是其中两个例子。

if (strpos(”abc“, ”a“) == true){ // 这部分永不会被执行,因为 ”a“ 的位置是 0,换算成布尔值“假”}if (strpos(”abc“, ”a“) === true){ // 这部份会被执行,因为“===”保证函式 strpos() 的送回值不会换算成布尔值.}

10、以下程序的输出结果

$str=“cd”;

$$str=“hotdog”;

$$str.=“ok”;

echo $cd;

?>

答案:hotdogok

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

$var1=1;

$var2=7;

$var3=8;

$max=$var1>$var2?$var1:$var2;

$max=$max>$var3?$max:$var3;

echo $max;

12、将一个选择2号选项的ip为127.0.0.1的用户在当前时间的投票记录到数据库的SQL

答:insert into poll (ip,time,iid) values('127.0.0.1',now(),2);

13、个函数验证电子邮件的格式是否正确 ?

答:function checkEmail($email)

{

$pregEmail = ”/([a-z0-9]*[-_\\.]?[a-z0-9]+)*@([a-z0-9]*[-_]?[a-z0-9]+)+[\\.][a-z]{2,3}([\\.][a-z]{2})?/i“;

return preg_match($pregEmail,$email);

}

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

function GenerateMenu($id=0,$str=”“)

{

$result=mysql_query(”select mainmenu,url,submenu from menu where mainmenu=$id“);

while($row=mysql_fetch_array($result))

{

echo $str.$row[”url“].”

“;

GenerateMenu($row[”submenu“],$str.”--“);

}

mysql_free_result($result);

}

$link=mysql_connect(”localhost“,”root“,”“);

mysql_select_db(”phpinterview“);

GenerateMenu();

mysql_close($link)

?>

15、PHP可以和sql server/oracle等数据库连接吗?

答:可以

16、写出PHP5权限控制修饰符?

答:public(公共),private(私用),protected(继承)

17、请写出php5的构造函数和析构函数?

答: 构造函数:官方称自定义函数

析构函数:垃圾回收函数(__destruct)

18、表单中 get与post提交方法的区别?

答:get是发送请求HTTP协议通过url参数传递进行接收,而post是实体数据,可以通过表单提交大量信息.

19、session与cookie的区别?

答:session:储存用户访问的全局唯一变量,存储在服务器上的php指定的目录中的(session_dir)的位置进行的存放

cookie:用来存储连续L一个面时所使用,是存储在客户端,对于Cookie来说是存储在用户WIN的Temp目录中的。

两者都可通过时间来设置时间长短

20、用PHP打印出前一天的时间格式是-7-3 12:28:21?

答:echo date(‘Y-m-d H:i:s’, strtotime(‘-1 days’));

21、e2ho(),print(),print_r()的区别?

答:echo是PHP语句, print和print_r是函数,语句没有返回值,函数可以有返回值(即便没有用)

print() 只能打印出简单类型变量的值(如int,string)

print_r() 可以打印出复杂类型变量的值(如数组,对象)

echo 输出一个或者多个字符串

22、能够使HTML和PHP分离开使用的模板?

答:Smarty, TinyButStrong,XTemplate, Savant,Template Lite, Dwoo, phemplate

23、哪些工具进行版本控制?

答:cvs,svn,vss;

24、如何实现字符串翻转?

答:echo strrev($a); //strrev ― 颠倒字符串

25、优化查询语句?

a.最好在相同字段进行比较操作,在建立好的索引字段上尽量减少函数操作

例子1:

SELECT * FROM order WHERE YEAR(orderDate)<;(慢)

SELECT * FROM order WHERE orderDate<”2008-01-01“;(快)

例子2:

SELECT * FROM order WHERE addtime/7<24;(慢)

SELECT * FROM order WHERE addtime<24*7;(快)

例子3:

SELECT * FROM order WHERE title like ”%good%“;

SELECT * FROM order WHERE title>=”good” and name<”good“;

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

答:确认服务器硬件是否足够支持当前的流量,数据库读写分离,优化数据表,

程序功能规则,禁止外部的盗链,控制大文件的下载,使用不同主机分流主要流量

27、如何修改SESSION的生存时间?.

答:方法1:将php.ini中的session.gc_maxlifetime设置为9999重启apache

方法2:$savePath = “./session_save_dir/”;

$lifeTime = 小时 * 秒;

session_save_path($savePath);

session_set_cookie_params($lifeTime);

session_start();

方法3:setcookie() and session_set_cookie_params($lifeTime);

28、有一个网页地址, 比如PHP开发资源网主页: www.php100.com/,如何得到它的内容?

答:方法1(对于PHP5及更高版本):

$readcontents = fopen(“www.php100.com/”, “rb”);

$contents = stream_get_contents($readcontents);// stream_get_contents 取得字符串赋值给$contents

fclose($readcontents);

echo $contents;

方法2:

echo file_get_contents(“www.php100.com/”);

// file_get_contents() 函数把整个文件读入一个字符串中。

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

答:状态401代表未被授权,header(“Location:www.xxx.php”);

30、在PHP中,heredoc是一种特殊的字符串,它的结束标志必须?

答:heredoc的语法是用”<<<”加上自己定义成对的标签,在标签范围鹊奈淖质游一个字串

例子:

$str = <<

my name is Jiang Qihui!

SHOW;

31、foo()和@foo()之间有什么区别?

答:@foo()控制错误输出

32、如何声明一个名为”myclass”的没有方法和属性的类?

答:class myclass{ }

33、如何实例化一个名为”myclass”的对象?

答:new myclass()

34、你如何访问和设置一个类的属性?

答:$object = new myclass();

$newstr = $object->test;

$object->test = “info”;

35、mysql_fetch_row() 和mysql_fetch_array之间有什么区别?

答:mysql_fetch_row是从结果集取出1行数组,作为枚举

mysql_fetch_array是从结果集取出一行数组作为关联数组,或数字数组,两者兼得

36、下面哪个函数可以打开一个文件,以对文件进行读和写操作?

(a) fget() (b) file_open() (c) fopen() (d) open_file()

答:c

37、下面的程序会输入是否?

$num = 10;

function multiply(){

$num = $num * 10;

}

multiply();

echo $num;

?>

否,局部变量

38、JS表单弹出对话框函数是?获得输入焦点函数是?

答:弹出对话框: alert(),prompt(),confirm()

获得输入焦点 focus()

39、JS的转向函数是?怎么引入一个外部JS文件?

答:window.location.href;

40、$a = ‘abcdef’; 请取出$a的值并打印出第一个字母?

答:echo $a{0} 或 echo substr($a,0,1)

41、如何使用下面的类,并解释下面什么意思?

class test{

function Get_test($num){

$num=md5(md5($num).”En”);

return $num;

} }

双重md5加密

$testObject = new test();

$encryption = $testObject->Get_test(“xiaotian_ls”);

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

答:要用到服务器资源时才打开,及时关闭服务器资源,数据库添加索引,页面可生成静态,图片等大文件单独服务器。使用代码优化工具啦

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

$script=“以下内容不显示:alert(‘cc’);”;

echo preg_replace(“/].*?>.*?/si”, “替换内容”, $script);

?>

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

答:LoadModule

php5_module

“c:/php/php5apache2.dll”;AddType application/x-httpd-php .php

45、sort()、asort()、和 ksort() 有什么分别?它们分别在什么情况下使用?

sort()

根据阵列中元素的值,以英文字母顺序排序,索引键会由 0 到 n-1 重新编号。主要是当阵列索引键的值无关疼痒时用来把阵列排序。

asort()

与 sort() 一样把阵列的元素按英文字母顺序来排列,不同的是所有索引键都获得保留,特别适合替联想阵列排序。

ksort()

根据阵列中索引键的值,以英文字母顺序排序,特别适合用于希望把索引键排序的联想阵列。

46、用PHP写出显示客户端IP与服务器IP的代码?

答:打印客户端IP:echo $_SERVER[‘REMOTE_ADDR’]; 或者: getenv('REMOTE_ADDR');//getenv取得开发环境变量

打印服务器IP:echo gethostbyname(“www.bolaiwu.com”) // gethostbyname取得IP地址函数

47、语句include和require的区别是什么?为避免多次包含同一文件,可用(?)语句代替它们?

答:require->require是无条件包含也就是如果一个流程里加入require,无论条件成立与否都会先执行require

include->include有返回值,而require没有(可能因为如此require的速度比include快)

注意:包含文件不存在或者语法错误的时候require是致命的,include不是

48、PHP的意思?

答:PHP是一个基于服务端来创建动态网站的脚本语言,您可以用PHP和HTML生成网站主页

49、谈谈asp,php,jsp的优缺点?

答:ASP全名Active Server Pages,是一个WEB服务器端的开发环境, 利用它可以产生和运行动态的、交互的、高性能的WEB服务应用程序。ASP采用脚本语言VB Script(Java script)作为自己的开发语言。

PHP是一种跨平台的服务器端的嵌入式脚本语言. 它大量地借用C,Java和Perl语言的语法, 并耦合PHP自己的特性,使WEB开发者能够快速地写出动态生成页面.它支持目前绝大多数数据库。还有一点,PHP是完全免费的,不用花钱,你可以从PHP官方站点(www.php.net)自由下载。而且你可以不受限制地获得源码,甚至可以从中加进你自己需要的特色。

JSP 是Sun公司推出的新一代站点开发语言,他完全解决了目前ASP,PHP的一个通病--脚本级执行(据说PHP4 也已经在Zend 的支持下,实现编译运行).Sun 公司借助自己在Java 上的不凡造诣,将Java 从Java 应用程序 和 Java Applet 之外,又有新的硕果,就是Jsp--Java Server Page。Jsp 可以在Serverlet和JavaBean的支持下,完成功能强大的站点程序。

三者都提供在 HTML 代码中混合某种程序代码、由语言引擎解释执行程序代码的能力。但JSP代码被编译成 Servlet 并由 Java 虚拟机解释执行,这种编译操作仅在对 JSP 页面的第一次请求时发生。在 ASP 、PHP、JSP 环境下,HTML 代码主要负责描述信息的显示样式,而程序代码则用来描述处理逻辑。普通的 HTML 页面只依赖于 Web 服务器,而 ASP 、PHP、JSP 页面需要附加的语言引擎分析和执行程序代码。程序代码的执行结果被重新嵌入到 HTML 代码中,然后一起发送给浏览器。 ASP 、PHP、JSP三者都是面向 Web 服务器的技术,客户端浏览器不需要任何附加的软件支持。

50、   优化MYSQL数据库的方法

(1).选取最适用的字段属性,应该尽量把字段设置为NOT NULL,这样在将来执行查询的时候,数据库不用去比较NULL值。

(2).使用连接(JOIN)来代替子查询(Sub-Queries)

(3).尽量少使用 LIKE 关键字和通配符

篇5:关于精选php面试题及答案

精选php面试题及答案

一、基础题

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

<?php $str1 = null;

$str2 = false;

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

$str3 = ;

$str4 = 0;

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

$str5 = 0;

$str6 = 0;

echo $str5===$str6 ? 相等 : 不相等;?>

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

<?php $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;?>

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

<?php $test = aaaaaa;

$abc = & $test;

unset($test);

echo $abc;?>

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

<?php $count = 5;

function get_count(){

static $count = 0;

return $count++;

}

echo $count;

++$count;

echo get_count();

echo get_count();?>

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

<?php $GLOBALS[var1] = 5;

$var2 = 1;

function get_value(){

global $var2;

$var1 = 0;

return $var2++;

}

get_value();

echo $var1;

echo $var2;?>

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

<?php 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.常用php面试题及答案

2.php常用面试题及答案

3.PHP面试题汇总

4.优秀php高级工程师面试题及答案

5.百度PHP面试题

6.百度php面试题目

7.腾讯php面试题

8.提问得最多的PHP面试题

9.基础php面试题

10.百度php面试题

篇6:php初级面试题

一. 基本知识点

1.1 HTTP协议中几个状态码的含义:503 500 401 403 404 200 301 302。。。

200 : 请求成功,请求的数据随之返回。

301 : 永久性重定向。

302 : 暂时行重定向。

401 : 当前请求需要用户验证。

403 : 服务器拒绝执行请求,即没有权限。

404 : 请求失败,请求的数据在服务器上未发现。

500 : 服务器错误。一般服务器端程序执行错误。

503 : 服务器临时维护或过载。这个状态时临时性的。

1.2 Include require include_once require_once 的区别.

处理失败方式不同:

require 失败时会产生一个致命级别错误,并停止程序运行。

include 失败时只产生一个警告级别错误,程序继续运行。

include_once/require_once和include/require 处理错误方式一样,

唯一区别在于当所包含的文件代码已经存在时候,不在包含。

1.3 (mysql)请写出数据类型(int char varchar datetime text)的意思; 请问varchar和char有什么区别;

int : 数值类型

char : 固定长度字符串类型

varchar : 可变长度字符串类型

datetime : 时期时间类型

text : 文本类型

varchar和char有什么区别:

a. char 长度是固定的,不管你存储的数据是多少他都会都固定的长度。

而varchar则处可变长度但他要在总长度上加1字符,这个用来存储位置。

b. char 固定长度,所以在处理速度上要比varchar快速很多,但是浪费存储空间,

所以对存储不大,但在速度上有要求的可以使用char类型,反之可以用varchar类型来实例。

1.4 error_reporting 等调试函数使用

error_reporting() 函数能够在运行时设置php.ini中 error_reporting 指令。

所以可以再程序中随时调节显示的错误级别。

使用此函数时 display_errors必须是打开状态。

1.5 写代码来解决多进程/线程同时读写一个文件的问题。

PHP是不支持多线程的,可以使用php的flock加锁函数实现。

$fp = fopen(“/tmp/lock.txt”, “w+”);

if (flock($fp, LOCK_EX)) { // 进行排它型锁定

fwrite($fp, “Write something here ”);

flock($fp, LOCK_UN); // 释放锁定

} else {

echo “Couldn't lock the file !”;

}

fclose($fp);

1.6 写一段上传文件的代码。

upload.html

Send this file:

upload.php

$uploads_dir = '/uploads';

foreach ($_FILES[“error”] as $key =>$error) {

if ($error == UPLOAD_ERR_OK) {

$tmp_name = $_FILES[“tmp_name”][$key];

$name = $_FILES[“name”][$key];

move_uploaded_file($tmp_name, “$uploads_dir/$name”);

}

}

1.7 Mysql 的存储引擎,myisam和innodb的区别。

a. MyISAM类型不支持事务处理等高级处理,而InnoDB类型支持.

b. MyISAM类型的表强调的是性能,其执行数度比InnoDB类型更快.

c. InnoDB不支持FULLTEXT类型的索引.

d. InnoDB 中不保存表的具体行数,也就是说,

执行select count(*) from table时,InnoDB要扫描一遍整个表来计算有多少行,

但是MyISAM只要简单的读出保存好的行数即可.

e. 对于AUTO_INCREMENT类型的字段,InnoDB中必须包含只有该字段的索引,但是在MyISAM表中,可以和其他字段一起建立联合索引。

f. DELETE FROM table时,InnoDB不会重新建立表,而是一行一行的删除。

g. LOAD TABLE FROM MASTER操作对InnoDB是不起作用的,解决方法是首先把InnoDB表改成MyISAM表,导入数据后再改成InnoDB表,

但是对于使用的额外的InnoDB特性(例如外键)的表不适用.

h. MyISAM支持表锁,InnoDB支持行锁。

二. web 架构,安全,项目经验

2.1 MySQL数据库作发布系统的存储,一天五万条以上的增量,预计运维三年,怎么优化?

a. 设计良好的数据库结构,允许部分数据冗余,尽量避免join查询,提高效率。

b. 选择合适的表字段数据类型和存储引擎,适当的添加索引。

c. mysql库主从读写分离。

d. 找规律分表,减少单表中的数据量提高查询速度。

e。添加缓存机制,比如memcached,apc等。

f. 不经常改动的页面,生成静态页面。

g. 书写高效率的SQL。比如 SELECT * FROM TABEL 改为 SELECT field_1, field_2, field_3 FROM TABLE.

2.2 对于大流量的网站,您采用什么样的方法来解决各页面访问量统计问题

a. 确认服务器是否能支撑当前访问量。

b. 优化数据库访问。参考2.3

c. 禁止外部访问链接(盗链), 比如图片盗链。

d. 控制文件下载。

e. 使用不同主机分流。

f. 使用浏览统计软件,了解访问量,有针对性的进行优化。

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

答:/<[^>].*?>.*?/si

2.4 用PHP打印出前一天的时间格式是-5-10 22:21:21

答:echo date('Y-m-d H:i:s', strtotime('-1 day'));

2.5 echo(),print(),print_r()的区别

答:echo是语言结构,无返回值;print功能和echo基本相同,不同的是print是函数,有返回值;print_r是递归打印,用于输出数组对象

2.6 如何实现字符串翻转?

答:.用strrev函数呗,不准用PHP内置的就自己写:

[php] view plaincopy

strrev($str)

{

$len=strlen($str);

$newstr = '';

for($i=$len;$i>=0;$i--)

{

$newstr .= $str{$i};

}

return $newstr;

}

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

答:mb_substr()

2.8 如何用php的环境变量得到一个网页地址的内容?ip地址又要怎样得到?

答:$_SERVSR[‘REQUEST_URI’] , $_SERVER[‘REMOTE_ADDR’]

2.9 求两个日期的差数,例如-2-5 ~ 2007-3-6 的日期差数

答:(strtotime(‘2007-3-6’)-strtotime(‘2007-2-5’))/3600*24

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

答:获取open()的返回值,如果是null,就是屏蔽了

[php初级面试题]

篇7:常用php面试题及答案

1.简述两种屏蔽php程序的notice警告的方法

初始化变量,文件开始设置错误级别或者修改php.ini 设置error_reporting

set_error_handler 和 @抑制错误

1.在程序中添加:error_reporting (E_ALL & ~E_NOTICE);

2.或者修改php.ini中的:error_reporting = E_ALL

改为:error_reporting = E_ALL & ~E_NOTICE

3.error_reporting(0);或者修改php.inidisplay_errors=Off

2.instanceof的作用, 经常在什么设计模式中使用

单例模式,但是其他的模式也会用到

3.1023用二进制表示, 并简述计算过程

10-2

1023%2=1

511%2 =1

255%2 =1

127%2 =1

63%2 =1

31%2 =1

15%2 =1

7%2 =1

3%2 =1

1%2 =1

0 =0

-------------------------------------------

1023

2^9=

511

k=9

10 9 8 7 6 5 4 3 2 1

1 1 1 1 1 1 1 1 1 1

----------------------

1023 1

1023-1/2=511 1

511-1/2=255 1

255-1/2=127 1

127-1/2=63 1

63-1/2=31 1

31-1/2=15 1

15-1/2=7 1

7-1/2=3 1

3-1/2=1 1

-----------------------------------------------

2-10

只需用将二进制数的各个位上的数从最右边开始,最右边的第一个数乘以二的零次方,第二个数乘以二的一次方,第三个数乘以二的二次方,依次类推可得第n个数乘以二的(n-1)次方,然后把得到的结果相加即可

例如:110011=1*2^0+1*2^1+0*2^2+0*2^3+1*2^4+1*2^5=51

这也可以算是一个公式就是An*2^(n-1) An表示二进制数最右边开始的第n个数,

将第一项第二项第三项一直到第n项用式子An*2^(n-1) 计算出来并加在一起即可

4.有如下数据库, 用原生态mysql扩展去连接并查询user表的前十行

host: 192.168.0.254

port: 3306

user: one

pass: piece

database: db_user

table: user

$link = mysql_connect(“192.168.0.254:3306”,“one”,“piece”) or die('Could not connect: '.mysql_error);

mysql_select_db('db_user',$link);

$query = mysql_query(“select * from user limit 10”);

while($rs = mysql_fetch_array($query,MYSQL_ASSOC))

5.符串”\\r”,”\\n”,”\\t”,”\\x20”分别代表什么?

答案: “\\r”代表的含义是:

在Linux、unix 中表示返回到当行的最开始位置,在Mac OS 中表示换行且返回到下一行的最开始位置,相当于Windows 里的 \\n 的效果。

“\\n”代表的含义是:

在Windows 中表示换行且回到下一行的最开始位置。相当于Mac OS 里的 \\r 的效果,在linux、unix 中只表示换行,但不会回到下一行的开始位置。

“\\t”所代表的含义是:

键盘上的“TAB”键,跳格(移至下一列)。

“\\x20”所代表的含义是:是32在ASCII表中16进制的表示。

6.语句输出的结果是什么?

$a = 3;

echo “$a”,'$a',“\\\\\\$a”,“${a}”,“$a”.“$a”,“$a”+“$a”;

1

2

1

2

得到的

篇8:php算法面试题

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

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

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

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

一、基础题

1. 相等 相等 不相等

2. true true true true true false true false

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; $jC){

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

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算法面试题]

相关专题 面试题PHP