PHP 面試題三

nginx是應用層 我以爲從下往上的話 傳輸層用的是tcp/ip 應用層用的是http 
fastcgi負責調度進程 php

2. <? echo 'hello tusheng' ; ?> 沒有輸出結果, 多是什麼緣由, 簡述的解決此問題的過程(提示: 語法沒有問題) 
可能服務器上面沒有開啓短標籤short_open_tag =設置爲Off,,php.ini開啓短標籤控制參數: short_open_tag = On java

3. 簡述下面程序的輸出結果, 簡要說明爲何, 如何解決這類問題? mysql

<?php 
$tmp = 0 == "a"? 1: 2; 
echo $tmp; 

結果
1 int和string類型強制轉換形成的,0==="a" 0 == 0 確定是true啊 PHP是弱類型。。 $tmp = 0 === "a"? 1: 2; echo $tmp; 這樣就是2

4. 已知一個字符串以下: $str = "1109063 milo 1"; 
用一行代碼將該字符串裏面的1109063賦值給$uid, milo賦值給$user, 1賦值給$type 
空格以下 
list($uid, $user, $type) = explode(" ", $str); 
\t以下 
list($uid, $user, $type) = explode("\t", $str); 


list($uid, $user, $type) = sscanf($str, "%d %s %d"); 


$n = sscanf($auth, "%d\t%s %s", $id, $first, $last); 


5. 分別列出以下類型的有符號和無符號範圍 TINYINT SMALLINT MEDIUMINT INT 


TINYINT-2^7 - 2^7-10 ~ 2^8-1 
SMALLINT-2^15 - 2^15-1 0 ~ 2^16-1 
MEDIUMINT-2^23 - 2^23-1 0 ~ 2^24-1 
INT-2^31 - 2^31-1 0 ~ 2^32-1 


6. 將下面的數組用一行拼裝成一個字符串i am milo! day day up! linux

<?php $arr = array( 'I', 'AM', 'MILO!', 'DAY', 'DAY', 'UP!' ); $str = strtolower(implode(" ",$arr)); 

7. 調用以下函數獲取函數並獲取count的值 nginx

<?php 
function get_list($cnd = array(), &$count = false) { 
    // 僞代碼 處理$cnd 並賦值datas 
    $datas = 'i am call back'; 
    $count && $count = rand(1, 10000); 
    return $datas; 
} 
$count=1; 
$data = get_list($cnd,&$count); 
echo $count; 

8. 幾種方式去取代session機制, 簡單描述各自的優劣 
mysql、memcache、cookie保持一種惟一狀態標識碼 

9. 下列HTTP狀態碼出現的可能緣由, 如何處理 
200, 301, 404, 502, 503 ajax

200 OK  --請求正常處理完畢 ;  
204 No Content --請求成功處理,沒有實體的主體返回; 
206 Partial Content --GET範圍請求已成功處理
301 Moved Permanently --永久重定向,資源已永久分配新URI; 
302 Found --臨時重定向,資源已臨時分配新URI;  
303 See Other --臨時重定向,指望使用GET定向獲取
304 Not Modified --發送的附帶條件請求未知足; 
307 Temporary Redirect --臨時重定向,POST不會變成GET
400 Bad Request --請求報文語法錯誤或參數錯誤; 
401 Unauthorized --須要經過HTTP認證,或認證失敗
403 Forbidden --請求資源被拒絕;   
404 Not Found --沒法找到請求資源(服務器無理由拒絕)
500 Internal Server Error --服務器故障或Web應用故障; 
502 Bad Gateway 服務器做爲網關或者代理時,爲了完成請求訪問下一個服務器,但該服務器返回了非法的應答。
503 Service Unavailable --服務器超負載或停機維護

10. 有以下數據庫, 用原生態mysql擴展去鏈接並查詢user表的前十行 
host: 192.168.0.254 
port: 3306 
user: one 
pass: piece 
database: db_user 
table: user 


$link = mysql_connect("192.168.0.254:3306","one","piece") or die('Could not connect: '.mysql_error()); 
mysql_select_db('db_user',$link); 
$query = mysql_query("select * from user limit 10"); 
while($rs = mysql_fetch_array($query,MYSQL_ASSOC)) 
{} 

11. 用autoload($class) 實現Lib目錄下的類的自動加載並能夠兼容子目錄 
$request->action = lcfirst(implode(array_map( 
'ucfirst', 
explode('-', strtolower($request->action)) 
))); 
------------------------------------------------------------ 
function __autoload($class) 

$cls = strtolower(str_replace("_","/",$class)); 


if(file_exsits(LIB.$cls.'.php')) 

include_once(LIB.$cls.'.php'); 

else 

die("not found {$class} class"); 


defined("LIB",'/data/wwwroot/www.xx.com/lib/'); 
$author = new Lib_Author(); 
----------------------------------------------------------- 
function __authload($class) 

$cls = explode("_",$class); 
if(@is_dir($cls[1])) 

if(@is_file($cls[2])) 

include_once("CON_PATH".$cls[1].'/'.$cls[2].".php"); 

else 

dir('error'); 


else if(@is_file($cls[1].".php")) 

include_once("CON_PATH".$cls[1].".php"); 

else 

dir('error'); 


--------------------------------------- 
function __autoload($class) 

$cls = explode("_",$class); 
$file = get_file($cls); 
if($file=='error') 

die('error'); 

include_once($file); 

function get_file($dir) 

if(is_array($dir)) 

foreach($dir as $k=>$v) 

$tmpdir .= $v.'/'; 
if(is_dir('CON_PATH'.$tmpdir)) 

continue(); 

else if(is_file('CON_PATH'.$tmpdir.".php")) 

return 'CON_PATH'.$tmpdir.".php"; 

else 

return 'error'; 


return 'error'; 

return 'error'; 



defined("CON_PATH","/data/wwwroot/www.xx.com/app/cntroller/"); 
$sb = new controller_sb(); 
------------------------------------ 
function __autoload_my_classes($classname) 

# ... your logic to include classes here 

spl_autoload_register('__autoload_my_classes'); 
----------------------------------------------------------- 
12. 用set_error_handle 去捕獲錯誤並輸出, 級別本身定 
set_error_handle(callback,level) 
function callback(int $errno , string $errstr [, string $errfile [, int $errline [, array $errcontext ]]] ){ 



function dealErrorHandler($errno,$errstr,$errfile,$errline) 

switch($errno){ 
case E_USER_ERROR: 
echo "error [$errno] $errstr fatal error on line $errline in file $errfile"; 
break; 
case E_USER_WARNING: 
echo "my warning [$errno] $errstr": 
break; 
case E_USER_NOTICE: 
echo "my notice[$errno] $errstr"; 
break; 
default: 
echo "unkonwn error type :[$errno] $errstr"; 
break; 


set_erro_handler(dealErrorHandler); 


trigger_error("notice", E_USER_NOTICE); 
trigger_error("warning", E_USER_WARNING); 
trigger_error("error", E_USER_ERROR); 


13. 簡述兩種屏蔽php程序的notice警告的方法 


初始化變量,文件開始設置錯誤級別或者修改php.ini 設置error_reporting 
set_error_handler 和 @抑制錯誤 


1.在程序中添加:error_reporting (E_ALL & ~E_NOTICE); 


2.或者修改php.ini中的:error_reporting = E_ALL 


改成:error_reporting = E_ALL & ~E_NOTICE 
3.error_reporting(0);或者修改php.inidisplay_errors=Off 




14. instanceof的做用, 常常在什麼設計模式中使用 


單例模式,可是其餘的模式也會用到 


15. 1023用二進制表示, 並簡述計算過程 


10-2 
1023%2=1 
511%2 =1 
255%2 =1 
127%2 =1 
63%2 =1 
31%2 =1 
15%2 =1 
7%2 =1 
3%2 =1 
1%2 =1 
0 =0 
------------------------------------------- 
1023 
2^9=<N<2^10 
511 


k=9 
10 9 8 7 6 5 4 3 2 1 
1 1 1 1 1 1 1 1 1 1 
---------------------- 
1023 1 
1023-1/2=511 1 
511-1/2=255 1 
255-1/2=127 1 
127-1/2=63 1 
63-1/2=31 1 
31-1/2=15 1 
15-1/2=7 1 
7-1/2=3 1 
3-1/2=1 1 




----------------------------------------------- 


2-10 


只需用將二進制數的各個位上的數從最右邊開始,最右邊的第一個數乘以二的零次方,第二個數乘以二的一次方,第三個數乘以二的二次方,依次類推可得第n個數乘以二的(n-1)次方,而後把獲得的結果相加便可 
例如:110011=1*2^0+1*2^1+0*2^2+0*2^3+1*2^4+1*2^5=51 
這也能夠算是一個公式就是An*2^(n-1) An表示二進制數最右邊開始的第n個數, 
將第一項第二項第三項一直到第n項用式子An*2^(n-1) 計算出來並加在一塊兒便可 




16. 下面php程序輸出的內容是什麼? 爲何? 
<?php 
$str = "aa\tbb\tcc"; 
@list($a, $b, $c) = explode('\t', $str); 
echo $a,$b,$c; 
?> 


aabbcc;//'\t'不會以\t切割字符串,explode以後申城一個array(0=>"aa\tbb\tcc")因此。。。,'\t'換成"\t"就被切割 


17. include和require 分別返回什麼錯誤級別 


include會系統警告並繼續執行,require會發出系統警告可是會引致致命錯誤令腳本終止運行 


18. 現有一個函數, 有不肯定多少個的參數(可能有5個也可能有50個), 如何去定義這個函數 
方法一: 不借助php內置函數 
方法二: 提示func_num_args() func_get_arg() unc_get_args() 




function param() 

$numargs = func_num_args(); 
echo "Number of arguments: $numargs<br />\n"; 
if ($numargs >= 2) { 
echo "Second argument is: " . func_get_arg(1) . "<br />\n"; 

$arg_list = func_get_args(); 
for ($i = 0; $i < $numargs; $i++) { 
echo "Argument $i is: " . $arg_list[$i] . "<br />\n"; 




param(1,2,3,4,5); 




/** 
2 * 例子寫完後,原本認爲完事了,結果遇到有人問call_user_func_array(),看了一下手冊 
3 * 原來,我上面的那個test函數還能夠精簡成以下的例子, 
4 */ 
5 function otest1 ($a) 
6 { 
7 echo( '一個參數' ); 
8 } 

10 function otest2 ( $a,$b) 
11 { 
12 echo( '二個參數' ); 
13 } 
14 
15 function otest3 ( $a,$b,$c) 
16 { 
17 echo( '三個啦' ); 
18 } 
19 
20 function otest () 
21 { 
22 $args=func_get_args(); 
23 $num=func_num_args(); 
24 call_user_func_array( 'otest'.$num,$args ); 
25 } 
26 
27 otest(1,2); 










19. 在一個函數(該函數沒有return語句)裏面去處理全局變量, 而且改變他的值, 用兩種方法去實現(global和引用&) 


$var=1; 
function get_pra() 

global $var; 
$var = 'xxx'; 
echo $var; 

echo $var.'--'; 
get_pra(); 
echo $var; 
---------------------------------- 
$test = 1; 
$test1 = 2; 
function get_yinyong() 

global $test1; 
$GLOBALS["test"] = &$test1; 

echo $test."\n"; 
get_yinyong(); 
echo $test; 
---------------------------- 
20. 應用中咱們常常會遇到在user表隨機調取10條數據來展現的狀況, 簡述你如何實現該功能, 不能使用sql函數以及order by等語句 
表 user 字段uid, username 


估計一個user表中的區間,在此區間用php去一個隨機數,sql語句大於或者小於此id去limit幾十條(保證10條數據),再不夠散亂的話,取出來的數據shuffle函數打亂數組,array_rand隨即取出10個 


21. 假設下面的sql語句裏面的uid都能獲取到具體值, 通過下面語句查詢後uid的順序是什麼, 如何去按照uid in 輸入的順序去排序 
select uid from user where uid in(10, 1, 3, 8, 11, 4, 7); 


可觀的結果是1,3,4,7,8,10,11升序,有種狀況特殊就是不肯定由於中間的某些id人爲直接修改可能不是升序了,若是按照uid in的順序須要從新循環一次根據id獲取查詢結果數組中的值放進新數組中便可 


22. 用PHP將一個字符串中的字母替換成** 


preg_replace('/[a-zA-Z]*/','**',$str); 
若是指定的字符就能夠str_replace('ooxx','**',$str); 


23. 下面2.php中打印結果是什麼? 爲何? 執行順序1.php->2.php 


cookie,cookie時間就有問題time()+3600 




24. 簡述php經常使用的json編碼函數, 如何將json解碼的時候返回數組 


25. mysql 在sql語句中有' / 等詞的時候, 要對sql語句的每一個具體值作些什麼處理 


mysql_real_escape_string 


26. 如何在php中設置header頭信息 


header(''); 


27.有以下幾個腳本, 請問2.php的輸出結果 


1.php 
<?php 
setcookie('test', 'cookie_test', 3600); 
?> 
2.php 
<?php 
$cookie = isset($_COOKIE['test'])? $_COOKIE['test']: 'cookie'; 
echo $cookie; 
?> 


i am here 

總結 
a.若是include或include_once不是在函數或方法中被調用,則輸出結果均同樣。 
b.若是include或 include_once在函數或方法中被調用,則若是想讓第二次及之後調用時有結果,則必須用include,而不能用include_once,這一點必定要注意。 


28. 簡述call_user_func的功能 


調用函數或者類裏面的函數,返回第一個參數的值。相似的功能call_user_func_array 


29. 訪假設nginx已經配置server_name www.120.net xxx.120.net 
訪問問http://www.120.net/index.php和http://xxx.120.net/index.php以後 
$_SERVER["SERVER_NAME"] 和 $_SERVER["REQUEST_URI"]分別是什麼 


www.120.net xxx.120.net 
/index.php /index.php 


30. linux下某文件的屬性爲 drwxr-xr-x 用數字表示其權限是 


目錄權限爲755全部者u擁有讀寫修改權限所屬組g擁有讀、修改權限所屬組以外o的擁有讀和修改權限 


31. 寬帶的1Mbps理論上的下載速度是多少KBps, 計算的方法 


1*1024/8 


1M=1024KB 
1KB=1024B 
1B=8bit 


第二部分 
1. 簡單實現一個單例+工廠的設計模式abstract class Example{ // The parameterized factory method public static function factory($type) { if (include_once 'Drivers/' . $type . '.php') { 
$classname = 'Driver_' . $type; 
return new $classname; 
} else { 
throw new Exception ('Driver not found'); 

}}// Load a MySQL Driver$mysql = Example::factory('MySQL'); 
// Load a SQLite Driver 
$sqlite = Example::factory('SQLite'); 
definded('DRIVER','/data/wwwroot/www.want.com/core/driver/');abstract class Example(){ private function __construct() { } public static function factory($type) { if(include_once(DRIVER.$type.'.php')) { return ExampleSon::singleton($type); } else { throw new Exception("Driver is not found!"); } } }class ExampleSon implements Example{ // Hold an instance of the class private static $instance; //靜態私有的類實例 // A private constructor; prevents direct creation of object private function __construct() { echo 'I am constructed'; } // The singleton method public static function singleton() { if (!isset(self::$instance)) { //若是沒有設置靜態私有類實例,建立之 $c = __CLASS__; //得到類名稱 self::$instance = new $c } return self::$instance; } // Example method public function bark() { echo 'Woof!'; } // Prevent users to clone the instance public function __clone() //不容許被克隆 { trigger_error('Clone is not allowed.', E_USER_ERROR); 
}}關鍵詞: 
1 私有靜態成員變量 
2 __CLASS__獲取當前類名 
3 公共靜態方法獲取單例 
4 覆蓋__clone()方法 

----十個字:私有靜態量,公共靜態法-------- 

2. 例舉幾個經常使用的魔術方法, 並說明做用? 如何在打印一個對象的時候展現咱們自定義的內容? 

魔術函數 

1。__construct() 
實例化對象時被調用, 
當__construct和以類名爲函數名的函數同時存在時,__construct將被調用,另外一個不被調用。 

2。__destruct() 
當刪除一個對象或對象操做終止時被調用。 

3。__call() 
對象調用某個方法, 
若方法存在,則直接調用; 
若不存在,則會去調用__call函數。 

4。__get() 
讀取一個對象的屬性時, 
若屬性存在,則直接返回屬性值; 
若不存在,則會調用__get函數。 

5。__set() 
設置一個對象的屬性時, 
若屬性存在,則直接賦值; 
若不存在,則會調用__set函數。 

6。__toString() 
打印一個對象的時被調用。如echo $obj;或print $obj; 

7。__clone() 
克隆對象時被調用。如:$t=new Test();$t1=clone $t; 

8。__sleep() 
serialize以前被調用。若對象比較大,想刪減一點東東再序列化,可考慮一下此函數。 

9。__wakeup() 
unserialize時被調用,作些對象的初始化工做。 

10。__isset() 
檢測一個對象的屬性是否存在時被調用。如:isset($c->name)。 

11。__unset() 
unset一個對象的屬性時被調用。如:unset($c->name)。 

12。__set_state() 
調用var_export時,被調用。用__set_state的返回值作爲var_export的返回值。 

13。__autoload() 
實例化一個對象時,若是對應的類不存在,則該方法被調用。 

魔術常量 

1。__LINE__    返回文件中的當前行號。 


2。__FILE__ 
返回文件的完整路徑和文件名。若是用在包含文件中,則返回包含文件名。自 PHP 4.0.2 起,__FILE__ 老是包含一個絕對路徑,而在此以前的版本有時會包含一個相對路徑。 

3。__FUNCTION__ 
返回函數名稱(PHP 4.3.0 新加)。自 PHP 5 起本常量返回該函數被定義時的名字(區分大小寫)。在 PHP 4 中該值老是小寫字母的。 

4。__CLASS__ 
返回類的名稱(PHP 4.3.0 新加)。自 PHP 5 起本常量返回該類被定義時的名字(區分大小寫)。在 PHP 4 中該值老是小寫字母的。 

5。__METHOD__ 
返回類的方法名(PHP 5.0.0 新加)。返回該方法被定義時的名字(區分大小寫)。 

3. 類靜態方法和實例化類方法比較及優缺點 

4. 有一個論壇 
threads表記錄主題以及標題等信息 
posts表記錄主題內容以及回覆內容等信息 
threads 表主鍵爲 tid 
posts 表主鍵爲 pid, 所屬主題標記爲tid 
經過tid將threads和posts 一對多關聯起來 
如今數據量posts表達到了1億, threads表2000萬, 大約一個主題有5篇回覆 
請你設計一下分表, 將posts表和threads表進行mysql分表 

5. 如今有一個mysql 主庫/叢庫, 請問php mysql查詢的時候怎麼在php程序中實現主從分離? 主從分離有什麼好處配置主從數組文件,本身封轉幾個model函數,查詢的加載slave配置實例化,破壞數據的操做加載master進行實例化優勢:並 發負載能力提升,利於數據維護和安全,提升可用性缺點:數據同步有些延遲 

6. 簡述UCenter的單點登陸機制 
所謂單點登陸,無非就是幾個站點共用一個用戶中心,實現同步登錄,同步退出。 

其實最終仍是用戶去登陸,只是採用了ajax (javascript利用src異步跨域調用)用戶不會發現。 

並且利用了p3p頭實現了,不一樣域名,單點登陸(ucenter用的cookie) 

缺點就是採用ajax 客服端請求 ,若是有10個以上應用,登陸速度就慢下來了。 


7. linux相關 有一個包 http://www.120.net/test-1.0.0.tar.gz 
a. 將它下載到/usr/local/src 
b. 將其源碼編譯安裝到/usr/local/test 目錄 
c. 他依賴mysql包, 位於/usr/local/mysql 目錄 
寫出下載編譯安裝過程 

wget - c http://www.120.net/test-1.0.0.tar.gz/usr/local/srctar zxvf /usr/local/src/test-1.0.0.tar.gzcd /usr/local/src/test-1.0.0./configure --prefix=/usr/local/test --exec--prefix=/usr/local/mysqlmake testmake install 

8. 使用php 的memcache擴展編寫一個獲取數據的函數(緩存即將過時超時加鎖) 
a. 數據超時以後去mysql獲取, 獲取完後更新memcache 
b. 去mysql獲取數據的時候加鎖, 讓一個進程去mysql拉數據, 其餘人返回memcache中的數據 

public function get_cache($key) { if($this->memcahe) { $var = $this->memcahe->get($this->pre.$key); $valid = $this->memcahe->get($this->pre.$key.'_valid'); if($var && !$valid) { $lock = $this->memcahe->get($this->pre.$key.'_lock'); if(!$lock) { $this->memcahe->set($this->pre.$key.'_lock', true, 0, 60); return false; } } return $var; } return false; } 
public function set_cache($key, $var = null, $expire = 0) { if($this->memcahe) { $expire = (int)$expire; $expire = ($expire ? $expire : $this->expire); $this->memcahe->set($this->pre.$key, $var, 0, $expire+300); $this->memcahe->set($this->pre.$key.'_lock', false, 0, $expire); $this->memcahe->set($this->pre.$key.'_valid', true, 0, $expire); return true; } return false; } 

9. 簡述隊列, 堆棧的原理 


均可以看作是一維數組來操做,隊列先進先出,出列只能在列頭,進列只能在列尾,堆棧是後進先出,進棧和出棧都是從棧頂 


堆棧的工做原理是什麼? 


堆 棧是一種抽象數據結構,其操做機理是後進先出。當你把新條目推動堆棧時,已經在堆棧內的任何條目都會壓到堆棧的深處。一樣的,把一個條目從堆棧移出則會讓 堆棧內的其餘條目都向堆棧的頂部移動。只有堆棧最頂端的條目能從堆棧中取出,條目離開堆棧的順序和它們被推動堆棧的順序同樣。你不妨回想下自動售貨機的裝 貨和取貨過程就明白了。 
10. arrayaccess 定義以下 用它實現一個數組 
ArrayAccess { 
/* Methods */ 
abstract public boolean offsetExists ( string $offset ) 
abstract public mixed offsetGet ( string $offset ) 
abstract public void offsetSet ( string $offset , string $value ) 
abstract public void offsetUnset ( string $offset ) 

class Single implements ArrayAccess{ private $name; private static $_Instance = null; private function __construct() { } static function load() { if(null == self::$_Instance) { self::$_Instance = new Single(); } return self::$_Instance; } public function setName($name) { $this->name = $name; } public function getName() { return $this->name; } /** * 實現四個方法 * offsetExists(),用於標識一個元素是否已定義 * offsetGet(),用於返回一個元素的值 * offsetSet(),用於爲一個元素設置新值 * offsetUnset(),用於刪除一個元素和相應的值 **/ public function offsetSet($offset, $value) { if (is_null($offset)) { $this->container[] = $value; } else { $this->container[$offset] = $value; } } public function offsetGet($offset) { return isset($this->container[$offset]) ? $this->container[$offset] : null; } public function offsetExists($offset) { return isset($this->container[$offset]); } public function offsetUnset($offset) { unset($this->container[$offset]); }}$s = Single::load();$s->setName("jack");$s["name"] = "mike";echo $s->getName(); //jackecho $s["name"]; //mike 
11. 假設coreseek安裝目錄爲/usr/local/coreseek 
配置文件爲/usr/local/coreseek/etc/test.conf 
索引名爲 post 
a. 建立索引 
b. 啓動服務 
c. 重建索引(重建過程當中保證搜索服務仍然可用) 

indexer -c /usr/local/coreseek/etc/test.conf --allsearchd -c /usr/local/coreseek/etc/test.conf indexer -c /usr/local/coreseek/etc/test.conf --all --rotate12. 假設您有一張posts帖子表 對該表進行sphinx增量準實時索引, 描述你的方案 
使用「主索引+增量索引」方法有個簡單的實現,在數據庫中增長一個計數表,記錄每次從新構建主索引時,被索引表的最後一個數據id,這樣在增量索引時只須要索引這個id之後的數據便可,每次從新構建主索引時都更新這個表。 


13. php代碼: 
$i = 97;$a = ($i++) + (++$i) + $i ;$b = (--$i) + ($i--) + $i + 6; 

echo "$i, $a, $b";輸出結果是什麼 

97, 295, 299 
97 
97+99+99 
98+98+97+6 


14. 如下代碼,用於取得客戶端IP: if(getenv('HTTP_CLIENT_IP') && strcasecmp(getenv('HTTP_CLIENT_IP'), 'unknown')) { $onlineip = getenv('HTTP_CLIENT_IP');} elseif(getenv('HTTP_X_FORWARDED_FOR') && strcasecmp(getenv('HTTP_X_FORWARDED_FOR'), 'unknown')) { $onlineip = getenv('HTTP_X_FORWARDED_FOR');} elseif(getenv('REMOTE_ADDR') && strcasecmp(getenv('REMOTE_ADDR'), 'unknown')) { $onlineip = getenv('REMOTE_ADDR');} elseif(isset($_SERVER['REMOTE_ADDR']) && $_SERVER['REMOTE_ADDR'] && strcasecmp($_SERVER['REMOTE_ADDR'], 'unknown')) { $onlineip = $_SERVER['REMOTE_ADDR'];}可是以HTTP_開始的請求header均屬於客戶端能夠僞造的信息,在反向代理環境下,如何保證 PHP不會接收到僞造的HTTP_CLIENT_IP, HTTP_X_FORWARDED_FOR值? 




15. 例如google,baidu等大型網站,當使用不一樣客戶端(如手機和PC機)訪問一樣的URL時,呈現的頁面卻不相同,這是何原理? 若是能給出實際解決方案,可加分。 




簡單的能夠用user_agent判斷,可是及其初步 

能夠的話經過服務器或者手機終端特徵或者wap網關accept信息等 





16. 生產環境php.ini中magic_quotes_gpc及magic_quotes_runtime值應該設置爲何?onoff17. PHP調用遠程http接口時可以使用file_get_contents, 但當遠程主機不可達或響應過慢,會致使本地PHP進程被長時間掛起,從而影響本地服務器穩定性,如何避免超時時,PHP進程長時間被掛起? 




file_get_contents能夠設置下超時時間$ctx = stream_context_create(array( 'http' => array( 'timeout' => 1 


); 
file_get_contents("http://www.want.com/", 0, $ctx); 
curl實現獲取遠程http接口也能夠,一樣須要設置超時時間curl_setopt($s,CURLOPT_TIMEOUT,$timeout); sql


18. 同上題,如何避免DNS查詢過慢致使超時?19. mysql字符集set names * 命令設置哪幾個系統變量的值?(ACE) A、Character_set_client B、Character_set_system C、Character_set_results D、Character_set_server E、Character_set_connection F、Character_set_database20. 如下哪一種校對規則不區分大小寫?(A) A、utf8_general_ci B、utf8_general_cs C、utf8_general_bin21. 如何杜絕XSS攻擊? 
strip_tags能夠初步過濾,也能夠本身寫過濾函數針對特殊標籤進行處理,用ascii碼進行替換23. 如何杜絕CSRF攻擊? 
在Web應用程序側防護CSRF漏洞,通常都是利用referer、token或者驗證碼,tokenf方式仍是比較可信數據庫

相關文章
相關標籤/搜索