SimplePie is a very fast and easy-to-use class, written in PHP, that puts the 'simple' back into 'really simple syndication'. Flexible enough to suit beginners and veterans alike, SimplePie is focused on speed, ease of use, compatibility and standards compliance.
- PHP 7.2+ (Required since SimplePie 1.8.0)
- libxml2 (certain 2.7.x releases are too buggy for words, and will crash)
- One of iconv, mbstring or intl extensions
- Optionally, intl extension, symfony/polyfill-intl-idn or cURL extension built with IDN support to support IDNs
- cURL or fsockopen()
- PCRE support
Since SimplePie 1.9.0 you can use a PSR-18 HTTP client like Guzzle
or every other implementation.
Please note that you would also need PSR-17 implementations of RequestFactoryInterface
and an UriFactoryInterface
implementation.
$simplepie = new \SimplePie\SimplePie();
$simplepie->set_http_client(
new \GuzzleHttp\Client(),
new \GuzzleHttp\Psr7\HttpFactory(),
new \GuzzleHttp\Psr7\HttpFactory(),
);
Since SimplePie 1.8.0 you can use the PSR-16 cache from Symfony or every other implementation.
$simplepie = new \SimplePie\SimplePie();
$simplepie->set_cache(
new \Symfony\Component\Cache\Psr16Cache(
new \Symfony\Component\Cache\Adapter\FilesystemAdapter()
),
);
src/
- SimplePie classes for use with the autoloaderautoloader.php
- The SimplePie Autoloader if you want to use the separate file version.README.markdown
- This document.LICENSES/BSD-3-Clause.txt
- A copy of the BSD license.compatibility_test/
- The SimplePie compatibility test that checks your server for required settings.demo/
- A basic feed reader demo that shows off some of SimplePie's more noticeable features.build/
- Scripts related to generating pieces of SimplePietest/
- SimplePie's unit test suite.
Since SimplePie 1.3, we've split the classes into separate files to make it easier to maintain and use.
If you'd like a single monolithic file, see the assets in the
releases, or you can
run php build/compile.php
to generate SimplePie.compiled.php
yourself.
- Upload this package to your webserver.
- Make sure that the cache folder inside of the demo folder is server-writable.
- Navigate your browser to the demo folder.
For further setup and install documentation, function references, etc., visit the wiki. If you're using the latest version off GitHub, you can also check out the API documentation.
If you can't find an answer to your question in the documentation, head on over to one of our support channels. For bug reports and feature requests, visit the issue tracker.
SimplePie is currently maintained by Malcolm Blaney.
As an open source project, SimplePie is maintained on a somewhat sporadic basis. This means that feature requests may not be fulfilled straight away, as time has to be prioritized.
If you'd like to contribute to SimplePie, the best way to get started is to fork the project on GitHub and send pull requests for patches. When doing so, please be aware of our coding standards.
The main development for the next minor release happens in master
branch.
Please create your pull requests primarily against this branch.
We do not actively provide bug fixes or security fixes for older versions. Nevertheless, you are welcome to create backport PRs if you still need support for older PHP versions. Please open your PR against the appropriate branch.
branch | requires |
---|---|
master | PHP 7.2.0+ |
one-dot-seven | PHP 5.6.0+ |
one-dot-three | PHP 5.2.0+ |
- Malcolm Blaney (Maintainer, support)
- Ryan McCue (developer, support)
- Ryan Parman (Creator, developer, evangelism, support)
- Sam Sneddon (Lead developer)
- Michael Shipley (Submitter of patches, support)
- Steve Minutillo (Submitter of patches)
For a complete list of contributors:
- Pull down the latest SimplePie code
- In the
simplepie
directory, rungit shortlog -ns