最新PHP程序员面试题经典及答案集锦.doc
《最新PHP程序员面试题经典及答案集锦.doc》由会员分享,可在线阅读,更多相关《最新PHP程序员面试题经典及答案集锦.doc(79页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、Four short words sum up what has lifted most successful individuals above the crowd: a little bit more.-author-datePHP程序员面试题经典及答案集锦PHP程序员面试题经典及答案集锦都是经典基础题:1.表单中 get与post提交方法的区别?答:get是发送请求HTTP协议通过url参数传递进行接收,而post是实体数据,可以通过表单提交大量信息.2.session与cookie的区别?答:session:储存用户访问的全局唯一变量,存储在服务器上的php指定的目录中的(sessio
2、n_dir)的位置进行的存放 cookie:用来存储连续訪問一个頁面时所使用,是存储在客户端,对于Cookie来说是存储在用户WIN的Temp目录中的。 两者都可通过时间来设置时间长短3.数据库中的事务是什么?答:事务(transaction)是作为一个单元的一组有序的数据库操作。如果组中的所有操作都成功,则认为事务成功,即使只有一个操作失败,事务也不成功。如果所有操作完成,事务则提交,其修改将作用于所有其他数据库进程。如果一个操作失败,则事务将回滚,该事务所有操作的影响都将取消。简述题:1、用PHP打印出前一天的时间格式是2006-5-10 22:21:21(2分)答:echo date(Y
3、-m-d H:i:s, strtotime(-1 days); 2、echo(),print(),print_r()的区别(3分)答:echo是PHP语句, print和print_r是函数,语句没有返回值,函数可以有返回值(即便没有用) print() 只能打印出简单类型变量的值(如int,string) print_r() 可以打印出复杂类型变量的值(如数组,对象) echo 输出一个或者多个字符串3、能够使HTML和PHP分离开使用的模板(1分)答:Smarty,Dwoo,TinyButStrong,Template Lite,Savant,phemplate,XTemplate5、使用
4、哪些工具进行版本控制?(1分)答:cvs,svn,vss;6、如何实现字符串翻转?(3分)答:echo strrev($a);7、优化MYSQL数据库的方法。(4分,多写多得)答:1、选取最适用的字段属性,尽可能减少定义字段长度,尽量把字段设置NOT NULL,例如省份,性别,最好设置为ENUM2、使用连接(JOIN)来代替子查询: a.删除没有任何订单客户:DELETE FROM customerinfo WHERE customerid NOT in(SELECT customerid FROM orderinfo) b.提取所有没有订单客户:SELECT FROM customerinf
5、o WHERE customerid NOT in(SELECT customerid FROM orderinfo) c.提高b的速度优化:SELECT FROM customerinfo LEFT JOIN orderid customerinfo.customerid=orderinfo.customerid WHERE orderinfo.customerid IS NULL3、使用联合(UNION)来代替手动创建的临时表 a.创建临时表:SELECT name FROM nametest UNION SELECT username FROM nametest24、事务处理: a.保证
6、数据完整性,例如添加和修改同时,两者成立则都执行,一者失败都失败 mysql_query(BEGIN); mysql_query(INSERT INTO customerinfo (name) VALUES ($name1); mysql_query(SELECT * FROM orderinfo where customerid=.$id); mysql_query(COMMIT);5、锁定表,优化事务处理: a.我们用一个 SELECT 语句取出初始数据,通过一些计算,用 UPDATE 语句将新值更新到表中。 包含有 WRITE 关键字的 LOCK TABLE 语句可以保证在 UNLOCK
7、 TABLES 命令被执行之前, 不会有其它的访问来对 inventory 进行插入、更新或者删除的操作 mysql_query(LOCK TABLE customerinfo READ, orderinfo WRITE); mysql_query(SELECT customerid FROM customerinfo where id=.$id); mysql_query(UPDATE orderinfo SET ordertitle=$title where customerid=.$id); mysql_query(UNLOCK TABLES);6、使用外键,优化锁定表 a.把custo
8、merinfo里的customerid映射到orderinfo里的customerid, 任何一条没有合法的customerid的记录不会写到orderinfo里 CREATE TABLE customerinfo ( customerid INT NOT NULL, PRIMARY KEY(customerid) )TYPE = INNODB; CREATE TABLE orderinfo ( orderid INT NOT NULL, customerid INT NOT NULL, PRIMARY KEY(customerid,orderid), FOREIGN KEY (custome
9、rid) REFERENCES customerinfo (customerid) ON DELETE CASCADE )TYPE = INNODB; 注意:ON DELETE CASCADE,该参数保证当customerinfo表中的一条记录删除的话同时也会删除order 表中的该用户的所有记录,注意使用外键要定义事务安全类型为INNODB;7、建立索引: a.格式: (普通索引)- 创建:CREATE INDEX ON tablename (索引字段) 修改:ALTER TABLE tablename ADD INDEX 索引名 (索引字段) 创表指定索引:CREATE TABLE tab
10、lename(.,INDEX索引名(索引字段) (唯一索引)- 创建:CREATE UNIQUE ON tablename (索引字段) 修改:ALTER TABLE tablename ADD UNIQUE 索引名 (索引字段) 创表指定索引:CREATE TABLE tablename(.,UNIQUE索引名(索引字段) (主键)- 它是唯一索引,一般在创建表是建立,格式为: CREATA TABLE tablename (.,PRIMARY KEY索引字段)8、优化查询语句 a.最好在相同字段进行比较操作,在建立好的索引字段上尽量减少函数操作 例子1: SELECT * FROM ord
11、er WHERE YEAR(orderDate)2008;(慢) SELECT * FROM order WHERE orderDate2008-01-01;(快) 例子2: SELECT * FROM order WHERE addtime/724;(慢) SELECT * FROM order WHERE addtime=good and name$length) $str=null; $len=$start+$length; for($i=$start;$i0xa0) $str.=substr($string,$i,2); $i+; else $str.=substr($string,$
12、i,1); return $str.; else return $string; 11、您是否用过版本控制软件? 如果有您用的版本控制软件的名字是?(1分)12、您是否用过模板引擎? 如果有您用的模板引擎的名字是?(1分)答:用过,smarty13、请简单阐述您最得意的开发之作(4分)答:信息分类14、对于大流量的网站,您采用什么样的方法来解决访问量问题?(4分)答:确认服务器硬件是否足够支持当前的流量,数据库读写分离,优化数据表, 程序功能规则,禁止外部的盗链,控制大文件的下载,使用不同主机分流主要流量15、用PHP写出显示客户端IP与服务器IP的代码1分)答:打印客户端IP:echo $_
13、SERVERREMOTE_ADDR; 或者: getenv(REMOTE_ADDR); 打印服务器IP:echo gethostbyname()16、语句include和require的区别是什么?为避免多次包含同一文件,可用(?)语句代替它们? (2分)答:require-require是无条件包含也就是如果一个流程里加入require,无论条件成立与否都会先执行require include-include有返回值,而require没有(可能因为如此require的速度比include快) 注意:包含文件不存在或者语法错误的时候require是致命的,include不是17、如何修改SES
14、SION的生存时间(1分).答:方法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);18、有一个网页地址, 比如PHP开发资源网主页: 答:方法1(对
15、于PHP5及更高版本): $readcontents = fopen( rb); $contents = stream_get_contents($readcontents); fclose($readcontents); echo $contents; 方法2: echo file_get_contents( 19、在HTTP 1.0中,状态码401的含义是(?);如果返回“找不到文件”的提示,则可用 header 函数,其语句为(?);(2分)答:状态401代表未被授权,header(Location:www.xxx.php);12、在PHP中,heredoc是一种特殊的字符串,它的结束标
16、志必须?(1分)答:heredoc的语法是用加上自己定义成对的标签,在标签范围內的文字视为一个字符串 例子: $str = SHOW my name is Jiang Qihui! SHOW;13、谈谈asp,php,jsp的优缺点(1分)答:ASP全名Active Server Pages,是一个WEB服务器端的开发环境, 利用它可以产生和运行动态的、交互的、高性能的WEB服务应用程序。ASP采用脚本语言VB Script(Java script)作为自己的开发语言。 PHP是一种跨平台的服务器端的嵌入式脚本语言. 它大量地借用C,Java和Perl语言的语法, 并耦合PHP自己的特性,使W
17、EB开发者能够快速地写出动态生成页面.它支持目前绝大多数数据库。还有一点,PHP是完全免费的,不用花钱,你可以从PHP官方站点(http:/)自由下载。而且你可以不受限制地获得源码,甚至可以从中加进你自己需要的特色。 JSP 是Sun公司推出的新一代站点开发语言,他完全解决了目前ASP,PHP的一个通病脚本级执行(据说PHP4 也已经在Zend 的支持下,实现编译运行).Sun 公司借助自己在Java 上的不凡造诣,将Java 从Java 应用程序 和 Java Applet 之外,又有新的硕果,就是JspJava Server Page。Jsp 可以在Serverlet和JavaBean的支
18、持下,完成功能强大的站点程序。 三者都提供在 HTML 代码中混合某种程序代码、由语言引擎解释执行程序代码的能力。但JSP代码被编译成 Servlet 并由 Java 虚拟机解释执行,这种编译操作仅在对 JSP 页面的第一次请求时发生。在 ASP 、PHP、JSP 环境下, HTML 代码主要负责描述信息的显示样式,而程序代码则用来描述处理逻辑。普通的 HTML 页面只依赖于 Web 服务器,而 ASP 、PHP、JSP 页面需要附加的语言引擎分析和执行程序代码。程序代码的执行结果被重新嵌入到 HTML 代码中,然后一起发送给浏览器。 ASP 、PHP、 JSP三者都是面向 Web 服务器的技
19、术,客户端浏览器不需要任何附加的软件支持。14、谈谈对mvc的认识(1分)答:由模型(model),视图(view),控制器(controller)完成的应用程序 由模型发出要实现的功能到控制器,控制器接收组织功能传递给视图;15、写出发贴数最多的十个人名字的SQL,利用下表:members(id,username,posts,pass,email)(2分)答:SELECT * FROM members ORDER BY posts DESC limit 0,10;16. 请说明php中传值与传引用的区别。什么时候传值什么时候传引用?(2分)答:按值传递:函数范围内对值的任何改变在函数外部都会
20、被忽略 按引用传递:函数范围内对值的任何改变在函数外部也能反映出这些修改 优缺点:按值传递时,php必须复制值。特别是对于大型的字符串和对象来说,这将会是一个代价很大的操作。 按引用传递则不需要复制值,对于性能提高很有好处。17. 在PHP中error_reporting这个函数有什么作用? (1分)答:设置错误级别与错误信息回报18. 请写一个函数验证电子邮件的格式是否正确 (2分)答:function checkEmail($email) $pregEmail = /(a-z0-9*-_/.?a-z0-9+)*(a-z0-9*-_?a-z0-9+)+/.a-z2,3(/.a-z2)?/i;
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 最新 PHP 程序员 试题 经典 答案 集锦
限制150内