閱讀屋>面試> php初級面試題

php初級面試題

php初級面試題

一. 基本知識點

1.1 HTTP協議中幾個狀態碼的含義:503 500 401 403 404 200 301 302。。。

200 : 請求成功,請求的資料隨之返回。

301 : 永久性重定向。

302 : 暫時行重定向。

401 : 當前請求需要使用者驗證。

403 : 伺服器拒絕執行請求,即沒有許可權。

404 : 請求失敗,請求的資料在伺服器上未發現。

500 : 伺服器錯誤。一般伺服器端程式執行錯誤。

503 : 伺服器臨時維護或過載。這個狀態時臨時性的。

1.2 Include require include_once require_once 的區別.

處理失敗方式不同:

require 失敗時會產生一個致命級別錯誤,並停止程式執行。

include 失敗時只產生一個警告級別錯誤,程式繼續執行。

include_once/require_once和include/require 處理錯誤方式一樣,

唯一區別在於當所包含的檔案程式碼已經存在時候,不在包含。

1.3 (mysql)請寫出資料型別(int char varchar datetime text)的意思; 請問varchar和char有什麼區別;

int : 數值型別

char : 固定長度字串型別

varchar : 可變長度字串型別

datetime : 時期時間型別

text : 文字型別

varchar和char有什麼區別:

a. char 長度是固定的,不管你儲存的資料是多少他都會都固定的長度。

而varchar則處可變長度但他要在總長度上加1字元,這個用來儲存位置。

b. char 固定長度,所以在處理速度上要比varchar快速很多,但是浪費儲存空間,

所以對儲存不大,但在速度上有要求的可以使用char型別,反之可以用varchar型別來例項。

1.4 error_reporting 等除錯函式使用

error_reporting() 函式能夠在執行時設定php.ini中 error_reporting 指令。

所以可以再程式中隨時調節顯示的錯誤級別。

使用此函式時 display_errors必須是開啟狀態。

1.5 寫程式碼來解決多程序/執行緒同時讀寫一個檔案的'問題。

PHP是不支援多執行緒的,可以使用php的flock加鎖函式實現。

$fp = fopen("/tmp/lock.txt", "w+");

if (flock($fp, LOCK_EX)) { // 進行排它型鎖定

fwrite($fp, "Write something here ");

flock($fp, LOCK_UN); // 釋放鎖定

} else {

echo "Couldn't lock the file !";

}

fclose($fp);

1.6 寫一段上傳檔案的程式碼。

upload.html



Send this file:



upload.php

$uploads_dir = '/uploads';

foreach ($_FILES["error"] as $key => $error) {

if ($error == UPLOAD_ERR_OK) {

$tmp_name = $_FILES["tmp_name"][$key];

$name = $_FILES["name"][$key];

move_uploaded_file($tmp_name, "$uploads_dir/$name");

}

}

1.7 Mysql 的儲存引擎,myisam和innodb的區別。

a. MyISAM型別不支援事務處理等高階處理,而InnoDB型別支援.

b. MyISAM型別的表強調的是效能,其執行數度比InnoDB型別更快.

c. InnoDB不支援FULLTEXT型別的索引.

d. InnoDB 中不儲存表的具體行數,也就是說,

執行select count(*) from table時,InnoDB要掃描一遍整個表來計算有多少行,

但是MyISAM只要簡單的讀出儲存好的行數即可.

e. 對於AUTO_INCREMENT型別的欄位,InnoDB中必須包含只有該欄位的索引,但是在MyISAM表中,可以和其他欄位一起建立聯合索引。

f. DELETE FROM table時,InnoDB不會重新建立表,而是一行一行的刪除。

g. LOAD TABLE FROM MASTER操作對InnoDB是不起作用的,解決方法是首先把InnoDB表改成MyISAM表,匯入資料後再改成InnoDB表,

但是對於使用的額外的InnoDB特性(例如外來鍵)的表不適用.

h. MyISAM支援表鎖,InnoDB支援行鎖。

二. web 架構,安全,專案經驗

2.1 MySQL資料庫作釋出系統的儲存,一天五萬條以上的增量,預計運維三年,怎麼最佳化?

a. 設計良好的資料庫結構,允許部分資料冗餘,儘量避免join查詢,提高效率。

b. 選擇合適的表字段資料型別和儲存引擎,適當的新增索引。

c. mysql庫主從讀寫分離。

d. 找規律分表,減少單表中的資料量提高查詢速度。

e。新增快取機制,比如memcached,apc等。

f. 不經常改動的頁面,生成靜態頁面。

g. 書寫高效率的SQL。比如 SELECT * FROM TABEL 改為 SELECT field_1, field_2, field_3 FROM TABLE.

2.2 對於大流量的網站,您採用什麼樣的方法來解決各頁面訪問量統計問題

a. 確認伺服器是否能支撐當前訪問量。

b. 最佳化資料庫訪問。參考2.3

c. 禁止外部訪問連結(盜鏈), 比如圖片盜鏈。

d. 控制檔案下載。

e. 使用不同主機分流。

f. 使用瀏覽統計軟體,瞭解訪問量,有針對性的進行最佳化。

2.3 寫出一個正則表示式,過慮網頁上的所有JS/VBS指令碼(即把標記及其內容都去掉):(9)。

答:/<[^>].*?>.*?</>/si

2.4 用PHP打印出前一天的時間格式是2006-5-10 22:21:21

答:echo date('Y-m-d H:i:s', strtotime('-1 day'));

2.5 echo(),print(),print_r()的區別

答:echo是語言結構,無返回值;print功能和echo基本相同,不同的是print是函式,有返回值;print_r是遞迴列印,用於輸出陣列物件

2.6 如何實現字串翻轉?

答:.用strrev函式唄,不準用PHP內建的就自己寫:

[php] view plaincopy

strrev($str)

{

$len=strlen($str);

$newstr = '';

for($i=$len;$i>=0;$i--)

{

$newstr .= $str{$i};

}

return $newstr;

}

2.7 實現中文字串擷取無亂碼的方法。

答:mb_substr()

2.8 如何用php的環境變數得到一個網頁地址的內容?ip地址又要怎樣得到?

答:$_SERVSR[‘REQUEST_URI’] , $_SERVER[‘REMOTE_ADDR’]

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

答:(strtotime(‘2007-3-6’)-strtotime(‘2007-2-5’))/3600*24

2.10 如何透過javascript判斷一個視窗是否已經被遮蔽

答:獲取open()的返回值,如果是null,就是遮蔽了


【php初級面試題】相關文章: