33道php常见面试题及答案


Posted in PHP onJuly 06, 2015

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打印出前一天的时间格式是2006-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() 函数调用之前调用:

<?php
// 保存一天
$lifeTime = 24 * 3600;
session_set_cookie_params($lifeTime);
session_start();
$_SESSION["admin"] = true;
?>

20. 请写一个函数,实现以下功能: 字符串“open_door” 转换成 “OpenDoor”、”make_by_id” 转换成 ”MakeById”。

答:

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.求两个日期的差数,例如2007-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/2003';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有所帮助。

PHP 相关文章推荐
拼音码表的生成
Oct 09 PHP
PHP数组循环操作详细介绍 附实例代码
Feb 03 PHP
php的memcache类分享(memcache队列)
Mar 26 PHP
PHP调用VC编写的COM组件实例
Mar 29 PHP
PHP常用技巧汇总
Mar 04 PHP
Yii中CGridView禁止列排序的设置方法
Jul 12 PHP
使用ThinkPHP的自动完成实现无限级分类实例详解
Sep 02 PHP
php性能分析之php-fpm慢执行日志slow log用法浅析
Oct 17 PHP
php实现文章置顶功能的方法
Oct 20 PHP
Yii2选项卡的简单使用
May 26 PHP
PHP定义字符串的四种方式详解
Feb 06 PHP
PHP+MySQL实现在线测试答题实例
Jan 02 PHP
PHP中创建和验证哈希的简单方法实探
Jul 06 #PHP
详解PHP中的PDO类
Jul 06 #PHP
php中 $$str 中 &quot;$$&quot; 的详解
Jul 06 #PHP
PHP生成唯一订单号
Jul 05 #PHP
启用Csrf后POST数据时出现的400错误
Jul 05 #PHP
php超快高效率统计大文件行数
Jul 05 #PHP
PHP版QQ互联OAuth示例代码分享
Jul 05 #PHP
You might like
10个可以简化php开发过程的MySQL工具
2010/04/11 PHP
php可扩展的验证类实例(可对邮件、手机号、URL等验证)
2015/07/09 PHP
PHP表单验证内容是否为空的实现代码
2016/11/14 PHP
详解Yii2 rules 的验证规则
2016/12/02 PHP
PHP实现的字符串匹配算法示例【sunday算法】
2017/12/19 PHP
Mootools 1.2教程 输入过滤第二部分(字符串)
2009/09/15 Javascript
页面版文本框智能提示JS代码
2009/11/20 Javascript
JS跨域代码片段
2012/08/30 Javascript
javascript中不提供sleep功能如何实现这个功能
2014/05/27 Javascript
js去除浏览器默认底图的方法
2015/06/08 Javascript
JavaScript实现给定时间相加天数的方法
2016/01/25 Javascript
深入理解JS中的substr和substring
2016/04/26 Javascript
JS遍历数组和对象的区别及递归遍历对象、数组、属性的方法详解
2016/06/14 Javascript
浅谈js对象属性 通过点(.) 和方括号([]) 的不同之处
2016/10/29 Javascript
jquery插入兄弟节点的操作方法
2016/12/07 Javascript
javascript显示系统当前时间代码
2016/12/29 Javascript
JS中Safari浏览器中的Date
2017/07/17 Javascript
利用vue.js把静态json绑定bootstrap的table方法
2018/08/28 Javascript
vue.js自定义组件实现v-model双向数据绑定的示例代码
2020/01/08 Javascript
Vue SSR 即时编译技术的实现
2020/05/06 Javascript
[02:33]2018DOTA2亚洲邀请赛赛前采访——LGD
2018/04/04 DOTA
[01:21:07]EG vs Liquid 2018国际邀请赛淘汰赛BO3 第一场 8.25
2018/08/29 DOTA
python用装饰器自动注册Tornado路由详解
2017/02/14 Python
python中的print()输出
2019/04/12 Python
django搭建项目配置环境和创建表过程详解
2019/07/22 Python
Python要求O(n)复杂度求无序列表中第K的大元素实例
2020/04/02 Python
CSS3使用多列制作瀑布流
2016/05/10 HTML / CSS
澳大利亚天然护肤品、化妆品和健康产品一站式商店:Nourished Life
2018/12/02 全球购物
美国庭院家具购物网站:AlphaMarts
2019/04/10 全球购物
经济管理专业自荐信
2013/12/30 职场文书
大四本科生的自我评价
2013/12/30 职场文书
财务会计毕业生个人求职信
2014/02/03 职场文书
2015年行政人事工作总结
2015/05/21 职场文书
2015年十月一日放假通知
2015/08/18 职场文书
个人售房合同协议书
2016/03/21 职场文书
解决mysql的int型主键自增问题
2021/07/15 MySQL