<?php
fonction get_url_content($Url,$Method = 'c') {
//Introduisez le codage de langue requis. Sinon, il sera par défaut utf-8, ne vous inquiétez pas.
jeu de caractères $ global ;
$Urlarr = parse_url($Url);
//Si le nom de domaine ne peut pas être détecté, retournez.
if (!isset($Urlarr['host'])) {
renvoie faux ;
}
//Nous définissons plusieurs informations d'en-tête de manière intelligente.
foreach (@getallheaders() comme $key => $val){
$key==='Hôte' && $val = $Urlarr['hôte'];
$key==='Référent' && $val ='http://'.$Urlarr['hôte'];
$str .= "'$key:$val', n";
}
//Origine virtuelle.
!eregi('Referer',$str) && $str .="'Referer:http://{$Urlarr['host']}', n";
//Après correction, en gros, la source est également ce site, et l'hôte est également le site Url.
$En-tête = array(trim($str));
// Ce qui suit consiste simplement à choisir le programme à utiliser pour la collection.
if($Method === 'f'&&function_exists('file_get_contents')) {
$opts = tableau(
'http'=>tableau(
'méthode'=>"OBTENIR",
'en-tête'=>$En-tête,
)
);
$cxContext = stream_context_create($opts);
$file_contents = @file_get_contents($Url, false, $cxContext);
} elseif ($Method === 'c'&&function_exists('curl_init')) {
$Ch = curl_init();
$Délai d'attente = 5 ;
curl_setopt($Ch,CURLOPT_HTTPHEADER,$En-tête);
curl_setopt ($Ch, CURLOPT_URL, $Url);
curl_setopt ($Ch, CURLOPT_RETURNTRANSFER,1);
curl_setopt ($Ch, CURLOPT_CONNECTTIMEOUT, $Timeout);
$file_contents = curl_exec($Ch);
curl_close($Ch);
}
// Afin que le style s'affiche magnifiquement, nous y ajoutons un guide cible.
$file_contents = str_replace('</title>',"</title>n<base href=" http://{$Urlarr['host']}/ " />",$file_contents);
// Traitez les encodages les plus courants. Si le site Web cible n'a pas d'encodage, il sera par défaut GBK.
!preg_match('/charset=([^<>"]*)"/isU',$file_contents,$lang) && $lang[1]='GBK';
function_exists('mb_convert_encoding') && $file_contents = mb_convert_encoding($file_contents,empty($Charset)?'UTF-8':$Charset,$lang[1]);
//Déconnectez-vous d'une partie du code ;
unset($Url,$lang,$Timeout,$Urlarr,$Charset);
renvoie $file_contents ;
}
// Commencer les tests en utilisant la méthode file_get_contents
HEADER("TYPE DE CONTENU:TEXTE/HTML; CHARSET=UTF-8");
//http://www.xtzj.com/read-htm-tid-347550.html Cela ne peut pas être collecté.
$file = get_url_content(" http://www.hao123.com", 'f' );
$file = strip_tags($file,'<a>');
preg_match_all('/(http:[^"<>]*)>/isU',$file,$link);unset($link[0]);
$link = $link[1];
//Simulons l'obtention de données vous-même. 0-151 Ce qui suit utilise curl.
$x = 10 ;
$file = get_url_content($lien[$x]);
echo $fichier ;
?>
Écrivez toutes les explications et commentaires.
S'il y a des réponses que vous ne comprenez pas... Je diffuserai les connaissances sur la collection.
Adresse originale : http://bbs.phpchina.com/viewthread.php?tid=. 99263