L'errore significa safe_mode o open_basedir ARE abilitato (probabilmente open_basedir) probabilmente non è possibile eseguire l'override se l'host dispone di impostazioni di sicurezza decenti.
In modo da avere una scelta
1) il cambiamento host (non proprio auspicabile immagino)
2) utilizzare una funzione simile a quelle che si trovano sulla pagina curl_setopt php, cioè http://www.php.net/manual/en/function.curl-setopt.php#95027
Il segue è una versione fissa della funzione di cui al punto 2
function curl_redirect_exec($ch, &$redirects, $curlopt_header = false) {
curl_setopt($ch, CURLOPT_HEADER, true);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
$data = curl_exec($ch);
$http_code = curl_getinfo($ch, CURLINFO_HTTP_CODE);
if ($http_code == 301 || $http_code == 302) {
list($header) = explode("\r\n\r\n", $data, 2);
$matches = array();
preg_match("/(Location:|URI:)[^(\n)]*/", $header, $matches);
$url = trim(str_replace($matches[1], "", $matches[0]));
$url_parsed = parse_url($url);
if (isset($url_parsed)) {
curl_setopt($ch, CURLOPT_URL, $url);
$redirects++;
return curl_redirect_exec($ch, $redirects, $curlopt_header);
}
}
if ($curlopt_header) {
return $data;
} else {
list(, $body) = explode("\r\n\r\n", $data, 2);
return $body;
}
}
divertente, ma lo script funziona bene sul mio host (economico e virtuale), ma il capo usa host stupido e non ha voglia di cambiare. riguardo a questa funzione - lo so, quando inizio a scrivere script, richiama manualmente ogni url, ma l'ultimo url non funziona, e usare solo CURLOPT_FOLLOWLOCATION mi aiuta – kusanagi
Eek scusate se non ho effettivamente testato la funzione, si ' a destra non funziona (si presuppone che l'intestazione Location non sia l'ultima) Ho aggiunto una versione corretta che ho testato per la mia risposta. – Rwky
La tua soluzione ha alcuni bug. La regex dovrebbe essere '[^ \ n]'. Quando si chiama ricorsivamente "curl_redirect_exec' si dovrebbe passare a' $ curlopt_header'. –