php工程师综合试卷,PHP工程师面试题

一、基础及程序题(建议使用你擅长的语言:C/C++、PHP、Java)

1.写一个排序算法,可以是冒泡排序或者是快速排序,假设待排序对象是一个维数组。(提示:不能使用系统已有函数,另外请仔细回忆以前学习过的基础知识)

2.实现一个字符串截取的函数,类似于substr,必须能够截取中文这种多字节编码。假设每个中文也是一个字符,普通的数字、符号、字母也是一个字符。(提示:GB编码的中文字符高位范围是 0x81-0xFE )

3.写一个遍历指定目录下所有子目录和子文件的函数(提示:可以使用递归的方法)

4.写出匹配邮箱地址和URL的两个正则表达式。类似下面的:

邮箱地址:user_name.first@example.com.cn

URL地址:http://www.example.com.cn/user_profile.php?uid=100

(提示:使用标准的正则表达式,就是PHP中preg_* 类的正则处理函数能够解析的正则)

二、数据库技术题

1.写出三种以上MySQL数据库存储引擎的名称(提示:不区分大小写)

2.说出你所知道的三种以上开源数据库的名称(提示:想想目前国外流行的开源数据库)

3.MySQL数据库中的字段类型varchar和char的主要区别是什么?那种字段的查找效率要高,为什么?

4.说出MySQL 4.0和MySQL 4.1版本的最主要的两个区别。如果你使用过MySQL 5,请说说MySQL 5跟MySQL 4的主要区别。(后半题选作)

5.MySQL数据库基本的三个优化法则是什么?(提示:从服务配置、应用、开发角度考虑)

三、综合技术题

1.请使用JavaScript写出三种产生一个Image 标签的方法(提示:从方法、对象、HTML角度考虑)

2.请使用CSS样式,描述两种方法在当前列中只显示一个div对象

3.请描述出两点以上XHTML和HTML最显著的区别

4.出五种以上你使用过的PHP的扩展的名称(提示:常用的PHP扩展)

5.了解MVC模式吗?请写出三种以上目前PHP流行的MVC框架名称(不区分大小写)

6.写出15个以上你所知道的常用的Linux命令和它的功能

7.使用过Vim编辑器吗?如果使用过,如何在vim里切分多个可视化窗口,包括横排和纵排。(本题选作)

8.说说Linux下的find命令和grep命令的区别(本题选作)

9.请描述出七层网络模型的名称,由下到上(可以使用中文描述)

10.说说下面这些这些协议的全称和中文解释(提示:都是工作在应用层)SMTP、POP3、HTTP、FTP、DNS

11.使用过Memcache缓存吗,如果使用过,能够简单的描述一下它的工作原理吗?(本题选作)

12.请大致的说说Session的工作原理。(提示:与Cookie有相应的关系)

13.说说你所了解的搜索引擎包含那些技术?(本题选作)

四、项目及设计题

1.一个Web开发团队开发中,大致说说你所了解的所有成员的分工合作情况

2.说说你做过的最得意的项目或者个人开发作品(可以是个人作品,也可以是合作项目)

3.假设给你5台服务器,请大致的描述一下,如何使用你所熟悉的开源软件,搭建一个日PV 300万左右的中型网站

六、数据库技术题

6.写出三种以上MySQL数据库存储引擎的名称(提示:不区分大小写)

MyISAM、InnoDB、BDB(Berkeley DB)、Merge、Memory(Heap)、Example、Federated、Archive、CSV、Blackhole、MaxDB 等等十几个引擎

7.说出你所知道的三种以上开源数据库的名称(提示:想想目前国外流行的开源数据库)

MySQL、SQLite、BDB(Berkeley DB)、PostgreSQL、Firebird

8.MySQL数据库中的字段类型varchar和char的主要区别是什么?那种字段的查找效率要高,为什么?

Varchar是变长,节省存储空间,char是固定长度。查找效率要char型快,因为varchar是非定长,必须先查找长度,然后进行数据的提取,比char定长类型多了一个步骤,所以效率低一些

9.说出MySQL 4.0和MySQL 4.1版本的最主要的两个区别。如果你使用过MySQL 5,请说说MySQL 5跟MySQL 4的主要区别。(后半题选作)

MySQL 4.1 主要是比MySQL 4.0多了子查询和字符编码的支持两个特点。

MySQL5增加的功能比MySQL4要更多,包括存储过程、视图、事务等等

10.MySQL数据库基本的三个优化法则是什么,除了增加硬件和带宽?(提示:从服务配置、应用、开发角度考虑)

(1)系统服务优化,把MySQL的key_buffer、cache_buffer、query_cache等增加容量

(2)给所有经常查询的字段增加适当的索引

(3)优化SQL语句,减少Ditinct、Group、Join等等语句的操作

面试题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的代码:

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.设计一个网页,使得打开它时弹出一个全屏的窗口,该窗口中有一个文本框和一个按钮。用户在文本框中输入信息后点击按钮就可以把窗口关闭,而输入的信息却在主网页中显示。

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 ________

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. 请举例说明在你的开发过程中用什么方法来加快页面的加载速度。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值