今天因工作需要,需要用 curl / file_get_contents 獲取需要授權(Authorization)的頁面內容,解決后寫了這篇文章分享給大家。
PHP curl 擴展,能夠在服務器端發起POST/GET請求,訪問頁面,并能獲取頁面的返回數據。
例如要獲取的頁面:http://localhost/server.php
<?php $content = isset($_POST['content'])? $_POST['content'] : ''; header('content-type:application/json'); echo json_encode(array('content'=>$content)); ?> 使用curl獲取server.php頁面
<?php $url = 'http://localhost/server.php'; $param = array('content'=>'fdipzone blog'); $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_POST, true); curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query($param)); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); $ret = curl_exec($ch); $retinfo = curl_getinfo($ch); curl_close($ch); if($retinfo['http_code']==200){  $data = json_decode($ret, true);  print_r($data); }else{  echo 'POST Fail'; } ?> 如果服務沒有安裝php curl擴展,使用file_get_contents也可以實現發起請求,獲取頁面返回數據
<?php $url = 'http://localhost/server.php'; $param = array('content'=>'fdipzone blog'); $opt = array(  'http' => array(   'method' => 'POST',   'header' => 'content-type:application/x-www-form-urlencoded',   'content' => http_build_query($param)  ) ); $context = stream_context_create($opt); $ret = file_get_contents($url, false, $context); if($ret){  $data = json_decode($ret, true);  print_r($data); }else{  echo 'POST Fail'; } ?> 使用curl 和 file_get_contents 返回的結果都是一樣的。
Array ( [content] => fdipzone blog )
對于需要授權的頁面,例如使用了htpasswd+.htaccess設置目錄訪問權限的頁面,直接用上面的方法會返回401 Unauthorized錯誤。
這次的例子先不使用htpasswd+.htaccess來控制訪問權限,而使用 $_SERVER['PHP_AUTH_USER'] 和 $_SERVER['PHP_AUTH_PW']這兩個服務器參數。
http://localhost/server.php 修改為:
<?php if(!isset($_SERVER['PHP_AUTH_USER'])) {  header('WWW-Authenticate: Basic realm="localhost"');  header("HTTP/1.0 401 Unauthorized");  exit; }else{  if (($_SERVER['PHP_AUTH_USER']!= "fdipzone" || $_SERVER['PHP_AUTH_PW']!="654321")) {   header('WWW-Authenticate: Basic realm="localhost"');   header("HTTP/1.0 401 Unauthorized");   exit;  } } $content = isset($_POST['content'])? $_POST['content'] : ''; header('content-type:application/json'); echo json_encode(array('content'=>$content)); ?> 設定帳號:fdipzone 密碼:654321
curl中,有一個參數是 CURLOPT_USERPWD,我們可以利用這個參數把帳號密碼在請求時發送過去。
	curl_setopt($ch, CURLOPT_USERPWD, '帳號:密碼');  
curl請求的程序修改為:
<?php $url = 'http://localhost/server.php'; $param = array('content'=>'fdipzone blog'); $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_POST, true); curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query($param)); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); curl_setopt($ch, CURLOPT_USERPWD, 'fdipzone:654321'); // 加入這句 $ret = curl_exec($ch); $retinfo = curl_getinfo($ch); curl_close($ch); if($retinfo['http_code']==200){  $data = json_decode($ret, true);  print_r($data); }else{  echo 'POST Fail'; } ?> 而file_get_contents 如果要發送帳號和密碼,需要手動拼接header
file_get_contents 請求的程序修改為:
<?php $url = 'http://localhost/server.php'; $param = array('content'=>'fdipzone blog'); $auth = sprintf('Authorization: Basic %s', base64_encode('fdipzone:654321')); // 加入這句 $opt = array(  'http' => array(   'method' => 'POST',   'header' => "content-type:application/x-www-form-urlencoded/r/n".$auth."/r/n", // 把$auth加入到header   'content' => http_build_query($param)  ) ); $context = stream_context_create($opt); $ret = file_get_contents($url, false, $context); if($ret){  $data = json_decode($ret, true);  print_r($data); }else{  echo 'POST Fail'; } ?> 源碼下載地址:點擊查看
以上就是本文的全部內容,希望本文的內容對大家的學習或者工作能帶來一定的幫助,同時也希望多多支持VeVb武林網!
新聞熱點
疑難解答
圖片精選