這些是我從網路上整理出來的面試題,希望在今後大家出去面試時,會有所幫助。
一.基本知識點
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\n");
flock($fp, LOCK_UN); // 釋放鎖定
} else {
echo "Couldn't lock the file !";
}
fclose($fp);
#1.6 寫一段上傳檔案的程式碼。
upload.html
#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腳本(即把標記及其內容都去掉):
答:/].*?>.*?/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 實作中文字串截取無亂碼的方法
#答:mb_substr()
2.7 如何用php的環境變數得到一個網頁位址的內容? ip位址又要怎麼得到?
答案:$_SERVSR['REQUEST_URI'] , $_SERVER['REMOTE_ADDR']
2.8 求兩個日期的差數,例如2007-2-5 ~ 2007-3-6 的日期差數
答案:(strtotime('2007-3-6')-strtotime('2007-2-5'))/3600*24
2.9 如何透過javascript判斷一個視窗是否已經被屏蔽
回答:取得open()的回傳值,如果是null,就是屏蔽了
以上是我在網路上整理出來的PHP面試題,希望未來大家出去找工作會對大家有幫助。
相關文章:
以上是PHP常見的面試題的詳細內容。更多資訊請關注PHP中文網其他相關文章!

要保護應用免受與會話相關的XSS攻擊,需採取以下措施:1.設置HttpOnly和Secure標誌保護會話cookie。 2.對所有用戶輸入進行輸出編碼。 3.實施內容安全策略(CSP)限制腳本來源。通過這些策略,可以有效防護會話相關的XSS攻擊,確保用戶數據安全。

优化PHP会话性能的方法包括:1.延迟会话启动,2.使用数据库存储会话,3.压缩会话数据,4.管理会话生命周期,5.实现会话共享。这些策略能显著提升应用在高并发环境下的效率。

theSession.gc_maxlifetimesettinginphpdeterminesthelifespanofsessiondata,setInSeconds.1)它'sconfiguredinphp.iniorviaini_set().2)abalanceisesneededeededeedeedeededto toavoidperformance andunununununexpectedLogOgouts.3)

在PHP中,可以使用session_name()函數配置會話名稱。具體步驟如下:1.使用session_name()函數設置會話名稱,例如session_name("my_session")。 2.在設置會話名稱後,調用session_start()啟動會話。配置會話名稱可以避免多應用間的會話數據衝突,並增強安全性,但需注意會話名稱的唯一性、安全性、長度和設置時機。

會話ID應在登錄時、敏感操作前和每30分鐘定期重新生成。 1.登錄時重新生成會話ID可防會話固定攻擊。 2.敏感操作前重新生成提高安全性。 3.定期重新生成降低長期利用風險,但需權衡用戶體驗。

在PHP中設置會話cookie參數可以通過session_set_cookie_params()函數實現。 1)使用該函數設置參數,如過期時間、路徑、域名、安全標誌等;2)調用session_start()使參數生效;3)根據需求動態調整參數,如用戶登錄狀態;4)注意設置secure和httponly標誌以提升安全性。

在PHP中使用會話的主要目的是維護用戶在不同頁面之間的狀態。 1)會話通過session_start()函數啟動,創建唯一會話ID並存儲在用戶cookie中。 2)會話數據保存在服務器上,允許在不同請求間傳遞數據,如登錄狀態和購物車內容。

如何在子域名間共享會話?通過設置通用域名的會話cookie實現。 1.在服務器端設置會話cookie的域為.example.com。 2.選擇合適的會話存儲方式,如內存、數據庫或分佈式緩存。 3.通過cookie傳遞會話ID,服務器根據ID檢索和更新會話數據。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!