㈠ php如何驗證網址是否正確
public function getUrlParams()
{
if ($this->_urlParams === null)
{
$pa = @parse_url($this->getUrl());
$pa['scheme'] = isset($pa['scheme']) ? strtolower($pa['scheme']) : 'http';
if ($pa['scheme'] !== 'http' && $pa['scheme'] !== 'https')
{
trigger_error("Invalid url scheme `{$pa['scheme']}`", E_USER_WARNING);
return false;
}
if (!isset($pa['host']))
{
trigger_error("Invalid request url, host required", E_USER_WARNING);
return false;
}
if (!isset($pa['path']))
$pa['path'] = '/';
// basic auth
if (isset($pa['user']) && isset($pa['pass']))
$this->applyBasicAuth($pa['user'], $pa['pass']);
// convert host to IP address
$port = isset($pa['port']) ? intval($pa['port']) : ($pa['scheme'] === 'https' ? 443 : 80);
$pa['ip'] = $this->hasHeader('x-server-ip') ?
$this->getHeader('x-server-ip') : self::getIpAddr($pa['host']);
$pa['conn'] = ($pa['scheme'] === 'https' ? 'ssl' : 'tcp') . '://' . $pa['ip'] . ':' . $port;
// host header
if (!$this->hasHeader('host'))
$this->setHeader('host', strtolower($pa['host']));
else
$pa['host'] = $this->getHeader('host');
$this->_urlParams = $pa;
}
return $this->_urlParams;
}
public function getUrlParam($key)
{
$pa = $this->getUrlParams();
return isset($pa[$key]) ? $pa[$key] : null;
}
㈡ 如何還原PHP對URL中+的轉義
php返回的json數據是吧。php端默認是htmlspecialchars(urlencode($json)),當然這是框架自己乾的;
你試下用php執行urldecode(htmlsepcialchars_decode($json));不知道你用什麼語言。
那些字元是url編碼
㈢ php里怎麼替換指定的一段url
一是PHP獲取當前頁面的網址:
代碼如下:
//獲得當前的腳本網址
function GetCurUrl()
{
if(!empty($_SERVER["REQUEST_URI"]))
{
$scriptName = $_SERVER["REQUEST_URI"];
$nowurl = $scriptName;
}
else
{
$scriptName = $_SERVER["PHP_SELF"];
if(empty($_SERVER["QUERY_STRING"]))
{
$nowurl = $scriptName;
}
else
{
$nowurl = $scriptName."?".$_SERVER["QUERY_STRING"];
}
}
return $nowurl;
}
另一個是PHP替換網址中query部分的某變數的值比如 ,我們要設$url中的key=321;
其實有幾種情況:
$url='www.sina.com/a.php?key=330′;
或$url='www.sina.com/a.php;
或$url='www.sina.com/a.php?cat=2′;
等等。雖然情況很多,但PHP處理起來非常簡單,如下:
復制代碼 代碼如下:
/* 將URL中的某參數設為某值*/ //【這一段就挺好啊】
function url_set_value($url,$key,$value)
{
$a=explode('?',$url);
$url_f=$a[0];
$query=$a[1];
parse_str($query,$arr);
$arr[$key]=$value;
return $url_f.'?'.http_build_query($arr);
}
不過替換是這樣寫的
代碼如下:
<?php
/**
*使用常式:可用於分頁類或頁面中的替換等
$url = "add_jd.php?pid=4&tb=gm_jd&page=1";
echo( "原始的URL:" . $url );
echo( '<br/>' );
echo( "字元串參數:" . url::replace( $url , "pid=10,page=2") );
echo( '<br/>' );
echo( "數組型參數:" . url::replace( $url , array('pid'=>10,'page'=>5)) );
//echo( urlReplace( $url , array('pid'=>10,'page'=>5)) );
*/
/**
* url replace
* @param string $url 需要替換的URL字元串,一般為aaa.php?abc=def,也可以帶上路徑,象http://xxx.com/abc/def.php?aa=bb
* @param mixed $options 需要替換的變數,可以是字元串或數組,如果是字元串,格式為"aa=bb,cc=dd",有多個,用","隔開
* @return string $url 替換後的URL
*/
class url
{
static function replace ( $url , $options)
{
$options = self::optInit( $options );
$Query = parse_url( $url , PHP_URL_QUERY );
if($Query){
parse_str( $Query , $GET );
if ( $GET ){
//foreach ( $GET as $_k => $_v ){
// //if( array_key_exists( $_k , $options)){
// $GET[$_k] = $options[$_k];
// //}
//}
$GET = array_merge($GET,$options);
}
return str_replace( $Query , http_build_query( $GET ), $url );
}
if( !$Query && $options ){
return $url . "?" . http_build_query($options);
}
return $url;
}
static private function optInit ( $options )
{
if( is_string( $options )){
$optlists = Power::Normalize( $options );
foreach( $optlists as $val){
list($tmpKey,$tmpVal) = Power::Normalize( $val , "=");
$opts[$tmpKey] = $tmpVal;
}
}else{
$opts = $options;
}
//unset( $options );
return $opts;
}
}
雖然考慮了一些東西,但也僅僅是個很一般的解決方法
以下是一些補充資料:
例: 我需要 獲取當前的 的URL 地址
$url_this = "http://".$_SERVER ['HTTP_HOST'].$_SERVER['PHP_SELF'];
echo $url_this;
則顯示 : http://localhost/lu.php
伺服器變數:$_SERVER
注: 在 PHP 4.1.0 及以後版本使用。之前的版本,使用 $HTTP_SERVER_VARS。
$_SERVER 是一個包含諸如頭部(headers)、路徑(paths)和腳本位置(script locations)的數組。數組的實體由 web 伺服器創建。不能保證所有的伺服器都能產生所有的信息;伺服器可能忽略了一些信息,或者產生了一些未在下面列出的新的信息。這意味著,大量的這些變數在 CGI 1.1 specification 中說明,所以您應該仔細研究它。
這是一個「superglobal」,或者可以描述為自動全局變數。這只不過意味這它在所有的腳本中都有效。在函數或方法中您不需要使用 global $_SERVER; 訪問它,就如同使用 $HTTP_SERVER_VARS 一樣。
$HTTP_SERVER_VARS 包含著同樣的信息,但是不是一個自動全局變數。(注意: $HTTP_SERVER_VARS 和 $_SERVER 是不同的變數,PHP 處理它們的方式不同。)
如果設置了 register_globals 指令,這些變數也在所有腳本中可用;也就是,分離了 $_SERVER 和 $HTTP_SERVER_VARS 數組。相關信息,請參閱安全的相關章節 使用 Register Globals。這些單獨的全局變數不是自動全局變數。
您或許會發現下面列出的某些 $_SERVER 元素並不可用。注意,如果以命令行方式運行 PHP,下面列出的元素幾乎沒有有效的(或是沒有任何實際意義的)。
「PHP_SELF」
當前正在執行腳本的文件名,與 document root相關。舉例來說,在URL地址為 http://example.com/test.php/foo.bar 的腳本中使用 $_SERVER['PHP_SELF'] 將會得到 /test.php/foo.bar 這個結果。
如果 PHP 以命令行方式運行,該變數無效。
「argv」
傳遞給該腳本的參數。當腳本運行在命令行方式時,argv 變數傳遞給程序 C 語言樣式的命令行參數。當調用 GET 方法時,該變數包含請求的數據。
「argc」
包含傳遞給程序的命令行參數的個數(如果運行在命令行模式)。
「GATEWAY_INTERFACE」
伺服器使用的 CGI 規范的版本。例如,「CGI/1.1」。
'SERVER_NAME'
當前運行腳本所在伺服器主機的名稱。如果該腳本運行在一個虛擬主機上,該名稱是由那個虛擬主機所設置的值決定。
'SERVER_SOFTWARE'
伺服器標識的字串,在響應請求時的頭部中給出。
「SERVER_PROTOCOL」
請求頁面時通信協議的名稱和版本。例如,「HTTP/1.0」。
「REQUEST_METHOD」
訪問頁面時的請求方法。例如:「GET」、「HEAD」,「POST」,「PUT」。
「QUERY_STRING」
查詢(query)的字元串。
「DOCUMENT_ROOT」
當前運行腳本所在的文檔根目錄。在伺服器配置文件中定義。
「HTTP_ACCEPT」
當前請求的 Accept: 頭部的內容。
「HTTP_ACCEPT_CHARSET」
當前請求的 Accept-Charset: 頭部的內容。例如:「iso-8859-1,*,utf-8」。
「HTTP_ACCEPT_ENCODING」
當前請求的 Accept-Encoding: 頭部的內容。例如:「gzip」。
「HTTP_ACCEPT_LANGUAGE」
當前請求的 Accept-Language: 頭部的內容。例如:「en」。
「HTTP_CONNECTION」
當前請求的 Connection: 頭部的內容。例如:「Keep-Alive」。
「HTTP_HOST」
當前請求的 Host: 頭部的內容。
「HTTP_REFERER」
鏈接到當前頁面的前一頁面的 URL 地址。不是所有的用戶代理(瀏覽器)都會設置這個變數,而且有的還可以手工修改 HTTP_REFERER。因此,這個變數不總是正確真實的。
「HTTP_USER_AGENT」
當前請求的 User_Agent: 頭部的內容。該字元串表明了訪問該頁面的用戶代理的信息。一個典型的例子是:Mozilla/4.5 [en] (X11; U; Linux 2.2.9 i586)。您也可以使用 get_browser() 得到這個信息。
「REMOTE_ADDR」
正在瀏覽當前頁面用戶的 IP 地址。
'REMOTE_HOST'
正在瀏覽當前頁面用戶的主機名。反向域名解析基於該用戶的 REMOTE_ADDR。
注: 必須配置 Web 伺服器來建立此變數。例如 Apache 需要在 httpd.conf 中有 HostnameLookups On。參見 gethostbyaddr()。
「REMOTE_PORT」
用戶連接到伺服器時所使用的埠。
「SCRIPT_FILENAME」
當前執行腳本的絕對路徑名。
「SERVER_ADMIN」
該值指明了 Apache 伺服器配置文件中的 SERVER_ADMIN 參數。如果腳本運行在一個虛擬主機上,則該值是那個虛擬主機的值。
「SERVER_PORT」
伺服器所使用的埠。默認為「80」。如果你使用 SSL 安全連接,則這個值為您所設置的 HTTP 埠。
「SERVER_SIGNATURE」
包含伺服器版本和虛擬主機名的字元串。
「PATH_TRANSLATED」
當前腳本所在文件系統(不是文檔根目錄)的基本路徑。這是在伺服器進行虛擬到真實路徑的映像後的結果。
「SCRIPT_NAME」
包含當前腳本的路徑。這在頁面需要指向自己時非常有用。
「REQUEST_URI」
訪問此頁面所需的 URI。例如,「/index.html」。
「PHP_AUTH_USER」
當 PHP 運行在 Apache 模塊方式下,並且正在使用 HTTP 認證功能,這個變數便是用戶輸入的用戶名。
「PHP_AUTH_PW」
當 PHP 運行在 Apache 模塊方式下,並且正在使用 HTTP 認證功能,這個變數便是用戶輸入的密碼。
「AUTH_TYPE」
當 PHP 運行在 Apache 模塊方式下,並且正在使用 HTTP 認證功能,這個變數便是認證的類型。
㈣ 簡單獲取新浪短網址API介面的方法(附PHP請求示例)
新浪短網址api是新浪官方對外公開的短網址生成介面,可以將冗長的鏈接地址縮短生成 t.cn 格式的短鏈接,下面分享一個獲取新浪短網址API介面的方法以及介面請求方法。
1、在線使用
將API地址中 "http://www..com" 的部分換成自己的長網址,然後復制前往瀏覽器中粘貼打開就能生成了。
2、請求介面
如果嫌在線生成的流程很麻煩,可以將API介面對接到程序中請求生成,請求示例如下。
PHP請求示例:
Java請求示例:
Python請求示例:
1、調用API介面時,只需將 「http://www..com」換成需要縮短的長鏈接即可。
2、介面支持鏈接中帶參數,但要注意的是當鏈接中出現 & 符號時,請用 %26 代替(或者使用url編碼),否則參數可能會丟失。
3、更換鏈接時,必須要以http(s)://開頭,否則可能會導致短網址生成失敗或者生成的短網址無法跳轉訪問原網站。
4、上文提到的新浪短網址API介面,經測試都是比較穩定的,覺得好用記得收藏一下,以免丟失。
1、長鏈接轉換後,為什麼結尾的參數丟失了?
答:因為長鏈接中含有特殊字元,需要將url編碼後再使用介面生成。
2、介面沒有返回結果,是什麼情況?
答:有些時候介面返回數據會有延遲,超時未返回即生成失敗,也就不會返回結果;或者是因為原鏈接被封了。
3、生成的短鏈接有效期是多久?有沒有訪問次數限制?
答:生成的t.cn短鏈接是永久有效的,沒有點擊次數限制,可以放心使用。