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() 函數能夠在運行時設置中 error_reporting 指令。
所以可以再程序中隨時調節顯示的錯誤級別。
使用此函數時 display_errors必須是打開狀態。
1.5 寫代碼來解決多進程/線程同時讀寫一個文件的問題。
PHP是不支持多線程的,可以使用php的flock加鎖函數實現。
$fp = fopen("/tmp/", "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 寫一段上傳文件的代碼。
$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,就是屏蔽了
-
面試自我評價精選13篇
無論在學習、工作或是生活中,許多人都需要寫自我評價,自我評價會促使我們進行自我驗證,從而爲自我發展提供動力。相信很多朋友都對寫自我評價感到非常苦惱吧,以下是小編爲大家整理的面試自我評價,歡迎大家分享。面試自我評價1在讀書期間,我已經做過暑期工,是向用餐的...
-
面試自我評價(精選15篇)
在平凡的學習、工作、生活中,我們最不陌生的就是自我評價了,自我評價和人生價值選擇有着密切的關係。相信很多朋友都對寫自我評價感到非常苦惱吧,下面是小編收集整理的面試自我評價,歡迎閱讀,希望大家能夠喜歡。面試自我評價1我是一個比較謙虛好學的人,態度用心主動,...
-
面試需注意哪些禮儀
面試需注意哪些禮儀1(1)進門時要表現得自然,不要緊張或慌張;(2)面試時要始終面帶笑容,謙恭和氣。表現出熱情、開朗、大方、樂觀的精神狀態;(3)不要無緣無故皺眉頭或毫無表情;(4)不要直盯對方,也不要以眼瞟人、漫不經心,眼光宜落在主考人的鼻子上爲佳,這樣既保持了接觸...
-
銷售面試介紹
銷售面試介紹1大家下午好!我是來自邕江大學金融營銷專業的。我喜歡讀書看報,因爲它能豐富我的知識;我喜歡跑步,因爲它可以磨礪我的意志,我到底是個什麼樣的人呢?我是一個活潑開朗、熱情、執着、有堅強意志的人。既然今天競聘的是營銷經理一職,我想談談自己對營銷的理...