PHP面试题(1)

  • 第一题

写一个php脚本,抓取页面http://php.net/manual/en/langref.php右侧的目录列表.运行此脚本期望得到如下输出:

    [2016-12-17 13:44:30] fetching http://php.net/manual/en/langref.php
    [2016-12-17 13:44:31] parsing start
    [2016-12-17 13:44:32] the right side list is:
    PHP Manual (http://php.net/manual/en/index.php)
    Copyright (http://php.net/manual/en/copyright.php)
    PHP Manual (http://php.net/manual/en/manual.php)
    Getting Started (http://php.net/manual/en/getting-started.php)
    Installation and Configuration (http://php.net/manual/en/install.php)
    Language Reference (http://php.net/manual/en/langref.php)
    Security (http://php.net/manual/en/security.php)
    Features (http://php.net/manual/en/Features)
    Function Reference (http://php.net/manual/en/funcref.php)
    PHP at the Core: A Hacker's Guide (http://php.net/manual/en/internals2.php)
    FAQ (http://php.net/manual/en/faq.php)
    Appendices (http://php.net/manual/en/appendices.php)
    [2016-12-17 13:44:33] parsing end
    [2016-12-17 13:44:34] saving to file langref.txt
    [2016-12-17 13:44:35] saved

作者:何广宇

链接:https://www.zhihu.com/question/19757909/answer/13621166

来源:知乎

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

  • 答:

代码如下:

    <?php
    function request($config)
    {
        if (empty($config['url'])) {
            return false;
        }
    
        $ch = curl_init($config['url']);
        curl_setopt($ch, CURLOPT_HEADER, 0);
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
        if (!empty($config['https'])) {
            curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0);
            curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0);
        }
        if (!empty($config['method']) && 'post' == $config['method']) {
            curl_setopt($ch, CURLOPT_POST, 1);
            curl_setopt($ch, CURLOPT_POSTFIELDS, $config['postfields']);
        }
        $msg   = curl_exec($ch);
        $error = curl_error($ch);
        if (!empty($error)) {
            $msg = curl_errno($ch) . ': ' . $error;
        }
        curl_close($ch);
        return $msg;
    }
    $config['url'] = 'http://php.net/manual/en/langref.php';
    $str           = request(array('url' => 'http://php.net/manual/en/langref.php'));
    $reg           = '/<ul class=\'parent-menu-list\'>([\s\S]*?)<\/ul>/';
    preg_match($reg, $str, $liStr);
    $liStr = $liStr[1];
    $reg   = '/<a href="(.*?)".*?>(.*?)<\/a>/';
    preg_match_all($reg, $liStr, $finalStr);
    $str = '[' . date('Y-m-d H:i:s') . '] fetching ' . $config['url'] . PHP_EOL;
    echo '[' . date('Y-m-d H:i:s') . '] fetching ' . $config['url'] . '<br>';
    sleep(1);
    $str .= '[' . date('Y-m-d H:i:s') . '] parsing start' . PHP_EOL;
    echo '[' . date('Y-m-d H:i:s') . '] parsing start<br>';
    sleep(1);
    $str .= '[' . date('Y-m-d H:i:s') . '] the right side list is:' . PHP_EOL;
    echo '[' . date('Y-m-d H:i:s') . '] the right side list is:<br>';
    foreach ($finalStr[1] as $key => $value) {
        $str .= $finalStr[2][$key] . '(http://php.net/manual/en/' . $value . ')' . PHP_EOL;
        echo $finalStr[2][$key] . '(http://php.net/manual/en/' . $value . ')<br>';
    }
    sleep(1);
    $str .= '[' . date('Y-m-d H:i:s') . '] parsing end' . PHP_EOL;
    echo '[' . date('Y-m-d H:i:s') . '] parsing end<br>';
    sleep(1);
    $str .= '[' . date('Y-m-d H:i:s') . '] saving to file langref.txt' . PHP_EOL;
    echo '[' . date('Y-m-d H:i:s') . '] saving to file langref.txt<br>';
    file_put_contents('langref.txt', $str);
    sleep(1);
    echo '[' . date('Y-m-d H:i:s') . '] saved<br>';
    file_put_contents('langref.txt', '[' . date('Y-m-d H:i:s') . '] saved' . PHP_EOL, FILE_APPEND);
  • 第二题

创建一个数据库php_manual,新建表index,这个表有3个字段: id, title, link.
然后创建一个数据库用户php_manual_user,密码是php_manual_pass.
把上述数据库导出成sql,把SQL语句贴到下面,使得我们在mysql命令行终端里执行这些sql语句可以完成上述操作.

作者:何广宇

链接:https://www.zhihu.com/question/19757909/answer/13621166

来源:知乎

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

  • 答:

代码如下:

#  前提是已经以root权限登录
#  删除原来已经存在同名数据库
drop database if exists `php_manual`;
#  创建数据库
create database `php_manual`;
#  选择需要操作的数据库
use `php_manual`;
#  删除原来已经存在的同名数据表
drop table if exists `index`;
# 创建数据表
create table `index` (
    id int unsigned auto_increment primary key,
    title varchar(255) not null,
    link varchar(255) not null
)engine=InnoDB auto_increment=1 default charset=utf8;
#  创建用户名密码
create user `php_manual_user`@'%' identified by 'php_manual_pass';
# 退出命令行模式
exit;
# 命令行下执行以下命令导出数据库
mysqldump -uphp_manual_user -pphp_manual_pass php_manual > D:/php_manual.sql
  • 第三题

写一个php脚本,读取第1题的结果langref.txt并解析出title和link,插入第2题创建的数据库表index里.

作者:何广宇

链接:https://www.zhihu.com/question/19757909/answer/13621166

来源:知乎

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

  • 答:

代码如下:

  <?php
        //  从文件读取
        $title = $link = array();
        $fp    = fopen('langref.txt', 'r');
        while ($line = fgets($fp)) {
            if (strpos($line, ']')) {
                continue;
            }
            $strArr    = explode('(', $line);
            $title[]   = $strArr[0];
            $strArr[1] = trim($strArr[1]);
            $link[]    = str_replace(')', '', $strArr[1]);
        }
        fclose($fp);
        //  入库
        $conn = new mysqli('127.0.0.1', 'php_manual_user', 'php_manual_pass', 'php_manual');
        if ($conn->connect_error) {
            die('Error:' . $conn->connect_error);
        }
        foreach ($title as $key => $value) {
            $sql = 'INSERT INTO `index` (title, link) VALUES ("' . $value . '", "' . $link[$key] . '")';
            echo $sql;
            if (true === $conn->query($sql)) {
                echo 'Insert ' . $key . 'line successful<br>';
            } else {
                die('Cannot insert the data to mysql' . $conn->connect_error);
            }
        }
        $conn->close();
  • 第四题

使用jQuery写一个function来解析langref.php右侧的目录列表,运行这个function返回如下一个object.

作者:何广宇

链接:https://www.zhihu.com/question/19757909/answer/13621166

来源:知乎

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

{
    "Copyright": "http://php.net/manual/en/copyright.php",
    "PHP Manual": "http://php.net/manual/en/manual.php",
    "Getting Started": "http://php.net/manual/en/getting-started.php",
    "Installation and Configuration": "http://php.net/manual/en/install.php",
    "Language Reference": "http://php.net/manual/en/langref.php",
    "Security": "http://php.net/manual/en/security.php",
    "Features": "http://php.net/manual/en/Features",
    "Function Reference": "http://php.net/manual/en/funcref.php",
    "PHP at the Core: A Hacker's Guide": "http://php.net/manual/en/internals2.php",
    "FAQ": "http://php.net/manual/en/faq.php",
    "Appendices": "http://php.net/manual/en/appendices.php"
}
  • 答:

  • 第五题

写一条shell命令,执行此命令可获取到http://php.net/manual/en/langref.php的内容并将页面里的所有大写的PHP转成小写,最后将结果保存到/tmp/langref.html里.

作者:何广宇

链接:https://www.zhihu.com/question/19757909/answer/13621166

来源:知乎

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

  • 答:

  • 第六题:

(加分题) 改写下边的脚本,使得当接收到SIGINT信号时打印出"caught signal SIGINT, exit"并退出.

<?php
    while (1) {
        echo "\n\n";
        echo "I am doing something important\n";
        echo "if i am interruptted, the data will be corrupted\n";
        echo "be careful\n";
        echo "\n\n";
        sleep(3);
    }

作者:何广宇

链接:https://www.zhihu.com/question/19757909/answer/13621166

来源:知乎

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

  • 答:

  • 第七题:

(加分题) 有一个超级大的int数组要求和,假设有1000W,写一个php脚本,根据当前机器(假设是多核的)cpu的核数,fork出这么多子进程,把数组平分,每个子进程计算其中一部分,并把结果保存到/tmp/子进程pid.txt.
最后父进程汇总并输出求各结果.

作者:何广宇

链接:https://www.zhihu.com/question/19757909/answer/13621166

来源:知乎

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

  • 答:
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,670评论 5 460
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,928评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,926评论 0 320
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,238评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,112评论 4 356
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,138评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,545评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,232评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,496评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,596评论 2 310
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,369评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,226评论 3 313
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,600评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,906评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,185评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,516评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,721评论 2 335

推荐阅读更多精彩内容

  • 个人知乎收藏系列(4) 1.李燃末的回答## 看到这个问题竟然有些莫名的心酸。看了几个回答也有些隐隐的愤怒。 大学...
    独孤星夜的孤独等待阅读 5,187评论 0 23
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,067评论 25 707
  • 十八年来,经历了大大小小五花八门的失望。不算多,也少有彻底。 今天经历了一场迄今为止最深沉的失望。我是不想说出来的...
    远极独游阅读 100评论 0 0
  • 你突然的出现我没有防备 你是谁的骑士欲做谁护卫 心里要相遇或者与谁作对 全部放到一边而选择颓废 想问问对不对悔不悔...
    青菜萝卜豆腐汤阅读 357评论 2 0
  • 每个人。。。都有自己的一段过往,你永远不知道他的底线在哪里,他的容忍度有多大。若你无意触及那块伤疤,狠狠的揭下来,...
    夕年丶阅读 170评论 0 1