InterView之PHP2

PHP

理論知識

經常使用的超全局變量(8個)

  • $_GET ----->get傳送方式
  • $_POST ----->post傳送方式
  • $_REQUEST ----->能夠接收到get和post兩種方式的值
  • $GLOBALS ----->全部的變量都放在裏面
  • $_FILE ----->上傳文件使用
  • $_SERVER ----->系統環境變量
  • $_SESSION ----->會話控制的時候會用到
  • $_COOKIE ----->會話控制的時候會用到

$_POST$HTTP_RAW_POST_DATAphp://input 的區別?

$_POST

是獲取表單POST過來數據,MIME類型是「application/x-www-form-urlencoded」。可參考《什麼是MIME TYPE》
意思就是字段名和值都編碼了,每一個 key-value 對使用 ‘&’ 字符分隔開,keyvalue 使用 ‘=’ 分開,其餘特殊字符都會被使用 urlencode 方式進行編碼。php

$HTTP_RAW_POST_DATA

能夠獲取原始的POST數據,但須要在 php.ini 中設置開啓,而且不支持 enctype="multipart/form-data"方式傳遞的數據html

php://input

能夠獲取原始的 POST 數據,而且比$HTTP_RAW_POST_DATA更少消耗內存,也不支持"multipart/form-data",可使用 file_get_contents() 函數去獲取它的內容mysql

介紹一下常見的SSO(單點登錄)的原理。

SSO一種統一認證和受權機制,經過一個應用中的安全驗證後,再訪問其餘應用中的受保護資源時,再也不須要從新登陸驗證。解決了用戶只須要登陸一次就能夠訪問全部相互信任的應用系統,而不用重複登陸。統一的認證系統是SSO的前提之一。認證系統的主要功能是將用戶的登陸信息和用戶信息庫相比較,對用戶進行登陸認證;認證成功後,認證系統應該生成統一的認證標誌(ticket),返還給用戶。另外,認證系統還應該對ticket進行效驗,判斷其有效性。程序員

PHP緩存技術有哪些?

全頁面靜態化緩存

也就是將頁面所有生成html靜態頁面,用戶訪問時直接訪問的靜態頁面,而不會去走php服務器解析的流程。此種方式,在CMS系統中比較常見,好比dedecms;一種比較經常使用的實現方式是用輸出緩存:web

ob_start()
******要運行的代碼*******
$content = ob_get_contents();
****將緩存內容寫入html文件*****
ob_end_clean();

頁面部分緩存

該種方式,是將一個頁面中不常常變的部分進行靜態緩存,而常常變化的塊不緩存,最後組裝在一塊兒顯示;可使用相似於ob_get_contents的方式實現,也能夠利用相似ESI之類的頁面片斷緩存策略,使其用來作動態頁面中相對靜態的片斷部分的緩存(ESI技術,請baidu,此處不詳講)。該種方式能夠用於如商城中的商品頁;算法

數據緩存

顧名思義,就是緩存數據的一種方式;好比,商城中的某個商品信息,當用商品id去請求時,就會得出包括店鋪信息、商品信息等數據,此時就能夠將這些數據緩存到一個php文件中,文件名包含商品id來建一個惟一標示;下一次有人想查看這個商品時,首先就直接調這個文件裏面的信息,而不用再去數據庫查詢;其實緩存文件中緩存的就是一個php數組之類;Ecmall商城系統裏面就用了這種方式;sql

查詢緩存

其實這跟數據緩存是一個思路,就是根據查詢語句來緩存;將查詢獲得的數據緩存在一個文件中,下次遇到相同的查詢時,就直接先從這個文件裏面調數據,不會再去查數據庫;但此處的緩存文件名可能就須要以查詢語句爲基點來創建惟一標示;按時間變動進行緩存。其實,這一條不是真正的緩存方式;上面的二、三、4的緩存技術通常都用到了時間變動判斷;就是對於緩存文件您須要設一個有效時間,在這個有效時間內,相同的訪問纔會先取緩存文件的內容,可是超過設定的緩存時間,就須要從新從數據庫中獲取數據,並生產最新的緩存文件;好比,我將咱們商城的首頁就是設置2個小時更新一次。數據庫

按內容變動進行緩存

這個也並不是獨立的緩存技術,需結合着用;就是當數據庫內容被修改時,即刻更新緩存文件;好比,一我的流量很大的商城,商品不少,商品表必然比較大,這表的壓力也比較重;咱們就能夠對商品顯示頁進行頁面緩存;當商家在後臺修改這個商品的信息時,點擊保存,咱們同時就更新緩存文件;那麼,買家訪問這個商品信息時,實際上訪問的是一個靜態頁面,而不須要再去訪問數據庫;試想,若是對商品頁不緩存,那麼每次訪問一個商品就要去數據庫查一次,若是有10萬人在線瀏覽商品,那服務器壓力就大了;apache

內存式緩存

提到這個,可能你們想到的首先就是Memcachedmemcached是高性能的分佈式內存緩存服務器。 通常的使用目的是,經過緩存數據庫查詢結果,減小數據庫訪問次數,以提升動態Web應用的速度、 提升可擴展性。它就是將須要緩存的信息,緩存到系統內存中,須要獲取信息時,直接到內存中取;比較經常使用的方式就是 key–>value方式;編程

<?php 
     $memcachehost = '192.168.6.191';
     $memcacheport = 11211;
     $memcachelife = 60;
     $memcache = new Memcache;
     $memcache->connect($memcachehost,$memcacheport) or die ("Could not connect");
     $memcache->set('key','緩存的內容');
     $get = $memcache->get($key);       //獲取信息

apache緩存模塊

apache安裝完之後,是不容許被cache的。若是外接了cachesquid服務器要求進行web加速的話,就須要在httpd.conf裏進行設置,固然前提是在安裝apache的時候要激活mod_cache的模塊。安裝apache時:./configure –enable-cache –enable-disk-cache –enable-mem-cache

php APC緩存擴展

PHP有一個APC緩存擴展,windows下面爲php_apc.dll,須要先加載這個模塊,而後是在php.ini裏面進行配置:

[apc] 
     extension=php_apc.dll 
     apc.rfc1867 = on 
     upload_max_filesize = 100M 
     post_max_size = 100M 
     apc.max_file_size = 200M 
     upload_max_filesize = 1000M 
     post_max_size = 1000M 
     max_execution_time = 600 ;   每一個PHP頁面運行的最大時間值(秒),默認30秒 
     max_input_time = 600 ;       每一個PHP頁面接收數據所需的最大時間,默認60 
     memory_limit = 128M ;       每一個PHP頁面所吃掉的最大內存,默認8M

Opcode緩存

首先php代碼被解析爲Tokens,而後再編譯爲Opcode碼,最後執行Opcode碼,返回結果;因此,對於相同的php文件,第一次運行時能夠緩存其Opcode碼,下次再執行這個頁面時,直接會去找到緩存下的opcode碼,直接執行最後一步,而再也不須要中間的步驟了。比較知名的是XCacheTurck MM CachePHP Accelerator等。

php中傳值與傳引用的區別

  • 按值傳遞:函數範圍內對值的任何改變在函數外部都會被忽略
  • 引用傳遞:函數範圍內對值的任何改變在函數外部也能反映出這些修改

PHP的垃圾收集機制是怎樣的?

PHP是一門託管型語言,在PHP編程中程序員不須要手工處理內存資源的分配與釋放,這就意味着PHP自己實現了垃圾回收機制Garbage Collection)PHP使用的回收算法是引用計數法,每一個php變量存在一個叫"zval"的變量容器。一個zval變量容器,除了包含變量的類型和值,還包括兩個字節的額外信息。第一個是"is_ref",是個bool值,用來標識這個變量是不是屬於引用集合(reference set)。第二個額外字節是"refcount",用以表示指向這個zval變量容器的變量(也稱符號即symbol)個數。把一個變量賦值給另外一變量將增長引用次數(refcount)
當任何關聯到某個變量容器的變量離開它的做用域(好比:函數執行結束),或者對變量調用了函數unset()時,"refcount"就會減1變量容器在"refcount"變成0時就被銷燬

說幾個你知道的設計模式?

單例模式:

保證一個類僅有一個實例,並提供一個訪問他的全局訪問點例如框架中的數據庫鏈接

簡單工廠模式:

它具備建立對象的某些方法,可使用工廠類建立對象,而不直接使用 new。例如初始化數據庫的時候會用到,好比MySQLMSSQL

策略模式:

針對一組算法,將每個算法封裝到具備共同接口的獨立的類中,例如進入我的主頁時,根據瀏覽者的不一樣,給予不一樣的顯示與操做

註冊模式:

提供了在程序中有條理的存放並管理一組全局對象 (object),例如ZF框架中的Zend_Registry::set

適配器模式:

將不一樣接口適配成統一的API接口,例如數據操做有mysqlmysqlipdo等,可利用適配器模式統一接口

觀察者模式:

一個對象經過添加一個方法使自己變得可觀察。當可觀察的對象更改時,它會將消息發送到已註冊的觀察者。例如實現實現消息推送

裝飾器模式:

不修改原類代碼和繼承的狀況下動態擴展類的功能,例如框架的每一個Controller文件會提供beforeafter方法

迭代器模式:

提供一個方法順序訪問一個聚合對象中各個元素,在PHP中將繼承Iterator

原型模式:

實現了一個原型接口,該接口用於建立當前對象的克隆。當直接建立對象的代價比較大時,則採用這種模式。例如,一個對象須要在一個高代價的數據庫操做以後被建立。

issetemptyis_null的區別

isset

判斷變量是否認義或者是否爲空

  • 變量存在返回ture,不然返回false
  • 變量定義不賦值返回false
  • unset一個變量,返回false
  • 變量賦值爲null,返回false

empty

判斷變量的值是否爲空,能轉換爲false的都是空,爲空返回true,反之返回false

  • "",0,"0",NULLFALSE都認爲爲空,返回true
  • 沒有任何屬性的對象都認爲是空

is_null

檢測傳入的值(值、變量、表達式)是否爲null

  • 定義了,可是賦值爲null
  • 定義了,可是沒有賦值
  • unset一個變量

框架中什麼是單一入口和多入口 , 單一入口的優缺點?

多入口就是經過訪問不一樣的文件來完成用戶請求。單一入口只 web 程序全部的請求都指向一個腳本文件的。單一入口更容易控制權限,方便對 http 請求能夠進行安全性檢查。缺點:URL 看起來不那麼美觀,特別是對搜索引擎來講不友好。

簡述兩種屏蔽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.ini display_errors=Off

PHP配置指令做用域說明

PHP總共有4個配置指令做用域:(PHP中的每一個指令都有本身的做用域,指令只能在其做用域中修改,不是任何地方都能修改配置指令的)

  • PHP_INI_PERDIR:指令能夠在php.inihttpd.conf.htaccess文件中修改
  • PHP_INI_SYSTEM:指令能夠在php.inihttpd.conf文件中修改
  • PHP_INI_USER:指令能夠在用戶腳本中修改
  • PHP_INI_ALL:指令能夠在任何地方修改
相關文章
相關標籤/搜索