缓存外部xmlfeeds的最佳实践



我有几个(24)外部xmlfeed在我的首页上显示产品。有关提要的详细信息,请参阅此stackoverflow问题。每个提要显示一个产品,但每次有人访问我的网站时加载这些提要需要很长时间。提要每天更新一次。

缓存这些提要的最佳方式是什么?我应该用mysql做点什么还是在本地保存xml文件。我不知道从哪里开始。我试过JG_Cache,但没有成功。

这是我使用的循环:

<?php
    // get xml file contents
    $xmlurl = get_post_meta( get_the_ID( ), 'plus_xmlfeed', true );
    if ( !empty( $xmlurl ) ){
    $xml = simplexml_load_file($xmlurl);
    }
    $xml->product->name = substr($xml->product->name, 0, 30).'...';
    $desc = substr($xml->product->name, 0, 50).'';
?>
    <li class="span3">
      <div class="thumbnail">
      <a href="<?php echo $xml->product->productURL ;?>">
          <center><img src="<?php echo get_template_directory_uri(); ?>/img/logos/<?php echo get_post_meta(get_the_ID( ), 'plus_logos', true); ?>.gif"/></center>
          <center><img class="mainimg" alt="" src="<?php echo $xml->product->imageURL ;?>"/></center>
        </a>
        <div class="caption">
          <h5><a href="<?php echo $xml->product->productURL ;?>"><?php echo $xml->product->name; ?></a></h5>
          <div class="maindesc half clearfix"><div class="prijs">&euro; <?php echo $xml->product->price ;?></div><strike style="color: rgb(248, 148, 6);">
            <?php
            foreach ($xml->product->additional->field as $field) {
                               switch((string) $field['name']) {
                                   case 'price_advice':
                                      echo '&euro; ' .$field. '';
                                      break;
                                   case 'fromPrice':
                                      echo '&euro; ' .$field. '';
                                      break;
                                   case 'oldPrice':
                                      echo '&euro; ' .$field. '';
                                      break;
                                   case 'from_price':
                                      echo '&euro; ' .$field. '';
                                      break;
                                   case 'adviesprijs':
                                      echo '&euro; ' .$field. '';
                                      break;
                                   case 'advice_price':
                                      echo '&euro; ' .$field. '';
                                      break;
                                   case 'Fromprice':
                                      echo '&euro; ' .$field. '';
                                      break;
                                   case 'recommendedPrice':
                                      echo '&euro; ' .$field. '';
                                      break;
                                    }
                                }
            ?>
            </strike>
          <p style="color: rgb(153, 153, 153);"><?php echo $desc; ?></p></div>
          <div class="btn-group bot"><div class="pull-right"> </div><a class="btn btn-primary" href="<?php echo $xml->product->productURL ;?>">Kopen</a> <a class="btn" href="#<?php echo 'modal_'.get_the_ID();?>">Info</a></div>
        </div>
      </div>
    </li>
<?php /*end loop*/ ?>

要回答您的即时问题,请考虑以下伪代码:

  1. 检查是否存在包含xml内容的本地文件。类似/home/db/tempfiles/feed_name_current_date.xml

  2. 如果使用步骤1中的构造找不到匹配的本地本地文件,那么像现在一样加载xml

  3. 从URL加载xml后,使用带有feed_namecurrent_date的命名空间结构保存内容,因此当发出新请求时,步骤1将返回本地文件

不过,我很好奇,如果它是一个xml提要,您是否不想将数据存储在本地系统中?你如何跟踪购买情况等?

最新更新