PHP面試題三

1.nginx使用哪一種網絡協議?
nginx是應用層 我以爲從下往上的話 傳輸層用的是tcp/ip 應用層用的是http
fastcgi負責調度進程


2. <? echo 'hello tusheng' ; ?> 沒有輸出結果, 多是什麼緣由, 簡述的解決此問題的過程(提示: 語法沒有問題)


可能服務器上面沒有開啓短標籤short_open_tag =設置爲Off,,php.ini開啓短標籤控制參數: short_open_tag = On


3. 簡述下面程序的輸出結果, 簡要說明爲何, 如何解決這類問題?
<?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!
<?php
$arr = array(
'I', 'AM', 'MILO!', 'DAY', 'DAY', 'UP!'
);
?>


$str = strtolower(implode(" ",$arr));


7. 調用以下函數獲取函數並獲取count的值
<?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


200
  請求已成功,請求所但願的響應頭或數據體將隨此響應返回。
301
   被請求的資源已永久移動到新位置,而且未來任何對此資源的引用都應該使用本響應返回的若干個 URI 之一。若是可能,擁有連接編輯功能的客戶端應當自動把請求的地址修改成從服務器反饋回來的地址。除非額外指定,不然這個響應也是可緩存的。   新的永久性的 URI 應當在響應的 Location 域中返回。除非這是一個 HEAD 請求,不然響應的實體中應當包含指向新的 URI 的超連接及簡短說明。   若是這不是一個 GET 或者 HEAD 請求,所以瀏覽器禁止自動進行重定向,除非獲得用戶的確認,由於請求的條件可能所以發生變化。   注意:對於某些使用 HTTP/1.0 協議的瀏覽器,當它們發送的 POST 請求獲得了一個301響應的話,接下來的重定向請求將會變成 GET 方式。


404
   請求失敗,請求所但願獲得的資源未被在服務器上發現。沒有信息可以告訴用戶這個情況究竟是暫時的仍是永久的。假如服務器知道狀況的話,應當使用410狀 態碼來告知舊資源由於某些內部的配置機制問題,已經永久的不可用,並且沒有任何能夠跳轉的地址。404這個狀態碼被普遍應用於當服務器不想揭示到底爲什麼請 求被拒絕或者沒有其餘適合的響應可用的狀況下。
502
  做爲網關或者代理工做的服務器嘗試執行請求時,從上游服務器接收到無效的響應。
503
   因爲臨時的服務器維護或者過載,服務器當前沒法處理請求。這個情況是臨時的,而且將在一段時間之後恢復。若是可以預計延遲時間,那麼響應中能夠包含一個 Retry-After 頭用以標明這個延遲時間。若是沒有給出這個 Retry-After 信息,那麼客戶端應當以處理500響應的方式處理它。   注意:503狀態碼的存在並不意味着服務器在過載的時候必須使用它。某些服務器只不過是但願拒絕客戶端的鏈接。




200 OK 一切正常,對GET和POST請求的應答文檔跟在後面。
301 Moved Permanently 客戶請求的文檔在其餘地方,新的URL在Location頭中給出,瀏覽器應該自動地訪問新的URL
404 Not Found 沒法找到指定位置的資源。這也是一個經常使用的應答。
502 Bad Gateway 服務器做爲網關或者代理時,爲了完成請求訪問下一個服務器,但該服務器返回了非法的應答。
503 Service Unavailable 服務器因爲維護或者負載太重未能應答。例如,Servlet可能在數據庫鏈接池已滿的狀況下返回503。服務器返回503時能夠提供一個Retry-After頭。


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 }
9
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
1
總結
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);
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方式仍是比較可信javascript

相關文章
相關標籤/搜索