本文目錄一覽:
php模擬瀏覽器獲取get後返回的所有網址
模擬GET請求:file_get_contents($url)通過php內置的file_get_contents函數可以模擬瀏覽器訪問網址的行為。
取的結果就是那個網址所返回的所有網址。
網頁瀏覽器(WebBrowser),常被簡稱為瀏覽器,是一種用於檢索並展示萬維網信息資源的應用程序。這些信息資源可為網頁、圖片、影音或其他內容,它們由統一資源標誌符標誌,信息資源中的超鏈接可使用戶方便地瀏覽相關信息。
PHP如何能把瀏覽器地址欄的信息賦給變量
新建go.php 在裏面輸入: ?php $url=$_GET[“url”]; echo “訪問地址是:a href=’$url’$url/a”; ? 我來解釋一下:$url=$_GET[“url”]的意思是取得地址欄中url=後面的內容然後存儲到$url中 你看一下是否解決了你的問題? 再不行就來我blog看看
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){
}
PHP啟動第二步
1. 當一個頁面請求發生時,SAPI層將控制權交給PHP層。於是PHP設置了用於回複本次請求所需的環境變量。同時,它還建立一個變量表,用來存放執行過程中產生的變量名和值。
2. PHP調用各個模塊的RINIT方法,即「請求初始化」。一個經典的例子是Session模塊的RINIT,如果在php.ini中啟用了Session模塊,那在調用該模塊的RINIT時就會初始化$_SESSION變量,並將相關內容讀入;3. RINIT方法可以看作是一個準備過程,在程序執行之間就會自動啟動。
一個典型的RINIT方法如下:
PHP_RINIT_FUNCTION(extension_name) {
}
PHP關閉第一步
如同PHP啟動一樣,PHP的關閉也分兩步:
1. 一旦頁面執行完畢(無論是執行到了文件末尾還是用exit或die函數中止),PHP就會啟動清理程序。它會按順序調用各個模塊的RSHUTDOWN方法。
2. RSHUTDOWN用以清除程序運行時產生的符號表,也就是對每個變量調用unset函數。
一個典型的RSHUTDOWN方法如下:
PHP_RSHUTDOWN_FUNCTION(extension_name) {
}
PHP關閉第二步
最後,所有的請求都已處理完畢,SAPI也準備關閉了,PHP開始執行第二步:
1. PHP調用每個擴展的MSHUTDOWN方法,這是各個模塊最後一次釋放內存的機會。
一個典型的RSHUTDOWN方法如下:
PHP_MSHUTDOWN_FUNCTION(extension_name) {
}
php 怎麼獲取瀏覽器的類型?
獲取客戶端瀏覽器、IP地址操作系統類型等的方法(PHP)
=========================
獲取客戶端信息(瀏覽器、IP、OS)
?php
/*
作用:取得客戶端信息
參數:
返回:指定的資料
使用:
$code = new clientGetObj;
1、瀏覽器:$str = $code-getBrowse();
2、IP地址:$str = $code-getIP();
4、操作系統:$str = $code-getOS();
*/
class clientGetObj
{
function getBrowse()
{
global $_SERVER;
$Agent = $_SERVER[‘HTTP_USER_AGENT’];
$browser = ”;
$browserver = ”;
$Browser = array(‘Lynx’, ‘MOSAIC’, ‘AOL’, ‘Opera’, ‘JAVA’, ‘MacWeb’, ‘WebExplorer’, ‘OmniWeb’);
for($i = 0; $i = 7; $i ++){
if(strpos($Agent, $Browsers[$i])){
$browser = $Browsers[$i];
$browserver = ”;
}
}
if(ereg(‘Mozilla’, $Agent) !ereg(‘MSIE’, $Agent)){
$temp = explode(‘(‘, $Agent);
$Part = $temp[0];
$temp = explode(‘/’, $Part);
$browserver = $temp[1];
$temp = explode(‘ ‘, $browserver);
$browserver = $temp[0];
$browserver = preg_replace(‘/([d.]+)/’, ‘\1’, $browserver);
$browserver = $browserver;
$browser = ‘Netscape Navigator’;
}
if(ereg(‘Mozilla’, $Agent) ereg(‘Opera’, $Agent)) {
$temp = explode(‘(‘, $Agent);
$Part = $temp[1];
$temp = explode(‘)’, $Part);
$browserver = $temp[1];
$temp = explode(‘ ‘, $browserver);
$browserver = $temp[2];
$browserver = preg_replace(‘/([d.]+)/’, ‘\1’, $browserver);
$browserver = $browserver;
$browser = ‘Opera’;
}
if(ereg(‘Mozilla’, $Agent) ereg(‘MSIE’, $Agent)){
$temp = explode(‘(‘, $Agent);
$Part = $temp[1];
$temp = explode(‘;’, $Part);
$Part = $temp[1];
$temp = explode(‘ ‘, $Part);
$browserver = $temp[2];
$browserver = preg_replace(‘/([d.]+)/’,’\1′,$browserver);
$browserver = $browserver;
$browser = ‘Internet Explorer’;
}
if($browser != ”){
$browseinfo = $browser.’ ‘.$browserver;
} else {
$browseinfo = false;
}
return $browseinfo;
}
function getIP ()
{
global $_SERVER;
if (getenv(‘HTTP_CLIENT_IP’)) {
$ip = getenv(‘HTTP_CLIENT_IP’);
} else if (getenv(‘HTTP_X_FORWARDED_FOR’)) {
$ip = getenv(‘HTTP_X_FORWARDED_FOR’);
} else if (getenv(‘REMOTE_ADDR’)) {
$ip = getenv(‘REMOTE_ADDR’);
} else {
$ip = $_SERVER[‘REMOTE_ADDR’];
}
return $ip;
}
function getOS ()
{
global $_SERVER;
$agent = $_SERVER[‘HTTP_USER_AGENT’];
$os = false;
if (eregi(‘win’, $agent) strpos($agent, ’95’)){
$os = ‘Windows 95’;
}
else if (eregi(‘win 9x’, $agent) strpos($agent, ‘4.90’)){
$os = ‘Windows ME’;
}
else if (eregi(‘win’, $agent) ereg(’98’, $agent)){
$os = ‘Windows 98’;
}
else if (eregi(‘win’, $agent) eregi(‘nt 5.1’, $agent)){
$os = ‘Windows XP’;
}
else if (eregi(‘win’, $agent) eregi(‘nt 5’, $agent)){
$os = ‘Windows 2000’;
}
else if (eregi(‘win’, $agent) eregi(‘nt’, $agent)){
$os = ‘Windows NT’;
}
else if (eregi(‘win’, $agent) ereg(’32’, $agent)){
$os = ‘Windows 32’;
}
else if (eregi(‘linux’, $agent)){
$os = ‘Linux’;
}
else if (eregi(‘unix’, $agent)){
$os = ‘Unix’;
}
else if (eregi(‘sun’, $agent) eregi(‘os’, $agent)){
$os = ‘SunOS’;
}
else if (eregi(‘ibm’, $agent) eregi(‘os’, $agent)){
$os = ‘IBM OS/2’;
}
else if (eregi(‘Mac’, $agent) eregi(‘PC’, $agent)){
$os = ‘Macintosh’;
}
else if (eregi(‘PowerPC’, $agent)){
$os = ‘PowerPC’;
}
else if (eregi(‘AIX’, $agent)){
$os = ‘AIX’;
}
else if (eregi(‘HPUX’, $agent)){
$os = ‘HPUX’;
}
else if (eregi(‘NetBSD’, $agent)){
$os = ‘NetBSD’;
}
else if (eregi(‘BSD’, $agent)){
$os = ‘BSD’;
}
else if (ereg(‘OSF1’, $agent)){
$os = ‘OSF1’;
}
else if (ereg(‘IRIX’, $agent)){
$os = ‘IRIX’;
}
else if (eregi(‘FreeBSD’, $agent)){
$os = ‘FreeBSD’;
}
else if (eregi(‘teleport’, $agent)){
$os = ‘teleport’;
}
else if (eregi(‘flashget’, $agent)){
$os = ‘flashget’;
}
else if (eregi(‘webzip’, $agent)){
$os = ‘webzip’;
}
else if (eregi(‘offline’, $agent)){
$os = ‘offline’;
}
else {
$os = ‘Unknown’;
}
return $os;
}
}
?
獲取IP地址
說明:使用 Request.ServerVariables(“REMOTE_ADDR”) 來取得客戶端的 IP 地址,但如果客戶端是使用代理服務器來訪問,那取到的就是代理服務器的 IP 地址,而不是真正的客戶端 IP 地址。要想透過代理服務器取得客戶端的真實IP 地址,就要使用Request.ServerVariables(“HTTP_X_FORWARDED_FOR”) 來讀取。不過要注意的事,並不是每個代理服務器都能用 Request.ServerVariables(“HTTP_X_FORWARDED_FOR”) 來讀取客戶端的真實 IP,有些用此方法讀取到的仍然是代理服務器的 IP。
還有一點需要注意的是:如果客戶端沒有通過代理服務器來訪問,那麼用 Request.ServerVariables(“HTTP_X_FORWARDED_FOR”) 取到的值將是空的。因此,如果要在程序中使用此方法,可以這樣處理:
……
userip = Request.ServerVariables(“HTTP_X_FORWARDED_FOR”)
If userip = “” Then userip = Request.ServerVariables(“REMOTE_ADDR”)
……
即:如果客戶端通過代理服務器,則取 HTTP_X_FORWARDED_FOR 的值,如果沒通過代理服務器,就取 REMOTE_ADDR 的值。
方法一:
function real_ip($type)
{
if ($_SERVER[“HTTP_X_FORWARDED_FOR”])
{
if ($_SERVER[“HTTP_CLIENT_IP”])
{
$proxy = $_SERVER[“HTTP_CLIENT_IP”];
}
else
{
$proxy = $_SERVER[“REMOTE_ADDR”];
}
$ip = $_SERVER[“HTTP_X_FORWARDED_FOR”];
}
else
{
if ($_SERVER[“HTTP_CLIENT_IP”])
{
$ip = $_SERVER[“HTTP_CLIENT_IP”];
}
else
{
$ip = $_SERVER[“REMOTE_ADDR”];
}
}
if($type==’ip’)return $ip;
if($type==’proxy’)return $proxy;
}
方法二:
?
function iptype1 () {
if (getenv(“HTTP_CLIENT_IP”)) {
?return getenv(“HTTP_CLIENT_IP”);
}
else {
?return “none”;
}
}
function iptype2 () {
if (getenv(“HTTP_X_FORWARDED_FOR”)) {
?return getenv(“HTTP_X_FORWARDED_FOR”);
}
else {
?return “none”;
}
}
function iptype3 () {
if (getenv(“REMOTE_ADDR”)) {
?return getenv(“REMOTE_ADDR”);
}
else {
?return “none”;
}
}
function ip() {
$ip1 = iptype1();
$ip2 = iptype2();
$ip3 = iptype3();
if (isset($ip1) $ip1 != “none” $ip1 != “unknown”) {
?return $ip1;
}
elseif (isset($ip2) $ip2 != “none” $ip2 != “unknown”) {
?return $ip2;
}
elseif (isset($ip3) $ip3 != “none” $ip3 != “unknown”) {
?return $ip3;
}?
else {
return “none”;
}
}
Echo ip();
?
方法三:
01 : function ipCheck() {
02 : if (getenv( ‘HTTP_CLIENT_IP’ )) {
03 : $ip = getenv( ‘HTTP_CLIENT_IP’ );
04 : }
05 : elseif (getenv( ‘HTTP_X_FORWARDED_FOR’ )) {
06 : $ip = getenv( ‘HTTP_X_FORWARDED_FOR’ );
07 : }
08 : elseif (getenv( ‘HTTP_X_FORWARDED’ )) {
09 : $ip = getenv( ‘HTTP_X_FORWARDED’ );
10 : }
11 : elseif (getenv( ‘HTTP_FORWARDED_FOR’ )) {
12 : $ip = getenv( ‘HTTP_FORWARDED_FOR’ );
13 : }
14 : elseif (getenv( ‘HTTP_FORWARDED’ )) {
15 : $ip = getenv( ‘HTTP_FORWARDED’ );
16 : }
17 : else {
18 : $ip = $_SERVER[ ‘REMOTE_ADDR’ ];
19 : }
20 : return $ip;
21 : }
原創文章,作者:LUCA,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/144476.html