蜜蜂职场文库 > 面试技巧 >

php常见面试题

时间: 小龙 面试技巧

  php面试中,面试前必须做好准备,提前对面试题目有所了解,以下是小编为大家整理的php常见面试题,希望可以帮到大家。

  php常见面试题一

  1、表单提交get和post有何区别?

  答:get的方式是把数据在地址栏中发送,get传送的数据量较小,不能大于2KB。post传送的数据量较大,一般被默认为不受限制。但理论上,IIS4中最大量为80KB,IIS5中为100KB。

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

  echo date("Y-m-d H:i:s",time()-(3600*24));或echo date("Y-m-d H:i:s",strtotime("-1 day"));

  3、php中include和require的区别?

  这两种结构除了在如何处理失败之外完全一样。include() 产生一个警告而 require() 则导致一个致命错误。换句话说,如果你想在遇到丢失文件时停止处理页面就用 require()。include() 就不是这样,脚本会继续运行。

  4、echo(),print(),print_r()的区别

  echo可以接多个参数,print只能接一个参数,它们都是PHP的语言结构,print_r是递规打印,用来打印数组或对象

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

  smarty,phplib,SmartTemplate

  6、你如何理解MVC模式?

  首先说一下框架,框架:就是别人把一些底层,常用操作.比如数据操作(增,删,改,查)写好.你来直接用.其它的功能要自己来做。

  MVC:设计模式,M模型,V显示,C控制.现在许多框架都是基于MVC来做的把逻辑和显示分开.比如你要换页面,只需要改V里面的东西并不需要再去变动程序(详细的东西可以上网上!查一下)

  7、如何实现PHP、JSP交互?

  PHP提供了支持JAVA的类库文件,或者通过HTTP协议来交互数据

  8、使用哪些工具进行版本控制?

  VSS,CVS,SVN

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

  不考虑中英文混合,不是最优算法,不用php库函数翻转字符串:

  function str_to_reverse( $str ){

  for($length=0;$str[$length]!=null;$length++){;}

  $strlength = $length-1;

  unset($length);

  for($start=0,$end=$strlength;$start<$end;$start++,$end--){

  $temp = $str[$start];

  $str[$start] = $str[$end];

  $str[$end] = $temp;

  }

  unset($temp,$start,$end,$strlength);

  return $str;

  }

  10、优化MYSQL数据库的方法。

  1) 将where中用的比较频繁的字段建立索引,联合索引。

  2) 保证单表数据不超过200W,适时分割表。

  3) 避免使用长连接。

  4) 修改my.cnf里面的各项参数,比如最大连接数,查询缓存等。根据你的服务器内存来最大化调节那些配置参数。

  5) 针对需求,使用正确的表引擎,是myisam或是innodb。

  php常见面试题二

  1、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;

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

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

  这个首先要考虑字符集的问题,UTF-8下一个汉字占3字节,GBK下一个汉字占2字节.可以自己写个函数来处理,别人也写了很多,当然也可以开启mbstring扩展库,使用里面的mb_substr()等函数来截取。当截取字符出现乱码时,是因为汉字被截断了,可以再字符串尾部连上一个chr(0)

  var $empty = '';

  var $null = NULL;

  var $bool = FALSE;

  var $notSet;

  var $array = array();

  4,Http 和Https的区别

  第一:http是超文本传输协议,信息是明文传输,https是具有安全性的ssl加密传输协议

  第二:http和https使用的是完全不同的连接方式,端口也不一样,前者80 或者443 第三:http连接很简单,是无状态的。https协议是由ssl+http协议构建的可进行加密传输,身份认证的网络协议。

  5.什么方法来加快页面的加载速度

  01,用到服务器资源时在打开,不用时,立即关闭服务器资源。

  02,数据库添加索引

  03,页面可生成静态

  04,图片等大文件单独放在一个服务器

  05,能不查询数据库的尽量不去数据取数据,可以放在缓存中。

  6.表单中 get与post提交方法的区别?

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

  7.echo ,print,print_r 的区别:

  echo 是php语句,无返回值。

  print,print_r是函数,有返回值。

  print() 只能打印出简单类型变量的值(如int,string) print_r() 可以打印出复杂类型变量的值(如数组,对象) echo 输出一个或者多个字符串

  8.session与cookie区别

  session与cookie相同:跨页面、不跨用户

  session与cookie不相同:

  1、session可以存储任意类型的数据,但cookie只能存储字符串

  2、cookie产生在服务器端、存储在客户端

  session产生在服务器端、存储在服务器端

  php常见面试题三

  1.用PHP写出显示客户端IP与服务器IP的代码:

  echo $_SERVER['REMOTE_ADDR'] //客户端ip

  echo $_SERVER['SERVER_ADDR'] //服务器端ip

  2、apache+mysql+php实现最大负载的方法

  1) 问的太笼统,生成静态html页面,squid反向代理,apache,mysql的负载均衡。

  2) 可以采取数据缓存的方法,我们通常在统计数据的时候,需要在原始数据的基础上经过计算等一系列操作,才会得到最终的结果,如果每做一个查询都需要这样一系列操作,当数据量大时,势必会带来很多问题。可以建立一个结果表,写一个脚本,用crontab定时触发脚本去原始表取数据,计算,写入到结果表,前端查询从结果表取数据,这也是比较常用的一种做法。

  3) 采用分布式,多个apache,多个mysql,其实就是dns负载均衡,dns根据当前用户解析几个ip的ping值,将用户转移到某一台最快的服务器,或者平均分配。

  4 )money不是问题的话,可以考虑F5硬件负载均衡!

  5)可以使用Microsoft Windows Server系统的负载均衡设置

  3.数据库中的事务是什么?

  答:事务(transaction)是作为一个单元的一组有序的数据库操作。如果组中的所有操作都成功,则认为事务成功,即使只有一个操作失败,事务也不成功。如果所有操作完成,事务则提交,其修改将作用于所有其他数据库进程。如果一个操作失败,则事务将回滚,该事务所有操作的影响都将取消。

  4.1优化MYSQL数据库的方法。

  1、选择合适的字段的数据类型

  1)能用数字不用字符串

  2)char、varchar、text 能用varchar不用char

  3)给字段加not null 避免在表中出现NULL关键字(default 值)

  2、选择合适的字段充当主键

  1)建议每张表必须有主键

  2)用数字类型的字段充当主键

  3、拆分表

  1)拆分字段,将文章的标题与内容分开

  2)拆分记录,将今年的记录与往年的记录分开

  4、给字段合理添加索引

  a.格式:

  (普通索引)->

  创建:CREATE INDEX <索引名> ON tablename (索引字段)

  修改:ALTER TABLE tablename ADD INDEX [索引名] (索引字段)

  创表指定索引:CREATE TABLE tablename([...],INDEX[索引名](索引字段)) (唯一索引)->

  创建:CREATE UNIQUE <索引名> ON tablename (索引字段)

  修改:ALTER TABLE tablename ADD UNIQUE [索引名] (索引字段)

  创表指定索引:CREATE TABLE tablename([...],UNIQUE[索引名](索引字段)) (主键)->

  它是唯一索引,一般在创建表是建立,格式为:

  CREATA TABLE tablename ([...],PRIMARY KEY[索引字段])

  5、事务处理:

  a.保证数据完整性,例如添加和修改同时,两者成立则都执行,一者失败都失败 mysql_query("BEGIN");

  mysql_query("INSERT INTO customerinfo (name) VALUES ('$name1')";

  mysql_query("SELECT * FROM `orderinfo` where customerid=".$id");

  mysql_query("COMMIT");

  6、锁定表,优化事务处理:

  a.我们用一个 SELECT 语句取出初始数据,通过一些计算,用 UPDATE 语句将新值更新

49898