2017最新PHP面试题

  1. 如果帮到了您,可以支持一下,谢谢您的支持!我会及时补充最新的面试题
        1. 使对象可以像数组一样进行foreach循环,要求属性必须是私有。 
          class sample implements Iterator
          {
              private $_items = array(1,2,3,4,5,6,7);
          
              public function __construct() {
                  ;//void
              }
              public function rewind() { reset($this->_items); }
              public function current() { return current($this->_items); }
              public function key() { return key($this->_items); }
              public function next() { return next($this->_items); }
              public function valid() { return ( $this->current() !== false ); }
          }
          
          $sa = new sample();
          foreach($sa as $key => $val){
              print $key . "=>" .$val
          }
          
             
      1. 求 一个数组中出现最多的值
    1. $array = array(1, 1, 1, 54, 3,4, 3,4, 3, 14, 3,4, 3,7,8,9,12,45,66,5,7,8,9,2,45);
      $array2 = array_count_values($array); // 统计数组中所有值出现的次数
      arsort($array2); // 按照键值对关联数组进行降序排序
      $first = reset($array2);
      $first_key = key($array2);
      echo("数组中数字{$first_key}重复次数最多,为:{$first}次");
      exit;

    2. 写出创建多级目录的函数(新浪校招)
    3.   /*
        写出一个能创建多级目录的PHP函数
        */
        function createdirlist( $path , $mode ){
          if ( is_dir ( $path )){
          //判断目录存在否,存在不创建
            echo "目录'" . $path . "'已经存在" ;
         //已经存在则输入路径
          } else { //不存在则创建目录
             $re = mkdir ( $path , $mode ,true);
         //第三个参数为true即可以创建多极目录
            if ( $re ){
              echo "目录创建成功" ; //目录创建成功
            } else {
              echo "目录创建失败" ;
             }
            }
         }
      $path = "/a/x/cc/cd" ; //要创建的目录
      $mode =0755; //创建目录的模式,即权限.
      createdirlist( $path , $mode ); //测试
    4. 1.函数内部 static 和 global 关键字的作用,如:

      function foo()
      {
          static $a = 111;
          global $b;
      }

      2.子类重写父类的 protected 方法有什么限制?或者说有什么要遵守的规则?

      3.PHP文件末尾是否应该加 ?> 结束符号,为什么?

      4.谈一谈 PHP 开源框架 CI,ThinkPHP,Laravel 的优缺点及选型依据

      5.Memcache 和 Redis 的读写性能(qps)如何?两者优缺点?Redis 支持哪些数据类型?Redis 如何持久化?

      6.使用 PHP 下载网络图片,有哪些方法?

      7.什么是 CGI?什么是 FastCGI?php-fpm,FastCGI,Nginx 之间是什么关系?

      8.什么是 CSRF 攻击 ?XSS 攻击?如何防范?

      XSS跨站脚本攻击

      XSS跨站脚本攻击指攻击者在网页中嵌入客户端脚本(例如JavaScript),当用户浏览此网页时,脚本就会在用户的浏览器上执行,从而达到攻击者的目的,比如获取用户的Cookie,导航到恶意网站,携带木马等。

      如何防止XSS跨站脚本攻击:

      原则:不相信用户输入的数据

      1. 将重要的cookie标记为http only,这样的话Javascript 中的document.cookie语句就不能获取到cookie了
      2. 只允许用户输入我们期望的数据。例如:年龄的textbox中,只允许用户输入数字,而数字之外的字符都过滤掉
      3. 对数据进行Html Encode 处理。< 转化为 <、> 转化为 >、& 转化为 &、' 转化为 '、" 转化为 "、空格 转化为  
      4. 过滤或移除特殊的Html标签。例如:

      CSRF跨站请求伪造

      CSRF(XSRF)尽管听起来很想XSS跨站脚本攻击,但是它于XSS完全不同。XSS是利用站点内的信任用户,而CSRF则是通过伪装来自受信任用户的请求来利用受信任的站点。与XSS相比,CSRF攻击不大流行和难以防范,所以比XSS更具危险性。

      如何防止CSRF跨站请求伪造:

      1. 对于web站点,将持久化的授权方法(例如cookie或者HTTP授权)切换为瞬时的授权方法(在每个form中提供隐藏field)。
      2. “双提交”cookie。此方法只工作于Ajax请求,但它能够作为无需改变大量form的全局修正方法。如果某个授权的cookie在form post之前正被JavaScript代码读取,那么限制跨域规则将被应用。什么叫限制跨域规则呢?限制跨域规则就是:如果服务器需要在Post请求体或者URL中包含授权cookie的请求,那么这个请求必须来自于受信任的域,因为其它域是不能从信任域读取cookie的。上面那个例子的受信任域就是银行网站的某个域,而Mallory发给Bob的链接不是受信任的域。
      3. 使用Post代替Get。Post方式不会在web服务器和代理服务器日志中留下数据尾巴,然而Get方式却会留下数据尾巴。
      4. 以上三点都是正对web站点的防御手段,第4点是从用户的角度的防御手段。通过在浏览其它站点前登出站点或者在浏览器会话结束后清理浏览器的cookie来防止CSRF攻击。

      SQL注入

      所谓SQL注入,就是通过把SQL命令插入到Web表单递交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行恶意的SQL命令。

      如何防止SQL注入:

        1. 永远不要信任用户的输入。对用户的输入进行校验,可以通过正则表达式,或限制长度;对单引号和双”-“进行转换等。
        2. 永远不要使用动态拼装sql,可以使用参数化的sql或者直接使用存储过程进行数据查询存取
        3. 永远不要使用管理员权限的数据库连接,为每个应用使用单独的权限有限的数据库连接
        4. 不要把机密信息直接存放,加密或者hash掉密码和敏感的信息
        5. 应用的异常信息应该给出尽可能少的提示,最好使用自定义的错误信息对原始错误信息进行包装
    5. 9.列举常用的设计模式并说明?单例模式,观察者模式等等

      10.写一段代码,实现PHP内部的通知机制,如当一个类的属性发生变化时,另外一个类就可以收到通知。

    6. PHP基础
      1:变量的传值与引用。
      2:变量的类型转换和判断类型方法。
      3:php运算符优先级,一般是写出运算符的运算结果。
      4:PHP中函数传参,闭包,判断输出的echo,print是不是函数等。
      5:PHP数组,数组函数,数组遍历,预定义数组(面试必出)。
      6:PHP面向对象,魔术方法,封装、继承、多态。设计模式,包括(单利、工厂、迭代器、装饰、命令、策略)。
      7:正则表达式,每个标号含义,邮箱、网址、标签匹配,正则函数(面试必出)。
      8:PHP异常处理(级别,错误日志,控制错误输出)。
      9:PHP时间函数,日期计算函数。
      10:文件系统,记录日志、目录、文件的遍历、上传、多方法得到文件扩展名、文件引用方式、引用函数区别。(面试必出)。
      11:会话控制,主要说原理。session与cookie在分布式应用中出现问题的解决方案。
      12:PHP模板引擎,常用模板引擎特点,MVC好与不好的地方。
      13:PHP安全处理,过滤函数。
      14:XML的使用。
      15:PHP字符串的处理,包括转义(安全)、编码、截取、定位、与数组间的转换、处理函数等。(面试必出)。
      16:Socket编程,各种协议,head头,curl参数含义。
      17:网络状态码含义,常用(204,304, 404, 504,502)。
      18:Apache配置文件,PHP配置文件,各个含义字段的含义。
      19:网络各种攻击的名词含义(SQL攻击、XSS、CSRF、DDos),防止措施。
      20:url的处理函数,得到url指定的部分。
       
      Mysql基础
      复制代码_www.wityx.com
      1:基础sql语句书写(一般让写关联和子查询语句)
      2:索引的创建,优缺点,最左原则
      3:存储引擎,常用的几个,优缺点,差别,原理(面试必出)
      4:sql注入的处理方法
      5:mysql处理函数(PHP中封装的)
      6:PDO的使用方法,为什么使用
      7:mysql的优化,表拆分等
      8:事务处理,sql语句的处理效率等
      9:数据表字段的类型,同类型间的区别,改如何选取,int(10)与int(11)的区别等。
      10:数据库索引使用的那种数据结构,画出数据结构
      复制代码_www.wityx.com
       
      Linux
      1:常用命令的使用,vim编辑器的使用。
      2:进程,cpu等信息的查看命令。
      3:文件内查看命令(主要涉及统计信息)。
      4:Shell的使用,命令操作。
       
      NoSql
      1:Redis的应用场景,结合微博业务说出他的具体应用。
      2:Redis与MC支持数据的不同点,两者都支持哪些数据结构的存储,写越多越好。
      3:Redis持久化存储的原理,与Mysql的应用区别。怎样保持持久化数据与内存数据同步的关系(Redis同步机制)
      4:Redis与MC在并发状态下的性能比较。
      5:MC的内存管理机制,当一个数据需要存储的时候怎样分配内存空间
      6:Redis的内存管理机制,与MC有哪些不同点。
       
      开发环境
      1:PHP7中的新特性与废弃的特性
      2:为什么要使用PHP7,PHP7快在哪里
       
      版本控制
      1:git的使用命令,例如:写出版本回退命令。
      2:git与svn的区别。
      3:如何进行多分支开发,包括多人开发协同,分段测试,上线。

       

      PHP部分

      1、HTTP Keep-Alive的作用

      2、php数组函数常见的那些? (array_merge、in_array的作用)

      3、PHP中几个输出函数echo,print(),print_r(),sprintf(),var_dump()的区别

      4、不用新变量直接交换现有两个变量的值

      5、heredoc

      6、写个函数来解决多线程同时读写一个文件的问题。

      7、禁掉cookie的session使用方案,设置session过期的方法,对应函数

      8、json格式数据有哪些特点

      9、php获取文件内容的方法,对应的函数

      10、php魔术方法与魔术常量

      11、PHP 如何获取客户端的IP地址

      12、写一个函数,可以遍历文件夹下的所有文件和文件夹。

      13、有mail.log的一个文档,内容为若干邮件地址,用’\n’分隔换行。挑选sina.com的地址。

      14、PHP缓存技术有哪些? tp是局部还是完全缓存?

      15、strlen()与mb_strlen的作用与区别

      16、写一个函数,尽可能高效的从一个标准url中取出扩展名

      17、php.ini 中safe mod关闭 影响哪些函数和参数,至少写6个?

      18、  约瑟夫环问题

      19、Isset() 、empty()与is_null的区别

      20、求两个文件的相对路径

      21、MVC的优缺点

      22、Session与cookie的联系和区别(运行机制),session共享问题解决方案

      23、正则表达式

      24、写一个函数得到header头信息

       

      MySQL部分

       1、select * from table where (ID = 10)  or (ID = 32) or (ID = 22)  让结果按10, 32, 22的顺序检索出来?

       

      Linux部分

      1、Core文件是什么,有什么用?

      2、共享内存除了文件映射还有什么方式?

      3、请解释下列10个shell命令的用途

      4、Linux文件属性有哪些?(共十位)

      5、Linux查询命令

       

      服务器部分

      1、Apache与Nginx的优缺点比较 

      2、Cgi 与fastcgi的区别

      3、Select, poll和epoll的区别

      4、Memcache和Redis区别


       

      php部分我是按照面试常问的问题总结的,下面的问题在面试中出场率很高。问题比较基础

      1、HTTP Keep-Alive的作用

      作用:Keep-Alive:使客户端到服务器端的连接持续有效,当出现对服务器的后继请求时,Keep-Alive功能避免了建立或者重新建立连接。Web服务器,基本上都支持HTTP Keep-Alive。

      缺点:对于提供静态内容的网站来说,这个功能通常很有用。但是,对于负担较重的网站来说,虽然为客户保留打开的连 接有一定的好处,但它同样影响了性能,因为在处理暂停期间,本来可以释放的资源仍旧被占用。当Web服务器和应用服务器在同一台机器上运行时,Keep- Alive功能对资源利用的影响尤其突出。

      解决:Keep-Alive: timeout=5, max=100
      timeout:过期时间5秒(对应httpd.conf里的参数是:KeepAliveTimeout),max是最多一百次请求,强制断掉连接。就是在timeout时间内又有新的连接过来,同时max会自动减1,直到为0,强制断掉。

      2、php数组函数常见的那些? (array_merge、in_array的作用)

           PHP中以array_开头的数组函数有哪些,并说出使用方法(至少6个)
       
      一、数组遍历函数
      1 list();  //不是真正的函数,而是PHP的语言结构,用于给一组变量赋值,仅能用于索引数组
      2 each();  //返回数组当前元素的键值对,并将指针移动到下一个元素位置
      3 while(); //可配合list或each使用:while(list($key, $value) = each($arr)){each $key, $value; }
       
      二、数组内部指针控制
      1 current();  //读取指针位置的内容
      2 key();      //读取当前指针指向内容的索引值
      3 next();     //将数组中的内部指针指向下一单元
      4 prev();     //将数组内部指针倒回一位
      5 end();      //将数组内部指针指向最后一个元素
      6 reset();    //将目前指针指向第一个索引位置
      三、数组键值操作函数
      复制代码_www.wityx.com
      1 array_values($arr);       //获得数组的值
      2 array_keys($arr);         //获得数组的键名
      3 array_flip($arr);         //数组中的值与键名互换(如果有重复前面的会被后面的覆盖)
      4 array_search('PHP',$arr); //检索给定的值,加true则是严格类型检查
      5 array_reverse($arr);      //将数组中的元素翻转(前后顺序)
      6 in_array("apple", $arr);  //在数组中检索apple
      7 array_key_exists("apple", $arr); // 检索给定的键名是否存在数组中
      8 array_count_values($arr);        // 统计数组中所有值出现的次数
      9 array_unique($arr);              // 删除数组中重复的值
      
      复制代码_www.wityx.com
       
      四、数组回调函数
      1 array_filter(); //使用回调函数过滤数组中的元素,如果回调返回true则当前的元素被包含到返回数组中
      2 array_walk();   //回调函数处理数组,自定义函数要有两个参数,本函数第三个参数可以作为回调第三个参数返回
      3 array_map();    //可以处理多个数组,每个数组的长度应该相同,传入数组的个数和回调函数参数个数应该一致
      二、数组的分段和填充
      1 array_slice($arr, 0, 3);    //将数组中的一段取出,此函数忽略键名(数组的分段)
      2 array_splice($arr, 0, 3,array("black","maroon"));    //将数组中的一段取出,返回的序列从原数组中删除
      3 array_chunk($arr, 3, TRUE);   //将一个数组分割成多个,TRUE为保留原数组的键名(分割多个数组)
      四、数组与栈,列队
      1 array_push($arr, "apple", "pear");    //将一个或多个元素压入数组栈的末尾(入栈),返回入栈元素的个数
      2 array_pop($arr);    // 将数组栈的最后一个元素弹出(出栈)
      3 array_shift($arr);   //数组中第一个元素移出并返回(长度减1,其他元素向前移动一位,数字键名改为从零计数,文字键名不变)
      4 array_unshift($arr,"a",array(1,2));  //在数组的开头插入一个或多个元素
      六、数组的排序
      复制代码_www.wityx.com
      1 sort($arr);      //由小到大,忽略键名
      2 rsort($arr);     //由大到小,忽略键名
      
      3 asort($arr);     //由小到大,保留键名
      4 arsort($arr);    //由大到小,保留键名
      
      5 ksort($arr);     //按照键名正序排序
      6 krsort($arr);    //按照键名逆序排序
      复制代码_www.wityx.com
      七、数组的计算
      复制代码_www.wityx.com
      1 array_sum($arr);   //对数组内部的所有元素做求和运算(数组元素的求和)
      2 array_merge($arr1, $arr2); //合并两个或多个(相同字符串键名,后面覆盖前面,相同的数字键名,后面的附加到后面)
      3  
      4 array_diff($arr1, $arr2);           //返回差集结果数组   array_diff_assoc($arr1, $arr2, $arr3);  //返回差集结果数组,键名也做比较
      5 array_intersect($arr1, $arr2);  //返回交集结果数组    array_intersect_assoc($arr1, $arr2);   //返回交集结果数组,键名也做比较 
      复制代码_www.wityx.com
      八、其他的数组函数
      1 array_unique($arr);   //移除数组中重复的值,新的数组中会保留原始的键名
      2 shuffle($arr);             // 将数组的顺序打乱
        3、PHP中几个输出函数echo,print(),print_r(),sprintf(),var_dump()的区别

      1:echo:是语句不是函数,没有返回值,可输出多个变量值,不需要圆括号。不能输出数组和对象,只能打印简单类型(如int,string)。

      2:print:是语句不是函数,有返回值 1 ,只能输出一个变量,不需要圆括号。不能输出数组和对象,只能打印简单类型(如int,string)。

      3:print_r:是函数,可以打印复合类型,例如:stirng、int、float、array、object等,输出array时会用结构表示,而且可以通过print_r($str,true)来使print_r不输出而返回print_r处理后的值

      4:printf:是函数,把文字格式化以后输出(参看C语言)

      5:sprintf:是函数,跟printf相似,但不打印,而是返回格式化后的文字(该函数把格式化的字符串写写入一个变量中,而不是输出来),其    他的与printf一样。 

      例如:  

      1 $str = "Hello";    
      2 $number = 123; 
      3 $txt = sprintf("%s world. Day number %u",$str,$number);
      4 //输出: Hello world. Day number 123 

      6:var_dump():函数,输出变量的内容、类型或字符串的内容、类型、长度。常用来调试。

      可以通过function_exists('函数名称')进行测试

      1 var_dump(function_exists('print'));  //bool(false)
      2 
      3 var_dump(function_exists('echo'));  //bool(false)
      4 
      5 var_dump(function_exists('print_r')); //bool(true)

      4、不用新变量直接交换现有两个变量的值

      复制代码_www.wityx.com
       1 1: 
       3     list($a, $b) = array($b, $a);
       4 2: 
       5     $a = $a . $b;
       5     $b = strlen( $b );
       6     $b = substr( $a, 0, (strlen($a) – $b ) );
       7     $a = substr( $a, strlen($b) );
       8 
       9 3:(必须用一个两个字符串都都不能出现的字符做为分隔符)
      10     $a = $b.','.$a ;
      11     $a = explode(',', $a);
      12     $b = $a[1];
      13     $a = $a[0];
      14 
      15 4:这个是当两个数都是数字的时候:
      16     $a = $a + $b;
      17     $b = $a – $b;
      18     $a = $a – $b;
      19 
      20 5:借助数组
      21     $a = array($a,$b);
      22     $b = $a[0];
      23     $a = $a[1];
      复制代码_www.wityx.com

      5、heredoc

      Heredoc在正规的PHP文档中和技术书籍中一般没有详细讲述。他是一种Perl风格的字符串输出技术。使用heredoc技术可以实现界面与代码的准分离,比如phpwind模板。

      heredoc的语法是用”<<<”加上自己定义成对的标签,在标签范围內的文字视为一个字符串

      规则如下:

      1、以<<开始标记开始,以End结束标记结束,结束标记必须顶头写,不能有缩进和空格,且在结束标记末尾要有分号 。开始标记和开始标记相同,比如常用大写的EOT、EOD、EOF来表示,也可以使用其他标记,只要保证开始标记和结束标记不在正文中出现就行

      2、位于开始标记和结束标记之间的变量可以被正常解析,但是函数则不可以。在heredoc中,变量不需要用连接符 . 或 , 来拼接,比如:

      1 $a=2;
      2 $b= << 
              

      3、heredoc常用在输出包含大量HTML语法文档的时候。他要比传统的echo输出精炼很多,如下所示:

      复制代码_www.wityx.com
       1 function getHtml()
       2 {
       3     echo "";
       4     echo "Title";
       5     echo "Content";
       6     echo ";
       7 }
       8 
       9 function getHtml()
      10 {
      11 echo <<
      13       Title
      14       Content
      15       
      16 EOT;
      17 }
      复制代码_www.wityx.com
       
      6、写个函数来解决多线程同时读写一个文件的问题。
      复制代码_www.wityx.com
       1 
      复制代码_www.wityx.com

       

      7、禁掉cookie的session使用方案,设置session过期的方法,对应函数

      通过 url 传值,把session id附加到url上(缺点:整个站点中不能有纯静态页面,因为纯静态页面session id 将无法继续传到下一页面)
      通过隐藏表单,把session id 放到表单的隐藏文本框中同表单一块提交过去(缺点:不适用标签这种直接跳转的非表单的情况)
      直接配置php.ini文件,将php.ini文件里的session.use_trans_sid= 0设为1,(好像在win上不支持)
      用文件、数据库等形式保存Session ID,在跨页过程中手动调用
      复制代码_www.wityx.com
       1 第一种  setcookie() 直接用setcookie设置session id的生命周期。
       3     $lifetime=60; //保存1分钟 
       4     session_start(); 
       5     setcookie(session_name(), session_id(), time()+$lifetime, "/");
       6 第二种  session_set_cookie_params()    
       7     $lifetime=60;//保存1分钟
       8     session_set_cookie_params($lifetime);
       9     session_start();
      10     session_regenerate_id(true);
      11     其中session_regenerate_id();方法用于改变当前session_id的值,并保留session中数组的值。参数默认为 false,如果设置为true则改变session_id的值,并清空当前session数组。
      复制代码_www.wityx.com

      8、json格式数据有哪些特点 

          JSON 一种轻量级的数据交换格式。它基于ECMAScript的一个子集。 JSON采用完全独立于语言的文本格式,但是也使用了类似于c语言家族的习惯(包括C、C++、C#、Java、JavaScript、Perl、 Python等)。这些特性使JSON成为理想的数据交换语言。 易于人阅读和编写,同时也易于机器解析和生成(网络传输速率)。

      JSON的结构基于下面两点

      1. "名称/值"对的集合 不同语言中,它被理解为对象(object),记录(record),结构(struct),字典(dictionary),哈希表(hash table),键列表(keyed list)等
      2. 值的有序列表 多数语言中被理解为数组(array) 
       
      9、php获取文件内容的方法,对应的函数
      1:file_get_contents得到文件的内容(可以以get和post的方式获取),整个文件读入一个字符串中
      2:用fopen打开url, 以get方式获取内容(借助fgets()函数)
      3:用fsockopen函数打开url(可以以get和post的方式获取),以get方式获取完整的数据,包括header和body
      4:使用curl库获取内容,使用curl库之前,需要查看php.ini,查看是否已经打开了curl扩展

      10、php魔术方法与魔术常量
       
      类方法:
      1、__construct(); 
        用法说明:具有构造函数的类会在每次创建新对象时先调用此方法,适合在使用对象之前做一些初始化工作。 如果子类中定义了构造函数则不会隐式调用其父类的构造函数。要执行父类的构造函数,需要在子类的构造函数中调用 parent::__construct()。如果子类没有定义构造函数则会如同一个普通的类方法一样从父类继承。
      2、__destruct(); 
        用法说明:析构函数会在到某个对象的所有引用都被删除或者当对象被显式销毁时执行。
       
      方法重载:
      3、__call();
        用法说明:在对象中调用一个不可访问方法时,__call(); 方法会被调用。
      4、__callStatic();
        用法说明:用静态方式中调用一个不可访问方法时,__callStatic(); 方法会被调用。
       
      属性重载:(只对类中私有受保护的成员属性有效)
      5、__get();
        用法说明:读取不可访问属性的值时, __get() 会被调用。
      6、__set();
        用法说明:在给不可访问属性赋值时, __set() 会被调用。
      7、__isset();
        用法说明:当对不可访问属性调用  isset() 或 empty() 时,__isset() 会被调用。
      8、__unset();
        用法说明:当对不可访问属性调用  unset() 时,__unset() 会被调用。
       
      序列化相关:
      9、__sleep();
        用法说明:序列化时调用, serialize() 函数会检查类中是否存在该魔术方法。如果存在,该方法会先被调用,然后才执行序列化操作。
      10、__wakeup();
        用法说明: unserialize() 会检查是否存在一个 __wakeup() 方法。如果存在,则会先调用该方法,用在反序列化操作中,例如重新建立数据库连接,或执行其它初始化操作
       
      操作类和对象方法:
      11、__toString();
         用法说明:方法用于一个类被当成字符串时调用,例如把一个类当做字符串进行输出
      12、__invoke();
        用法说明:当尝试以调用函数的方式调用一个对象时, __invoke() 方法会被自动调用。
      12、__set_state();
        用法说明:当调用 var_export() 导出类时,此静态 方法会被调用。 本方法的唯一参数是一个数组
      13、__clone();
         用法说明:当复制完成时,如果定义了 __clone() 方法,则新创建的对象(复制生成的对象)中的 __clone() 方法会被调用,可用于修改属性的值。
      14、__autoload();
         用法说明:该方法可以自动实例化需要的类。当程序要用一个类但没有被实例化时,改方法在指定路径下查找和该类名称相同的文件。否则报错。
       
      说明:PHP 将所有以 __(两个下划线)开头的类方法保留为魔术方法。所以在定义类方法时,除了上述魔术方法,建议不要以 __ 为前缀。在命名自己的类方法时不能使用这些方法名,除非是想使用其魔术功能。
       
      常量:
      __LINK__      //文件中的当前行号。
      __FILE__       //文件的完整路径和文件名。如果用在被包含文件中,则返回被包含的文件名。
      __DIR__       //文件所在的目录。如果用在被包括文件中,则返回被包括的文件所在的目录,它等价于 dirname(__FILE__)。
       
      __FUNCTION__       //函数名称。自 PHP 5 起本常量返回该函数被定义时的名字(区分大小写)。在 PHP 4 中该值总是小写字母的。
       __CLASS__              //类的名称。自 PHP 5 起本常量返回该类被定义时的名字(区分大小写)。在 PHP 4 中该值总是小写字母的。
       __METHOD__         //类的方法名(PHP 5.0.0 新加)。返回该方法被定义时的名字(区分大小写)。
       __NAMESPACE__   //当前命名空间的名称(大小写敏感)。这个常量是在编译时定义的(PHP 5.3.0 新增)
       

      11、PHP 如何获取客户端的IP地址

      用$_SERVER获取的IP地址有什么问题?

      $_SERVER['REMOTE_ADDR'] ;   通过全局数组来获得 

      getenv('REMOTE_ADDR') ; 通过环境变量来获得

      当客户机使用代理的时候获取不到真实的IP地址

       

      12、写一个函数,可以遍历文件夹下的所有文件和文件夹。

      复制代码_www.wityx.com
       1     function get_dir_info($path){
       2           $handle = opendir($path);//打开目录返回句柄
       3           while(($content = readdir($handle))!== false){
       4                 $new_dir = $path . DIRECTORY_SEPARATOR . $content;
       5                 if($content == '..' || $content == '.'){
       6                        continue;
       7                 }
       8                 if(is_dir($new_dir)){
       9                       echo "
      目录:".$new_dir . '
      '; 10 get_dir_info($new_dir); 11 }else{ 12 echo "文件:".$path.':'.$content .'
      '; 13 } 14 } 15 } 16 get_dir_info($dir);
      复制代码_www.wityx.com

       

      13、有mail.log的一个文档,内容为若干邮件地址,用’\n’分隔换行。挑选sina.com的地址(包括从文件读取、过滤到列印出来)。

      思路1:用正则表达式(比较慢,效率地,不推荐用)

      思路2:cat mail.log | grep sina.com

       

      14、PHP缓存技术有哪些? tp是局部还是完全缓存?

      1. 全页面静态化缓存,也就是将页面全部生成html静态页面,用户访问时直接访问的静态页面,而不会去走php服务器解析的流程
      2. 页面部分缓存,将一个页面中不经常变的部分进行静态缓存,而经常变化的块不缓存,最后组装在一起显示
      3. 数据缓存,通过一个id进行请求的数据,将数据缓存到一个php文件中,id和文件是对应的,下次通过这个id进行请求时 直接读php文件
      4. 查询缓存,和数据缓存差不多,根据查询语句进行缓存;
      5. 常用的缓存技术有:redis和memcache
      个人认为tp应该是全局缓存 因为:tp缓存实在本地生成一个php文件来存储数据库中读取出来的数据
       

      15、strlen()与mb_strlen的作用与区别

      在PHP中,strlen与mb_strlen是求字符串长度的函数
      PHP内置的字符串长度函数strlen无法正确处理中文字符串,它得到的只是字符串所占的字节数。对于GB2312的中文编码,strlen得到的值是汉字个数的2倍,而对于UTF-8编码的中文,就是3倍(在 UTF-8编码下,一个汉字占3个字节)。
       
      采用mb_strlen函数可以较好地解决这个问题。mb_strlen的用法和strlen类似,只不过它有第二个可选参数用于指定字符编码。例如得到UTF-8的字符串 strmbstrlen(
      str,'UTF-8')。如果省略第二个参数,则会使用PHP的内部编码。内部编码可以通过 mb_internal_encoding()函数得到。

      需要注意的是,mb_strlen并不是PHP核心函数,使用前需要确保在php.ini中加载了php_mbstring.dll,即确保“extension=php_mbstring.dll”这一行存在并且没有被注释掉,否则会出现未定义函 数的问题。
       
      16、写一个函数,尽可能高效的从一个标准url中取出扩展名
       
      $arr = parse_url('http://www.sina.com.cn/abc/de/fg.php?id=1');
       
      result=pathinfo(
      arr['path']);var_dump($arr);
       
      var_dump($result['extension']);
       
      17、php.ini 中safe mod关闭 影响哪些函数和参数,至少写6个?
       
      move_uploaded_file()        exec()
      system()                              passthru()
      popen()                              fopen()
      mkdir()                               rmdir()
      rename()                            unlink()
      copy()                                 chgrp()
      chown()                              chmod()
      touch()                               symlink()
      link()                                   parse_ini_file()
      set_time_limit()                  max_execution_time mail()

       

      18、一群猴子排成一圈,按1,2,…,n依次编号。然后从第1只开始数,数到第m只,把它踢出圈,从它后面再开始数,再数到第m只,在把它踢出去…,如此不停 的进行下去,直到最后只剩下一只猴子为止,那只猴子就叫做大王。要求编程模拟此过程,输入m、n, 输出最后那个大王的编号。

      复制代码_www.wityx.com
       1 <?php
       2  function fuhuan($allnum, $ti){
       3      $arr = array();
       4      for($i = 0; $i < $allnum; $i++){
       5          $arr[$i] = $i;
       6      }
       7  
       8      $nums = 1;
       9      while(count($arr) > 1){
      10           foreach ($arr as $key => $value) {
      11               if($nums == $ti){
      12                   unset($arr[$key]);
      13                   $nums = 1;
      14               }else{
      15                   $nums++;
      16               }
      17          }
      18      }
      19      $new_arr = array_values($arr);
      20      var_dump($new_arr[0] + 1);
      21  }
      22  fuhuan(10,10);
      复制代码_www.wityx.com

       19、isset() 、empty()与is_null的区别

      1、当变量未定义时,is_null() 和“参数本身”是不允许作为参数判断的,会报Notice警告错误;

      2、empty , isset首先都会检查变量是否存在,然后对变量值进行检测。而is_null 和 “参数本身”只是直接检查变量值,是否为null,因此如果变量未定义就会出现错误!

      3、isset():仅当null和未定义,返回false;

      4、empty():""、0、"0"、NULL、FALSE、array(),未定义,均返回true;

      5、is_null():仅判断是否为null,未定义报警告;

      6、变量本身作为参数,与empty()一致,但接受未定义变量时,报警告;

       

      20、求两个文件的相对路径

      复制代码_www.wityx.com
       1  getpath('/a/b/c/d/e.php', '/a/d/12/34/c.php');
       2   
       3 public function getpath($a, $b)
       4 {
       5      $aarr = explode('/', $a);
       6      $barr = explode('/', $b);
       7      $count = count($barr) - 2;
       8      $pathinfo = '';
       9      for($i = 1; $i <= $count; $i++){
      10          if($aarr[$i] == $barr[$i]){
      11               $pathinfo .= '../';
      12          }else{
      13               $pathinfo .= $barr[$i] . '/';
      14          }
      15      }
      16      echo $pathinfo;
      17 }
      复制代码_www.wityx.com

       

      21、MVC的优缺点
      1、 MVC的优点 
              (1) 可以为一个模型在运行时同时建立和使用多个视图。变化-传播机制可以确保所有相关的视图及时得到模型数据变化,从而使所有关联的视图和控制器做到行为同步。 
              (2) 视图与控制器的可接插性,允许更换视图和控制器对象,而且可以根据需求动态的打开或关闭、甚至在运行期间进行对象替换。 
              (3) 模型的可移植性。因为模型是独立于视图的,所以可以把一个模型独立地移植到新的平台工作。需要做的只是在新平台上对视图和控制器进行新的修改。 
              (4) 潜在的框架结构。可以基于此模型建立应用程序框架,不仅仅是用在设计界面的设计中。 
      2、 MVC的不足之处 
              (1) 增加了系统结构和实现的复杂性。对于简单的界面,严格遵循MVC,使模型、视图与控制器分离,会增加结构的复杂性,并可能产生过多的更新操作,降低运行效率。 
              (2) 视图与控制器间的过于紧密的连接。视图与控制器是相互分离,但确实联系紧密的部件,视图没有控制器的存在,其应用是很有限的,反之亦然,这样就妨碍了他们的独立重用。 
              (3) 视图对模型数据的低效率访问。依据模型操作接口的不同,视图可能需要多次调用才能获得足够的显示数据。对未变化数据的不必要的频繁访问,也将损害操作性能。 
              (4) 目前,一般高级的界面工具或构造器不支持MVC模式。改造这些工具以适应MVC需要和建立分离的部件的代价是很高的,从而造成使用MVC的困难。 
       
       
      22、session与cookie的联系和区别(运行机制),session共享问题解决方案
      区别与联系:
          使用session_start()调用session,服务器端在生成session文件的同时生成session ID哈希值和默认值为PHPSESSID的session name,并向客户端发送变量为PHPSESSID(session name)(默认)值为一个128位的哈希值。服务器端将通过该cookie与客户端进行交互,session变量的值经php内部系列化后保存在服务器 机器上的文本文件中,和客户端的变量名默认情况下为PHPSESSID的coolie进行对应交互,即服务器自动发送了http 头:header(‘Set-Cookie: session_name()=session_id(); path=/’);即setcookie(session_name(),session_id());当从该页跳转到的新页面并调用 session_start()后,PHP将检查与给定ID相关联的服务器端存贮的session数据,如果没找到则新建一个数据集。
      共享方案:
      1:使用数据库保存session, 使用数据库来保存session,就算服务器宕机了也没事,session照样在。

      问题:程序需要定制;每次请求都进行数据库读写开销不小,另外数据库是一个单点,可以做数据库的hash来解 决这个问题。       

      2:使用 memcached来保存session, 这种方式跟数据库类似,内存存取性能比数据库好很多。

      问题:程序需要定制,增加 了工作量;存入memcached中的数据都需要序列化,效率较低,断电或者重启电脑容易丢失数据;

      3: 通过加密的cookie,在A服务器上登录,在用户的浏览器上添加加密的cookie,当用户访问B服务器时,检查有无Session,如果没有,就检验 Cookie是否有效,Cookie有效的话就在B服务器上重建session。简单,高效, 服务器的压力减小了,因为session数据不存在服务器磁盘上。根本就不会出现session读取不到的问题。

      问题:网络请求占用很多。每次请求时,客户端都要通过cookie发送session数据给服务器,session中数据不能太多,浏览器对cookie 的大

      小存在限制。不适合高访问量的情况,因为高访问量的情况下。

       

      23、 正则表达式

      匹配中文字符的正则表达式: [\u4e00-\u9fa5] 
      匹配双字节字符(包括汉字在内):[^\x00-\xff] 
      匹配空行的正则表达式:\n[\s| ]*\r 
      匹配HTML标记的正则表达式:/<(.*)>.*<\/\1>|<(.*) \/>/ 
      匹配首尾空格的正则表达式:(^\s*)|(\s*$) 
      匹配Email地址的正则表达式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)* 
      匹配网址URL的正则表达式:^[a-zA-z]+://(\\w+(-\\w+)*)(\\.(\\w+(-\\w+)*))*(\\?\\S*)?$ 
      匹配帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):^[a-zA-Z][a-zA-Z0-9_]{4,15}$ 
      匹配国内电话号码:(\d{3}-|\d{4}-)?(\d{8}|\d{7})? 
      匹配腾讯QQ号:^[1-9]*[1-9][0-9]*$ 

       

      24、写一个函数得到header头信息

      复制代码_www.wityx.com
      function getHeader()
      {
          $headers = [];
          if (function_exists('getallheaders')) {
              $headers = getallheaders();
          } elseif (function_exists('http_get_request_headers')) {
              $headers = http_get_request_headers();
          } else {
              foreach ($_SERVER as $key => $value) {
                  if(strstr($key, 'HTTP_')) {
                      $newk = ucwords(strtolower(str_replace('_', '-', substr($key, 5))));
                      $headers[$newk] = $value;
                  }
              }
          }
      
          var_dump($headers);
      }
      复制代码_www.wityx.com

      ------------------------mysql部分-----------------------

       1、select * from table where (ID = 10)  or (ID = 32) or (ID = 22)  让结果按10, 32, 22的顺序检索出来?

      Select *
      from user_info
      Where (ID IN (10, 32, 22))

      order BY FIND_IN_SET(ID, '10, 32, 22')

      ----------------------linux部分-----------------------

       1、core文件是什么,有什么用?

       core是unix系统的内核。当你的程序出现内存越界的时候,操作系统会中止你的进程,并将当前内存状态倒出到core文件中,以便进一步分析。程序员可以通过core文件来找出问题所在。它记录了程序挂掉时详细的状态描述。
      什么是core dump Core的意思是内存, Dump的意思是扔出来, 堆出来。开发和使用Unix程序时, 有时程序莫名其妙的down了, 却没有任何的提示(有时候会提示core dumped). 这时候可以查看一下有没有形如core.进程号的文件生成, 这个文件便是操作系统把程序down掉时的内存内容扔出来生成的,它可以做为调试程序的参考.
          core dump又叫核心转储, 当程序运行过程中发生异常, 程序异常退出时, 由操作系统把程序当前的内存状况存储在一个core文件中, 叫core dump。如何使用core文件 gdb -c core文件路径 [应用程序的路径],进去后输入where回车, 就可以显示程序在哪一行当掉的, 在哪个函数中.
      为什么没有core文件生成呢? core文件的生成跟你当前系统的环境设置有关系, 可以用下面的语句设置一下, 然后再运行程序便成生成core文件.
      ulimit -c unlimited core文件生成的位置一般于运行程序的路径相同, 文件名一般为core.进程号

      不用core文件,程序出了问题产生信号是否知道?答:内核向进程发信号嘛。

       

      2、共享内存除了文件映射还有什么方式?

      共享内存对象映射。

      二者有什么区别:

      答:内存映射文件是由一个文件到一块内存的映射,使应用程序可以通过内存指针对磁盘上的文件进行访问,其过程就如同对加载了文件的内存的访问,因此内存文件映射非常适合于用来管理大文件。

       

      3、请解释下列10个shell命令的用途
      top、ps、mv、find、df、cat、chmod、chgrp、grep、wc
      top:命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器。 
      ps:查看进程 
      mv:移动或者更改文件 
      find:在子目录中搜索匹配的文件 
      df:linux中df命令参数功能:检查文件系统的磁盘空间占用情况。

      cat:把一个或多个文件内容显示到标准输出 

      chmod:改变文件属性 

      chgrp:改变用户分组 

      grep:在文件内进行搜索 

      wc:命令的功能为统计指定文件中的字节数、字数、行数, 并将统计结果显示输出。

       

      4、Linux文件属性有哪些?(共十位)

      -rw-r--r--那个是权限符号,总共是- --- --- ---这几个位。

      第一个短横处是文件类型识别符:-表示普通文件;c表示字符设备(character);b表示块设备(block);d表示目录 (directory);l表示链接文件(link);后面第一个三个连续的短横是用户权限位(User),第二个三个连续短横是组权限位 (Group),第三个三个连续短横是其他权限位(Other)。每个权限位有三个权限,r(读权限),w(写权限),x(执行权限)。如果每个权限位都 有权限存在,那么满权限的情况就是:-rwxrwxrwx;权限为空的情况就是- --- --- ---。

      权限的设定可以用chmod命令,其格式位:chmod ugoa+/-/=rwx filename/directory。例如:

      一个文件aaa具有完全空的权限- --- --- ---。

      chmod u+rw aaa(给用户权限位设置读写权限,其权限表示为:- rw- --- ---)

      chmod g+r aaa(给组设置权限为可读,其权限表示为:- --- r-- ---)

      chmod ugo+rw aaa(给用户,组,其它用户或组设置权限为读写,权限表示为:- rw- rw- rw-)

      如果aaa具有满权限- rwx rwx rwx。

      chmod u-x aaa(去掉用户可执行权限,权限表示为:- rw- rwx rwx)

      如果要给aaa赋予制定权限- rwx r-x r-x,命令为:

      chmod u=rwx,Go=rx aaa

       
      5、linux查询命令
      1:find / -name "文件名"    在目录结构中搜索文件,并执行指定的操作。
       
      2:grep
       
      3:local 文件名  ---他是 'find -name' 的另一种写法,但要比后者快得多,原因在于它不搜索具体目录,而是搜索一个数据库(/var/lib/locatedb),这个数据库中含 有本地所有文件信息。Linux系统自动创建这个数据库,并且每天自动更新一次,所以改命令查不到最新变动过的文件。为了避免这种情况,可以在使用locate之前,先使用updatedb命令,手动更新数据库。
       
      4. whereis ---是定位可执行文件、源代码文件、帮助文件在文件系统中的位置。whereis命令只能用于程序名的搜索,而且只搜索二进制文件(参数-b)、man说明文件(参数-m)和源代码文件(参数-s)。如果省略参数,则返回所有信息。
       
      5:which  作用是在PATH变量指定的路径中,搜索某个系统命令的位置,并且返回第一个搜索结果。也就是说,使用which命令,就可以看到某个系统命令是否存在,以及执行的到底是哪一个位置的命令。

       -------------------服务器部分-------------------

       
      1、Apache与Nginx的优缺点比较 
      1、nginx相对于apache的优点: 
      轻量级,比apache 占用更少的内存及资源。高度模块化的设计,编写模块相对简单 
      抗并发,nginx 处理请求是异步非阻塞,多个连接(万级别)可以对应一个进程,而apache 则是阻塞型的,是同步多进程模型,一个连接对应一个进程,在高并发下nginx 能保持低资源低消耗高性能 
      nginx处理静态文件好,Nginx 静态处理性能比 Apache 高 3倍以上 

      2、apache 相对于nginx 的优点: 
      apache 的rewrite 比nginx 的rewrite 强大 ,模块非常多,基本想到的都可以找到 ,比较稳定,少bug ,nginx 的bug 相对较多 
       
      3:原因:这得益于Nginx使用了最新的epoll(Linux 2.6内核)和kqueue(freebsd)网络I/O模型,而Apache则使用的是传统的select模型。目前Linux下能够承受高并发访问的 Squid、Memcached都采用的是epoll网络I/O模型。 处理大量的连接的读写,Apache所采用的select网络I/O模型非常低效。
       
       
      2、cgi 与fastcgi的区别

      cgi在2000年或更早的时候用得比较多, 以前web服务器一般只处理静态的请求,web服务器会根据这次请求的内容,然后会fork一个新进程来运行外部c程序 (或perl脚本...), 这个进程会把处理完的数据返回给web服务器,最后web服务器把内容发送给用户,刚才fork的进程也随之退出。 如果下次用户还请求改动态脚本,那么web服务器又再次fork一个新进程,周而复始的进行。

      后来出现了一种更高级的方式是, web服务器可以内置perl解释器或php解释器。 也就是说这些解释器做成模块的方式,web服务器会在启动的时候就启动这些解释器。 当有新的动态请求进来时,web服务器就是自己解析这些perl或php脚本,省得重新fork一个进程,效率提高了。

      fastcgi的方式是,web服务器收到一个请求时,他不会重新fork一个进程(因为这个进程在web服务器启动时就开启了,而且不会退 出),web服务器直接把内容传递给这个进程(进程间通信,但fastcgi使用了别的方式,tcp方式通信),这个进程收到请求后进行处理,把结果返回 给web服务器,最后自己接着等待下一个请求的到来,而不是退出。 
      fastcgi跟cgi的区别是:
                        在web服务器方面                                                         在对数据进行处理的进程方面
      cgi
               fork一个新的进程进行处理                                           读取参数,处理数据,然后就结束生命期
      fastcgi   用tcp方式跟远程机子上的进程或本地进程建立连接       要开启tcp端口,进入循环,等待数据的到来,处理数据


      举个例子: 服务端现在有个10万个字单词, 客户每次会发来一个字符串,问以这个字符串为前缀的单词有多少个。 那么可以写一个程序,这个程序会建一棵trie树,然后每次用户请求过来时可以直接到这个trie去查找。 但是如果以cgi的方式的话,这次请求结束后这课trie也就没了,等下次再启动该进程时,又要新建一棵trie树,这样的效率就太低下了。   而用fastcgi的方式的话,这课trie树在进程启动时建立,以后就可以直接在trie树上查询指定的前缀了。

       

      3、select, poll和epoll的区别
      select

      select最早于1983年出现在4.2BSD中,它通过一个select()系统调用来监视多个文件描述符的数组,当select()返回后,该数组中就绪的文件描述符便会被内核修改标志位,使得进程可以获得这些文件描述符从而进行后续的读写操作。

      select目前几乎在所有的平台上支持,其良好跨平台支持也是它的一个优点,事实上从现在看来,这也是它所剩不多的优点之一。

      select的一个缺点在于单个进程能够监视的文件描述符的数量存在最大限制,在Linux上一般为1024,不过可以通过修改宏定义甚至重新编译内核的方式提升这一限制。

      另外,select()所维护的存储大量文件描述符的数据结构,随着文件描述符数量的增大,其复制的开销也线性增长。同时,由于网络响应时间的延迟 使得大量TCP连接处于非活跃状态,但调用select()会对所有socket进行一次线性扫描,所以这也浪费了一定的开销。

      poll

      poll在1986年诞生于System V Release 3,它和select在本质上没有多大差别,但是poll没有最大文件描述符数量的限制。 

      poll和select同样存在一个缺点就是,包含大量文件描述符的数组被整体复制于用户态和内核的地址空间之间,而不论这些文件描述符是否就绪,它的开销随着文件描述符数量的增加而线性增大。 

      另外,select()和poll()将就绪的文件描述符告诉进程后,如果进程没有对其进行IO操作,那么下次调用select()和poll() 的时候将再次报告这些文件描述符,所以它们一般不会丢失就绪的消息,这种方式称为水平触发(Level Triggered)。

      epoll

      直到Linux2.6才出现了由内核直接支持的实现方法,那就是epoll,它几乎具备了之前所说的一切优点,被公认为Linux2.6下性能最好的多路I/O就绪通知方法。

      epoll可以同时支持水平触发和边缘触发(Edge Triggered,只告诉进程哪些文件描述符刚刚变为就绪状态,它只说一遍,如果我们没有采取行动,那么它将不会再次告知,这种方式称为边缘触发),理论上边缘触发的性能要更高一些,但是代码实现相当复杂。

      epoll同样只告知那些就绪的文件描述符,而且当我们调用epoll_wait()获得就绪文件描述符时,返回的不是实际的描述符,而是一个代表 就绪描述符数量的值,你只需要去epoll指定的一个数组中依次取得相应数量的文件描述符即可,这里也使用了内存映射(mmap)技术,这样便彻底省掉了 这些文件描述符在系统调用时复制的开销。

      另一个本质的改进在于epoll采用基于事件的就绪通知方式。在select/poll中,进程只有在调用一定的方法后,内核才对所有监视的文件描 述符进行扫描,而epoll事先通过epoll_ctl()来注册一个文件描述符,一旦基于某个文件描述符就绪时,内核会采用类似callback的回调 机制,迅速激活这个文件描述符,当进程调用epoll_wait()时便得到通知。

       

      4、Memcache和Redis区别

      1. Redis中,并不是所有的数据都一直存储在内存中的,这是和Memcached相比一个最大的区别。
      2. Redis在很多方面具备数据库的特征,或者说就是一个数据库系统,而Memcached只是简单的K/V缓存。
      3. 他们的扩展都需要做集群;实现方式:master-slave、Hash。
      4. 在100k以上的数据中,Memcached性能要高于Redis。
      5. 如果要说内存使用效率,使用简单的key-value存储的话,Memcached的内存利用率更高,而如果Redis采用hash结构来做key-value存储,由于其组合式的压缩,其内存利用率会高于Memcached。当然,这和你的应用场景和数据特性有关。
      6. 如果你对数据持久化和数据同步有所要求,那么推荐你选择Redis,因为这两个特性Memcached都不具备。即使你只是希望在升级或者重启系统后缓存数据不会丢失,选择Redis也是明智的。
      7. Redis和Memcache在写入性能上面差别不大,读取性能上面尤其是批量读取性能上面Memcache更强
  2. 假设给你5台机器,请大致的描述一下,如何使用你所熟悉的开源软件,搭建一个日PV 3万左右的中型网站

           3台Web服务器,两台MySQL数据库服务器,采用Master/Slave同步的方式减轻数据库负载,Web服务器可以结合Memcahe缓存来减少负载,同时三台Web服
务器内容一致,可以采用DNS轮训的方式来进行负载平衡

     2.说说你所了解的搜索引擎包含那些技术?

      爬虫(采集)、切词(分词)、索引(存储)、查询以及其他相关技术

 

      3.使用过Memcache缓存吗,如果使用过,能够简单的描述一下它的工作原理吗?

       Memcahce是把所有的数据保存在内存当中,采用hash表的方式,

       每条数据又key和value组成,每个key是独一无二的,当要访问某个值的时候先按照找到
值,然后返回结果。

       Memcahce采用LRU算法来逐渐把过期数据清除掉。

  1. 平时喜欢哪些php书籍及博客?CSDN、虎嗅、猎云

  2. js闭包是什么,原型链了不了解?

  3. for与foreach哪个更快?

  4. php鸟哥是谁?能不能讲一下php执行原理?

  5. php加速器有哪些?apc、xcache.....能不能讲一下它的加速原理,与现在的O+有什么差别?

  6. Node.js能彻底代替php+apache 吗?

  7. 怎样判断一个值是否存在于数组中?in_array(),array_key_exists 哪一个更好

  8. 怎样判断select语句中是否使用了索引?explain 等的使用

  9. sphinx的中文分词词库使用第三方库还是自己建库?

  10. mysql与mysqli的区别有哪些?

  11. 将来的发展方向?安全、还是数据挖掘、大数据处理?

  12. php的面向对象:类的修饰符、封装、继承、多态等

  13. php的设计模式:单例模式、工厂模式、生产者模式......等23种

  14. 服务器状态码:200、202、301、404、500......

  15. i++++i++与++i的区别?

  16. 项目开发:电商项目中的购物车数据持久化、考试系统的安全性考虑、

  17. mysql设计基础:三大范式、功能->思维导图、创建表的第一字段是什么?

  18. mysql字段char、varchar、int、smallint、tinyint、mediumint、bigint、decimal、double、float字节数及应用场景

  19. mysql 数据类型有哪些 ? 分别占用多少存储空间 ?

  20. mysql 索引原理及sql性能优化

  21. memcache与mongoDB、Redis各自的使用场景是什么?

  22. 为什么mongoDB与Redis非但没有形成竞争反而是互补关系?

  23. Redis数据类型有哪些?int、string、hash、set、list ?

  24. 安装linux软件时使用make方式还使用yum方式?

  25. linux网络优化,如何查看进程、怎样查看最大文件打开数?

  26. 1条微薄要推送给100万个粉丝该怎么处理?

  27. 知道哪些算法?冒泡排序?快速排序?二分查找法?

  28. yii thinkphp ci 各自优点

  29. php 设计模式有哪些?单例模式的4个特性和实现原理

  30. C语言中的虚函数是什么?

  31. C排序算法有哪些?

  32. php 基本结构是什么?

  33. memcache magent 分布式设计?

  34. php的内存回收机制是什么?

  35. php在2011年底出现hash碰撞,hash碰撞原理为? 如何进行修复?

  36. 一个php文件的解释过程是? 一般加速php有哪些? 提高php整体性能会用到哪些技术?

  37. redis 分布式设计,如何设计?

  38. mongo 集群架构是怎样的?

  39. tcp/ip 网络协议,osi7层指是什么?

  40. php 处理大数据业务

  41. linux 应用,负载性能查看 ?

  42. nginx设置缓存js、css、图片等信息,缓存的实现原理是?

  43. nginx负载均衡有哪些? 如果其中一台服务器挂掉,报警机制如何实现?

  44. nginx 实战优化业务功能 ?

  45. 谈一下近三年来你的得意之作?

  46. 看看简历,会问一些过去做的项目的用户量、pv、吞吐量、相关难点和解决方法等

  47. 数据库设计经验,为什么进行分表? 分库?

  48. 一般多少数据量开始分表? 分库? 分库分表的目的? 什么是数据库垂直拆分? 水平拆分? 分区等等?可以举例说明

  49. 数据库优化有哪些? 分别需要注意什么?

  50. web开发方面会遇到哪些缓存? 分别如何优化?

  51. 给你256M的内存,对10G的文件进行排序(文件每行1个数字),如何实现?

  52. 对10G的文件进行查找如何实现?

  53. 统计10G文件每个关键字出现的次数如何实现?

  54. 假如你现在是12306火车订票的设计师,你该如何设计满足全国人民订票?

  55. 假如有1亿用户的访问量,你的服务器架构是怎样的? 用户信息的存储方案如何设计?

  56. 如果你是技术组长,所带团队任务进度无法完成你该如何解决?

  57. 如果在进度排满的前提下插入任务,你该如何保证总进度不延期?

  58. 如果有的工程师今天预定任务没有完成,你该如何解决?

  59. 从你的经验方面谈一下如何构建高性能web站点? 需要哪些环节? 步骤? 每个步骤需要注意什么如何优化等?

  60. 为什么要对数据库进行主从分离?

  61. 如何处理多服务器共享session?

  62. 一个10G的表,你用php程序统计某个字段出现的次数,思路是?

  63. 会告诉你一个nginx日志例子,用你认为最佳的编程语言统计一下http响应时间超过1秒的前10个url?

  64. 给你一个mysql配置文件,用你认为最佳的编程语言解析该文件?

  65. 给你两个路径a和b,写一个算法或思路计算a和b差距几层并显示a和b的交集?

  66. 给你一个url,在nginx配置一下rewrite指定到某个具体路径?

  67. session和cookie生存周期区别? 存储位置区别?

  68. require、include、require_once、include_once区别? 加载区别? 如果程序按需加载某个php文件你如何实现?

  69. chrome号称为多线程的,那么多线程和多进程的区别为?

  70. 如何提高缓存命中率? 如何对缓存进行颗粒化?

  71. web不安全因素有哪些? 分别如何防范?

  72. 假如两个单链表相交,写一个最优算法计算交点位置,说思路也可以?

  73. 假如你是技术组长? 如何提高团队效率?

  74. 不优化前提下,apache一般最大连接数为? nginx一般最大连接数为? mysql 每秒insert ? select ? update ? delete?

  75. 我的所有问题都问完了(当然没有这么多),你有什么问题问我没有?如果帮到了您,可以支持一下,谢谢您的支持!2017最新PHP面试题_第1张图片

你可能感兴趣的:(2017最新PHP面试题)