グラブ、キャッシュおよびリモートのXMLフィードを解析し、PHPでの検証チェック

StackOverflow https://stackoverflow.com/questions/2262079

  •  20-09-2019
  •  | 
  •  

質問

現在、私は、リモートサイトのXMLフィードをつかみ、PHPで解析することが私のサーバー上のローカルコピーを保存しています。

問題は、私はfeed.xmlファイルが有効であるかどうかを確認するためにPHPでいくつかのチェックを追加して行くとあればそうfeed.xmlを使用して行う方法です。

と(時々、リモートXMLフィードはサムス空白feed.xmlを表示している)エラーが発生した無効な場合は、前のグラブからfeed.xmlのバックアップ有効なコピーを提供/保存する?

コードグラブfeed.xml

<?php
/**
* Initialize the cURL session
*/
$ch = curl_init();
/**
* Set the URL of the page or file to download.
*/
curl_setopt($ch, CURLOPT_URL,
'http://domain.com/feed.xml');
/**
* Create a new file
*/
$fp = fopen('feed.xml', 'w');
/**
* Ask cURL to write the contents to a file
*/
curl_setopt($ch, CURLOPT_FILE, $fp);
/**
* Execute the cURL session
*/
curl_exec ($ch);
/**
* Close cURL session and file
*/
curl_close ($ch);
fclose($fp);
?>

これまでのところ唯一それをロードするためにこれを持っている。

$xml = @simplexml_load_file('feed.xml') or die("feed not loading");

感謝

役に立ちましたか?

解決

これはファイルに直接書き込むべきであるカールをpricipialていない場合は、お近くのfeed.xmlを再度書き込む前に、あなたはXMLをチェックすることができます:

<?php
/**
* Initialize the cURL session
*/
$ch = curl_init();
/**
* Set the URL of the page or file to download.
*/
curl_setopt($ch, CURLOPT_URL, 'http://domain.com/feed.xml');
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
$xml = curl_exec ($ch);
curl_close ($ch);
if (@simplexml_load_string($xml)) {
    /**
    * Create a new file
    */
    $fp = fopen('feed.xml', 'w');
    fwrite($fp, $xml);
    fclose($fp);
}

?>

他のヒント

これはどう?あなただけのドキュメントを取得する必要がある場合にはカールを使用する必要はありません。

$feed = simplexml_load_file('http://domain.com/feed.xml');

if ($feed)
{
    // $feed is valid, save it
    $feed->asXML('feed.xml');
}
elseif (file_exists('feed.xml'))
{
    // $feed is not valid, grab the last backup
    $feed = simplexml_load_file('feed.xml');
}
else
{
    die('No available feed');
}

私は一緒に入れ、クラスでは、私はそれがタイムリーに対応していますならば、リモートファイルが存在するかどうかをチェックする機能を持っています

/**
* Check to see if remote feed exists and responding in a timely manner
*/
private function remote_file_exists($url) {
  $ret = false;
  $ch = curl_init($url);

  curl_setopt($ch, CURLOPT_NOBODY, true); // check the connection; return no content
  curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 1); // timeout after 1 second
  curl_setopt($ch, CURLOPT_TIMEOUT, 2); // The maximum number of seconds to allow cURL functions to execute.
  curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (Windows; U; Windows NT 6.0; da; rv:1.9.0.11) Gecko/2009060215 Firefox/3.0.11');

  // do request
  $result = curl_exec($ch);

  // if request is successful
  if ($result === true) {
    $statusCode = curl_getinfo($ch, CURLINFO_HTTP_CODE);
    if ($statusCode === 200) {
      $ret = true;
    }
  }
  curl_close($ch);

  return $ret;
}

完全なクラスは、私たちは常にで動作するように何かを持っていることを確認するためにフォールバック・コードが含まれています。

完全なクラスを説明する

ブログ記事はこちらです:ます。http:// weedygarden.net/2012/04/simple-feed-caching-with-php/する

コードはここにある: https://github.com/erunyon/FeedCacheする

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top