Code réponse Serveur ** "header" => Headers du serveur ** "body" => Page HTML **/ function parse_response($this_response) { // Split response into header and body sections list($response_headers, $response_body) = explode("\r\n\r\n", $this_response, 2); $response_header_lines = explode("\r\n", $response_headers); // First line of headers is the HTTP response code $http_response_line = array_shift($response_header_lines); if(preg_match('@^HTTP/[0-9]\.[0-9] ([0-9]{3})@',$http_response_line, $matches)) { $response_code = $matches[1]; } // put the rest of the headers in an array $response_header_array = array(); $nbRMID=0; foreach($response_header_lines as $header_line) { list($header,$value) = explode(': ', $header_line, 2); if ($header=='Set-cookie' && substr($value,0,5)=='RMID=' && $nbRMID<5)//{ $nbRMID++; // echo ("Je gicle le RMID n°$nbRMID\r\n");} else @$response_header_array[$header] .= $value."\n"; } return array('code' => $response_code, 'header' => $response_header_array, 'body' => $response_body); } /** Récupère une page HTML en fonction des paramètres : ** $url Url distante de la page à récupérer ** $strCookies Chaine de caractère contenant les cookies ** $postData Tableau des données à passer en POST uniquement ** $referer Referer à indiquer lors de l'appel de la page ** $debug Activer le débogage (True/False) ** ** ... et retourne son contenu dans un tableau : ** "code" => Code réponse Serveur ** "header" => Headers du serveur ** "body" => Page HTML **/ function getUrl($url, $strCookies='', $postData='', $referer='', $debug=false, $host='', $proxy='', $timeout=0, $nbRetry=0) { $ch = curl_init(); if ($host=='') $this_header = array('Host: '. parse_url($url, PHP_URL_HOST)); else $this_header = array('Host: '. $host); curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_HEADER, 1); if ($proxy<>'') curl_setopt($ch, CURLOPT_PROXY, $proxy); //curl_setopt($ch, CURLOPT_PROXYUSERPWD, 'username:password'); // Pas nécessaire en authentification NT if (((int)$timeout)<>0) { curl_setopt($ch, CURLOPT_TIMEOUT, (int)$timeout); curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, (int)$timeout); } curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); //curl_setopt($ch, CURLOPT_BINARYTRANSFER, 1); // New //curl_setopt($ch, CURLOPT_FRESH_CONNECT, 1); //curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1); //curl_setopt($ch, CURLOPT_MAXREDIRS, 1); /* curl_setopt($ch, CURLOPT_WRITEFUNCTION, receiveResponse); function receiveResponse($curlHandle,$xmldata) { $this->responseString = $xmldata; $this->responseXML .= $this->responseString; $this->length = strlen($xmldata); $this->size += $this->length; return $this->length; } */ if (preg_match('/^https/i',$url)) curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); $user_agent = 'Mozilla/4.0 (compatible; MSIE 5.01; Windows NT 5.0)'; curl_setopt($ch, CURLOPT_USERAGENT, $user_agent); curl_setopt($ch, CURLOPT_REFERER, $referer); // Add each cookie that has been returned in the response // If cookies need to be added/deleted or value changed, then add code here if ($strCookies!='') { //die('"'.$strCookies.'"'); //echo $strCookies."\r\n"; $cookies = explode("\n", $strCookies); // Create the basic header foreach($cookies as $this_cookie) { if (trim($this_cookie)<>'') array_push($this_header, 'Cookie: '.$this_cookie); } } if ($postData!='') { if (is_array($postData)) $post_data=$postData; $o=""; foreach ($post_data as $k=>$v) { $o.= "$k=".utf8_encode($v)."&"; } $post_data=substr($o,0,-1); curl_setopt($ch, CURLOPT_POST, 1); curl_setopt($ch, CURLOPT_POSTFIELDS, $post_data); //if in_array('',$this_header /*array_push($this_header, "Content-type: application/x-www-form-urlencoded"); array_push($this_header, "Content-Length: 44");*/ } /* curl_setopt($ch, CURLOPT_STDERR, LOG_PATH.'/curlerror.log'); curl_setopt($ch, CURLOPT_VERBOSE, true); */ curl_setopt($ch, CURLOPT_HTTPHEADER, $this_header); //print_r($this_header); if ($nbRetry==0) { $page=curl_exec($ch); if($page === false) { if (curl_errno($ch) == 28) //TIMEOUT $response=array('code' =>408, 'header' =>array('curl_errno'=>curl_errno($ch),'curl_error'=>curl_error($ch)), 'body' =>'Connexion impossible au site du partenaire/Timeout'); else $response=array('code' =>400, 'header' =>array('curl_errno'=>curl_errno($ch),'curl_error'=>curl_error($ch)), 'body' =>'Erreur Curl : ' . curl_error($ch)); } else $response = parse_response($page); } else { $numTry=0; while($numTry<=$nbRetry) { $page=curl_exec($ch); if($page === false) { if (curl_errno($ch) == 28) //TIMEOUT $response=array('code' =>408, 'header' =>array('curl_errno'=>curl_errno($ch),'curl_error'=>curl_error($ch)), 'body' =>'Connexion impossible au site du partenaire'); else $response=array('code' =>400, 'header' =>array('curl_errno'=>curl_errno($ch),'curl_error'=>curl_error($ch)), 'body' =>'Erreur Curl : ' . curl_error($ch)); } else { $response = parse_response($page); break; } } } if ($debug){ $url2=str_replace('http://', '', $url); $url2=str_replace('/', '_', $url2); $url2=str_replace('?', '(param)', $url2); $url2=str_replace('&', '(et)', $url2); $fp=fopen('/tmp/curl-'. date('Ymd-His') .'-'. microtime_float(true) .'-'. $url2 . '.html', 'a'); fwrite($fp, $url."\r\n"); fwrite($fp, $page); fclose($fp); //echo strip_tags(html_entity_decode($response['body']), '