peeto/feeds

Laravel 5 对 SimplePie 库的 Service Provider

v1.1.4.2beta 2018-02-08 03:07 UTC

This package is auto-updated.

Last update: 2024-09-21 07:11:29 UTC


README

Latest Stable Version SensioLabsInsight License

Total Downloads Monthly Downloads Daily Downloads

一个简单的Laravel 5 服务提供者,用于包含SimplePie 库。

安装

您可以通过在项目中的 composer.json 中要求 willvincent/feeds 包来通过 Composer 安装 Laravel 5 Feeds 服务提供者。

{
    "require": {
        "willvincent/feeds": "1.1.*"
    }
}

配置

如果您正在使用 Laravel 5.5,您可以跳过下一步。

要使用 Feeds 服务提供者,您必须在引导 Laravel 应用程序时注册提供者。

在您的 config/app.php 中找到 providers 键并注册服务提供者。

    'providers' => [
        // ...
        willvincent\Feeds\FeedsServiceProvider::class,
    ],

在您的 config/app.php 中找到 aliases 键并注册外观。

    'aliases' => [
        // ...
        'Feeds'    => willvincent\Feeds\Facades\FeedsFacade::class,
    ],

用法

运行 php artisan vendor:publish --provider="willvincent\Feeds\FeedsServiceProvider" 来发布默认配置文件,根据需要编辑 config/feeds.php 文件中的缓存设置。

有关完整 API 用法文档,请参阅SimplePie 文档

make() 接受 3 个参数,第一个参数是订阅 URL 的数组,第二个参数是每个订阅返回的最大项目数,第三个参数是一个布尔值,您可以将其设置为强制读取,除非内容类型不是有效的 RSS。

$feed = Feeds::make('http://feed/url/goes/here');
注意:在 Laravel 5 中,外观必须以反斜杠开头,或者通过 use [facadeName] 声明引入作用域。

示例控制器方法和相关视图

控制器

  public function demo() {
    $feed = Feeds::make('http://blog.case.edu/news/feed.atom');
    $data = array(
      'title'     => $feed->get_title(),
      'permalink' => $feed->get_permalink(),
      'items'     => $feed->get_items(),
    );

    return View::make('feed', $data);
  }

或强制读取,除非内容类型不是有效的 RSS

  public function demo() {
    $feed = Feeds::make('http://blog.case.edu/news/feed.atom', true); // if RSS Feed has invalid mime types, force to read
    $data = array(
      'title'     => $feed->get_title(),
      'permalink' => $feed->get_permalink(),
      'items'     => $feed->get_items(),
    );

    return View::make('feed', $data);
  }

多订阅示例控制器方法和相关视图

控制器

  public function demo() {
    $feed = Feeds::make([
        'http://blog.case.edu/news/feed.atom',
        'http://tutorialslodge.com/feed'
    ], 5);
    $data = array(
      'title'     => $feed->get_title(),
      'permalink' => $feed->get_permalink(),
      'items'     => $feed->get_items(),
    );

    return View::make('feed', $data);
  }

或强制读取,除非内容类型不是有效的 RSS

  public function demo() {
        $feed = Feeds::make(['http://blog.case.edu/news/feed.atom',
        'http://tutorialslodge.com/feed'
    ], 5, true); // if RSS Feed has invalid mime types, force to read
    $data = array(
      'title'     => $feed->get_title(),
      'permalink' => $feed->get_permalink(),
      'items'     => $feed->get_items(),
    );

    return View::make('feed', $data);
  }

视图

@extends('app')

@section('content')
  <div class="header">
    <h1><a href="{{ $permalink }}">{{ $title }}</a></h1>
  </div>

  @foreach ($items as $item)
    <div class="item">
      <h2><a href="{{ $item->get_permalink() }}">{{ $item->get_title() }}</a></h2>
      <p>{{ $item->get_description() }}</p>
      <p><small>Posted on {{ $item->get_date('j F Y | g:i a') }}</small></p>
    </div>
  @endforeach
@endsection