天天看點

2020最新PHP面試100題(番外篇)

1、Parse error: syntax error, unexpected T_STRING in /website/index.php on line 18

18行文法錯誤,檢查文法

2、Warning:fopen(welcome.txt) [function.fopen]: failed to open stream: No such file or directory in /website/index.php on line 2

沒有找到welcome.txt檔案,檢查檔案是否存在

點選加入我的企鵝群

3、用PHP列印出前一天的時間,列印格式是2007年5月10日22:21:21

4、javascript能否定義二維數組,如果不能你如何解決?

javascript不支援二維數組定義,可以用arr[0] = new array()來解決

5、假設a.html和b.html在同一個檔案夾下面,用javascript實作當打開a.html五秒鐘後,自動跳轉到b.html。

<script>
function go2b(){
 window.location = “b.html”;
 window.close();
}
setTimeout( “go2b()”,5000 ); //5秒鐘後自動執行go2b()
</script>

//正在浏覽目前頁面使用者的 IP 位址:127.0.0.1
echo $_SERVER["REMOTE_ADDR"].”<br />”;
//查詢(query)的字元串(URL 中第一個問号 ? 之後的内容):id=1&bi=2
echo $_SERVER["QUERY_STRING"].”<br />”;
//目前運作腳本所在的文檔根目錄:d:inetpubwwwroot
echo $_SERVER["DOCUMENT_ROOT"].”<br />”;
           

6、在HTTP 1.0中,狀态碼 401 的含義是未授權____;如果傳回“找不到檔案”的提示,則可用 header 函數,其語句為header(“HTTP/1.0 404 Not Found”);

401表示未授權;header(“HTTP/1.0 404 Not Found”);

7、把 John 新增到 users 陣列?

8、在PHP中error_reporting這個函數有什麼作用?

error_reporting() 設定 PHP 的報錯級别并傳回目前級别。

9、如何修改SESSION的生存時間(1分).

方法1:将php.ini中的session.gc_maxlifetime設定為9999重新開機apache

方法2:$savePath = “./session_save_dir/”;

$lifeTime = 小時 * 秒;

session_save_path($savePath);
session_set_cookie_params($lifeTime);
session_start();
           

方法3:

10、有一個網頁位址, 比如PHP開發資源網首頁: http://www.phpres.com/index.html,如何得到它的内容?($1分)

方法1(對于PHP5及更高版本):

$readcontents = fopen(“http://www.phpres.com/index.html”, “rb”);
$contents = stream_get_contents($readcontents);
fclose($readcontents);
echo $contents;
           

方法2:

11、寫一個函數,盡可能高效的,從一個标準 url 裡取出檔案的擴充名

例如: http://www.sina.com.cn/abc/de/fg.php?id=1 需要取出 php 或 .php

答案1:

function getExt($url){
$arr = parse_url($url);
$file = basename($arr['path']);
$ext = explode(“.”,$file);
return $ext[1];
}
           

答案2:

function getExt($url) {
$url = basename($url);
$pos1 = strpos($url,”.”);
$pos2 = strpos($url,”?”);
if(strstr($url,”?”)){
Return substr($url,$pos1 + 1,$pos2 – $pos1 – 1);
} else {
return substr($url,$pos1);
}
}
           

12、使用五種以上方式擷取一個檔案的擴充名

要求:dir/upload.image.jpg,找出 .jpg 或者 jpg ,

必須使用PHP自帶的處理函數進行處理,方法不能明顯重複,可以封裝成函數 get_ext1( f i l e n a m e ) , g e t e x t 2 ( file_name), get_ext2( filen​ame),gete​xt2(file_name)

function get_ext1($file_name){
return strrchr($file_name, ‘.’);
}
function get_ext2($file_name){
return substr($file_name,strrpos($file_name, ‘.’));
}
function get_ext3($file_name){
return array_pop(explode(‘.’, $file_name));
}
function get_ext4($file_name){
$p = pathinfo($file_name);
return $p['extension'];
}
function get_ext5($file_name){
return strrev(substr(strrev($file_name), 0, strpos(strrev($file_name), ‘.’)));
}
           

13、

$str1 = null;
$str2 = false;
echo $str1==$str2 ? ‘相等’ : ‘不相等’;
$str3 = ”;
$str4 = 0;
echo $str3==$str4 ? ‘相等’ : ‘不相等’;
$str5 = 0;
$str6 = ’0′;
echo $str5===$str6 ? ‘相等’ : ‘不相等’;
?>
           

答:相等 相等 不相等

14、MySQL資料庫中的字段類型varchar和char的主要差別是什麼?那種字段的查找效率要高,為什麼?

Varchar是變長,節省存儲空間,char是固定長度。查找效率要varchar型快,因為varchar是非定長,必須先查找長度,然後進行資料的提取,比char定長類型多了一個步驟,是以效率低一些

15、請使用JavaScript寫出三種産生一個Image 标簽的方法(提示:從方法、對象、HTML角度考慮)

(1)var img = new Image();

(2)var img = document.createElement(“image”)

(3)img.innerHTML = “”

16、請描述出兩點以上XHTML和HTML最顯著的差別

(1)XHTML必須強制指定文檔類型DocType,HTML不需要

(2)XHTML所有标簽必須閉合,HTML比較随意

17、寫出三種以上MySQL資料庫存儲引擎的名稱(提示:不區分大小寫)

MyISAM、InnoDB、BDB(Berkeley DB)、Merge、Memory(Heap)、Example、Federated、Archive、CSV、Blackhole、MaxDB 等等十幾個引擎

18、求兩個日期的差數,例如2007-2-5 ~ 2007-3-6 的日期差數

方法一:

<?php
class Dtime{
 function get_days($date1, $date2){
  $time1 = strtotime($date1);
  $time2 = strtotime($date2);
  return ($time2-$time1)/86400;
 }
}
$Dtime = new Dtime;
echo $Dtime->get_days(’2007-2-5′, ’2007-3-6′);
?>
           

方法二:

<?php
$temp = explode(‘-’, ’2007-2-5′);
$time1 = mktime(0, 0, 0, $temp[1], $temp[2], $temp[0]);
$temp = explode(‘-’, ’2007-3-6′);
$time2 = mktime(0, 0, 0, $temp[1], $temp[2], $temp[0]);
echo ($time2-$time1)/86400;
           

方法三:echo abs(strtotime(“2007-2-1″)-strtotime(“2007-3-1″))/60/60/24 計算時間差

19/請寫一個函數,實作以下功能:

字元串“open_door” 轉換成 “OpenDoor”、”make_by_id” 轉換成 ”MakeById”。

方法:

function str_explode($str){
$str_arr=explode(“_”,$str);$str_implode=implode(” “,$str_arr); $str_implode=implode
(“”,explode(” “,ucwords($str_implode)));
return $str_implode;
}
$strexplode=str_explode(“make_by_id”);print_r($strexplode);
           

方法二:

$str=”make_by_id!”;
$expStr=explode(“_”,$str);
for($i=0;$i
echo ucwords($expStr[$i]);
}
           

方法三:echo str_replace(‘ ‘,”,ucwords(str_replace(‘_’,’ ‘,’open_door’)));

20、一個表中的Id有多個記錄,把所有這個id的記錄查出來,并顯示共有多少條記錄數,用SQL語句及視圖、存儲過程分别實作。

DELIMITER //
create procedure proc_countNum(in columnId int,out rowsNo int)
begin
select count(*) into rowsNo from member where member_id=columnId;
end
call proc_countNum(1,@no);
select @no;
           

方法:視圖:

create view v_countNum as select member_id,count(*) as countNum from member group by
member_id
select countNum from v_countNum where member_id=1
           

js中網頁前進和後退的代碼

前進: history.forward();=history.go(1);

後退: history.back();=history.go(-1);

echo count(“abc”); 輸出什麼?

答案:1

count — 計算數組中的單元數目或對象中的屬性個數

int count ( mixed$var [, int $mode ] ), 如果 var 不是數組類型或者實作了 Countable 接口的對象,将傳回1,有一個例外,如果 var 是 NULL 則結果是 0。

對于對象,如果安裝了 SPL,可以通過實作 Countable 接口來調用 count()。該接口隻有一個方法 count(),此方法傳回 count() 函數的傳回值。

21、有一個一維數組,裡面存儲整形資料,請寫一個函數,将他們按從大到小的順序排列。要求執行效率高。并說明如何改善執行效率。(該函數必須自己實作,不能使用php函數)

function BubbleSort(&$arr){
 $cnt=count($arr);
 $flag=1;
 for($i=0;$i<$cnt;$i++){
 if($flag==0){
  return;
 }
 $flag=0;
 for($j=0;$j<$cnt-$i-1;$j++){
  if($arr[$j]>$arr[$j+1]){
   $tmp=$arr[$j];
   $arr[$j]=$arr[$j+1];
   $arr[$j+1]=$tmp;
   $flag=1;
  }
 }
 }
}
$test=array(1,3,6,8,2,7);
BubbleSort($test);
var_dump($test);
           

22、請舉例說明在你的開發過程中用什麼方法來加快頁面的加載速度

要用到伺服器資源時才打開,及時關閉伺服器資源,資料庫添加索引,頁面可生成靜态,圖檔等大檔案單獨伺服器。使用代碼優化工具。

23、.以下的代碼會産生什麼?為什麼?

$num =10;
function multiply(){
$num =$num *10;
}
multiply();
echo $num;
           

由于函式 multiply() 沒有指定 $num 為全域變量(例如 global $num 或者 $_GLOBALS[‘num’]),是以 $num 的值是 10。

24、HTTP協定中GET、POST和HEAD的差別?

HEAD: 隻請求頁面的首部。

GET: 請求指定的頁面資訊,并傳回實體主體。

POST: 請求伺服器接受所指定的文檔作為對所辨別的URI的新的從屬實體。

(1)HTTP 定義了與伺服器互動的不同方法,最基本的方法是 GET 和 POST。事實上 GET 适用于多數請求,而保留 POST 僅用于更新站點。

(2)在FORM送出的時候,如果不指定Method,則預設為GET請 求,Form中送出的資料将會附加在url之後,以?分開與url分開。字母數字字元原樣發送,但空格轉換為“+“号,其它符号轉換為%XX,其中XX為 該符号以16進制表示的ASCII(或ISO Latin-1)值。GET請求請送出的資料放置在HTTP請求協定頭中,而POST送出的資料則放在實體資料中;

GET方式送出的資料最多隻能有1024位元組,而POST則沒有此限制。

(3)GET 這個是浏覽器用語向伺服器請求最常用的方法。POST這個方法也是用來傳送資料的,但是與GET不同的是,使用POST的時候,資料不是附在URI後面傳遞的,而是要做為獨立的行來傳遞,此時還必須要發送一個Content_length标題,以标明資料長度,随後一個空白行,然後就是實際傳送的資料。網頁的表單通常是用POST來傳送的。

點關注,不迷路

好了各位,以上就是這篇文章的全部内容了,能看到這裡的人呀,都是人才。之前說過,PHP方面的技術點很多,也是因為太多了,實在是寫不過來,寫過來了大家也不會看的太多,是以我這裡把它整理成了PDF和文檔,如果有需要的可以

點選進入暗号: PHP+「平台」

2020最新PHP面試100題(番外篇)
2020最新PHP面試100題(番外篇)

更多學習内容可以通路【對标大廠】精品PHP架構師教程目錄大全,隻要你能看完保證薪資上升一個台階(持續更新)

以上内容希望幫助到大家,很多PHPer在進階的時候總會遇到一些問題和瓶頸,業務代碼寫多了沒有方向感,不知道該從那裡入手去提升,對此我整理了一些資料,包括但不限于:分布式架構、高可擴充、高性能、高并發、伺服器性能調優、TP6,laravel,YII2,Redis,Swoole、Swoft、Kafka、Mysql優化、shell腳本、Docker、微服務、Nginx等多個知識點進階進階幹貨需要的可以免費分享給大家,需要的可以加入我的 PHP技術交流群