美文网首页互联网科技
100家名企中最常见的十五道PHP面试题

100家名企中最常见的十五道PHP面试题

作者: 再让你三行代码 | 来源:发表于2019-12-18 14:09 被阅读0次

    这些面试题是从黑马程序员社区中找到的,大部分是往届毕业生总结出来,其中不乏大厂的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。

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

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

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

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

    1)问的太笼统,生成静态 html 页面,squid 反向代理,apache,mysql 的负载均衡。
    2)可以采取数据缓存的方法,我们通常在统计数据的时候,需要在原始数据的基础上经过计算等一系列操作,才会得到最终的结果,如果每做一个查询都需要这样一系列操作,当数据量大时,势必会带来很多问题。可以建立一个结果表,写一个脚本,用 crontab 定时触发脚本去原始表取数据,计算,写入到结果表,前端查询从结果表取数据,这也是比较常用的一种做法。
    3)采用分布式,多个 apache,多个 mysql,其实就是 dns 负载均衡,dns 根据当前用户解析几个 ip 的 ping 值,将用户转移到某一台最快的服务器,或者平均分配。
    4)money 不是问题的话,可以考虑 F5 硬件负载均衡!
    5)可以使用 Microsoft Windows Server 系统的负载均衡设置

    13、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;
    用户输入文章时,通过选择下拉菜单选定文章分类
    写出如何实现这个下拉菜单

    14、PHP 文件操作

    上述内容管理系统:用户提交内容后,系统生成静态 HTML 页面;写出实现的基本思路 ob_start();

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

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

    var $empty        = '';
    var $null        = NULL;
    var $bool        = FALSE;
    var $notSet;        
    var $array        = array();
    

    5天玩转MySQL(视频网盘)
    5天玩转MySQL(资料网盘) 密码:mkqu

    相关文章

      网友评论

        本文标题:100家名企中最常见的十五道PHP面试题

        本文链接:https://www.haomeiwen.com/subject/lxqunctx.html