A. php網頁運行原理
轉載以下,希望對你有幫助:
你有沒有想過PHP是怎麼在瀏覽器里輸出「你好世界」的?我也是看了PHP內核和擴展後才知道的。也許有些朋友也想知道其中原理,那就讓我們開始吧。
在上一篇網志里我簡單介紹了「在我瀏覽這個頁面之前都發生了些什麼?」這個問題。如果你錯過了就點這里看看吧。現在我要討論的是「PHP是怎樣在瀏覽器里輸出內容」這個問題。
簡介
先看看下面這個過程:
1. 我們從未手動開啟過PHP的相關進程,它是隨著Apache的啟動而運行的;
2. PHP通過mod_php5.so模塊和Apache相連(具體說來是SAPI,即伺服器應用程序編程介面);
3. PHP總共有三個模塊:內核、Zend引擎、以及擴展層;
4. PHP內核用來處理請求、文件流、錯誤處理等相關操作;
5. Zend引擎(ZE)用以將源文件轉換成機器語言,然後在虛擬機上運行它;
6. 擴展層是一組函數、類庫和流,PHP使用它們來執行一些特定的操作。比如,我們需要mysql擴展來連接MySQL資料庫;
7. 當ZE執行程序時可能會需要連接若干擴展,這時ZE將控制權交給擴展,等處理完特定任務後再返還;
8. 最後,ZE將程序運行結果返回給PHP內核,它再將結果傳送給SAPI層,最終輸出到瀏覽器上。
深入探討
等等,沒有這么簡單。以上過程只是個簡略版,讓我們再深入挖掘一下,看看幕後還發生了些什麼。
1. Apache啟動後,PHP解釋程序也隨之啟動;
2. PHP的啟動過程有兩步;
3. 第一步是初始化一些環境變數,這將在整個SAPI生命周期中發生作用;
4. 第二步是生成只針對當前請求的一些變數設置。
PHP啟動第一步
不清楚什麼第一第二步是什麼?別擔心,我們接下來詳細討論一下。讓我們先看看第一步,也是最主要的一步。要記住的是,第一步的操作在任何請求到達之前就發生了。
1. 啟動Apache後,PHP解釋程序也隨之啟動;
2. PHP調用各個擴展的MINIT方法,從而使這些擴展切換到可用狀態。看看php.ini文件里打開了哪些擴展吧;
3. MINIT的意思是「模塊初始化」。各個模塊都定義了一組函數、類庫等用以處理其他請求。
一個典型的MINIT方法如下:
PHP_MINIT_FUNCTION(extension_name){
/* Initialize functions, classes etc */
}
PHP啟動第二步
1. 當一個頁面請求發生時,SAPI層將控制權交給PHP層。於是PHP設置了用於回復本次請求所需的環境變數。同時,它還建立一個變數表,用來存放執行過程中產生的變數名和值。
2. PHP調用各個模塊的RINIT方法,即「請求初始化」。一個經典的例子是Session模塊的RINIT,如果在php.ini中啟用了Session 模塊,那在調用該模塊的RINIT時就會初始化$_SESSION變數,並將相關內容讀入;
3. RINIT方法可以看作是一個准備過程,在程序執行之間就會自動啟動。
一個典型的RINIT方法如下:
PHP_RINIT_FUNCTION(extension_name) {
/* Initialize session variables, pre-populate variables, redefine global variables etc */
}
PHP關閉第一步
如同PHP啟動一樣,PHP的關閉也分兩步:
1. 一旦頁面執行完畢(無論是執行到了文件末尾還是用exit或die函數中止),PHP就會啟動清理程序。它會按順序調用各個模塊的RSHUTDOWN方法。
2. RSHUTDOWN用以清除程序運行時產生的符號表,也就是對每個變數調用unset函數。
一個典型的RSHUTDOWN方法如下:
PHP_RSHUTDOWN_FUNCTION(extension_name) {
/* Do memory management, unset all variables used in the last PHP call etc */
}
PHP關閉第二步
最後,所有的請求都已處理完畢,SAPI也准備關閉了,PHP開始執行第二步:
1. PHP調用每個擴展的MSHUTDOWN方法,這是各個模塊最後一次釋放內存的機會。
一個典型的RSHUTDOWN方法如下:
PHP_MSHUTDOWN_FUNCTION(extension_name) {
/* Free handlers and persistent memory etc */
}
這樣,整個PHP生命周期就結束了。要注意的是,只有在伺服器沒有請求的情況下才會執行「啟動第一步」和「關閉第二步」。
B. PHP中try.catch與return的執行順序,該怎麼解決
問題1
輸出結果是1
問題2
輸出結果是2
finally中的語句是一定要執行的,這點是肯定的。finally中的語句執行在try之後。通常try是要和catch(不捕獲異常try就沒意義了)。一般的用法是:
try{
1想要執行的代碼
}catch(Exception
e){
2異常處理
}finally{
3最終執行的代碼
}
1中代碼沒錯執行的順序就是1->3
1中代碼有錯執行的順序是2->3
finally中的代碼和return是沒關系的,你可以把return寫在任何地方。它只和try、catch有關。假如你把問題一種finally的代碼寫成:
finally{
return
++x;
}那麼結果就是2了。
finally一定會執行,且在try或catch之後執行。
不知道這么說能明白嗎~~~
不明白可以問,我再回答~~~
C. php代碼執行順序
php代碼理論上是從上到下的執行順序,但是也不是你這樣理解!
他最終的輸出內容,是根據你寫的php代碼的邏輯進行判斷輸出的!
比如:
$i=10;
if($i==20){
echo'您好!'
}else{
echo'太好了';
}
這段代碼執行順序確實是從上到下,但並不是說, echo '您好' 在echo '太好了' 的上面,那就一定會 輸出 「您好」這兩個字,
而是你看的邏輯
首先 $i 等於10,
所以 if ( $i == 20 )這個條件是不成立的
所以最終輸出的結果是 」太好了「3個字!
php所謂的代碼從上到下的執行順序,那是對於php伺服器端而言, 最終你在終端看到的結果, 是以代碼的邏輯思維為准!
D. php文本里 php和html代碼誰先執行誰啊
先執行PHP代碼,PHP和HTML混編的時候你肯定遇到過下面的情況:
<?php if(true){ ?>
<div>true</div>
<?php }else{ ?>
<div>false</div>
<?php } ?>
上面的代碼結果是瀏覽器顯示的是<div>true</div>
如果先執行html那麼結果你就發現PHP的邏輯判斷就不會生效了。
所以先執行的PHP,而PHP文件里的HTML代碼,程序會默認為是一個字元串被PHP輸出。以上代碼的最終呈現效果如果全換成PHP的話將會是下面的代碼:
<?php if(true){
echo '<div>true</div>';
}else{
echo '<div>false</div>';
}
?>
E. 簡述PHP頁面的執行過程
1. 我們從未手動開啟過PHP的相關進程,它是隨著Apache的啟動而運行的;
2. PHP通過mod_php5.so模塊和Apache相連(具體說來是SAPI,即伺服器應用程序編程介面);
3. PHP總共有三個模塊:內核、Zend引擎、以及擴展層;
4. PHP內核用來處理請求、文件流、錯誤處理等相關操作;
5. Zend引擎(ZE)用以將源文件轉換成機器語言,然後在虛擬機上運行它;
6. 擴展層是一組函數、類庫和流,PHP使用它們來執行一些特定的操作。比如,我們需要mysql擴展來連接MySQL資料庫;
7. 當ZE執行程序時可能會需要連接若干擴展,這時ZE將控制權交給擴展,等處理完特定任務後再返還;
8. 最後,ZE將程序運行結果返回給PHP內核,它再將結果傳送給SAPI層,最終輸出到瀏覽器上。
F. php如何順序執行,即等待一段代碼完全執行完畢後再執行後面的代碼
你所謂的消耗時間是指多長?
如果你確定**這段程序在php允許的默認的30秒內,這段程序是完全可以執行完成,並順序執行的。
如果你的這段耗時程序超過了30秒,基本上不好實現了,如果超過這個限定,php會報錯退出。
如果大於30秒,你可以試試這樣做:
php.ini中的:
max_execution_time = 30
這個30是指秒,有效的最大時間是1000秒,再不能大了,再大的話也只限定在1000秒;
改了這個參數再試試。如果還大於1000秒?那你的程序也是不合實際了,基本無法實現。
G. php,html,css,js,mysql的運行順序是什麼
訪問一個網頁,伺服器運行php解析程序,解析php,當用到mysql的時候鏈接mysql(當php解析完畢自動斷開),當php解析完畢,開始返回html,瀏覽器開始解析html,監測到js和css都是獨立文件時(很多時候css和js的代碼都在html里了),就開始請求js和css文件,具體他們兩個誰先請求,不太確定,推測是,在html中的順序,瀏覽器在得到html的時候就開始顯示網頁,css完畢的時候,整體顯示完整,js需要觸動。
H. php的MVC框架中,語句執行順序問題,新手,求解答
正常來說樓主想的邏輯的對的,window.location.href="";應該是你這個寫錯了;下面是我寫的,完全是當alert彈框點擊確認之後,才執行的跳轉。
<script>
alert('111');
window.location.href='2.html';
</script>
I. 關於php代碼和html代碼執行問題
PHP是解釋執行的,程序執行的結構包括:
順序結構(自上而下)
選擇結構(不是所有的代碼都自上而下的全部執行,而是根據條件選擇性的執行部分)
循環結構(反復的執行一段代碼)
客戶端向伺服器發送請求(Request)後,PHP解釋器按照上面所述的執行結構解釋翻譯PHP文件中的代碼(包括HTML部分)。PHP程序執行後的結果就全部是HTML,伺服器再將這些HTML反饋給客戶端的瀏覽器(Response),瀏覽器對接受到的HTML(包括HTML,JS和CSS樣式)進行翻譯渲染,最後呈現在訪問者的面前。
J. PHP代碼和JS代碼誰先執行
php先執行。整個運行是這樣的:
客戶端發送請求到伺服器,伺服器找到請求的文件(在伺服器上),判斷請求的文件類型。如果遇到php的代碼類型 就把代碼發送給php讓php先翻譯成html,再由伺服器把html發送到瀏覽器上。瀏覽器開始解釋html,遇到javascript再解釋javascript。最後完成整個流程。。