laravel-json-api

JSON API (jsonapi.org) package for Laravel applications.

Github星跟踪图

Build Status

cloudcreativity/laravel-json-api

Build feature-rich and standards-compliant APIs in Laravel.

This package provides all the capabilities you need to add JSON API
compliant APIs to your application. Extensive support for the specification, including:

  • Fetching resources
  • Fetching relationships
  • Inclusion of related resources (compound documents)
  • Sparse fieldsets.
  • Sorting.
  • Pagination.
  • Filtering
  • Creating resources.
  • Updating resources.
  • Updating relationships.
  • Deleting resources.
  • Validation of:
    • JSON API documents; and
    • Query parameters.

The following additional features are also supported:

  • Full support for Eloquent resources, with features such as:
    • Automatic eager loading when including related resources.
    • Easy relationship end-points.
    • Soft-deleting and restoring Eloquent resources.
    • Page and cursor based pagination.
  • Asynchronous processing.
  • Support multiple media-types within your API.
  • Generators for all the classes you need to add a resource to your API.

What is JSON API?

From jsonapi.org

If you've ever argued with your team about the way your JSON responses should be formatted, JSON API is your
anti-bikeshedding weapon.

By following shared conventions, you can increase productivity, take advantage of generalized tooling, and focus
on what matters: your application. Clients built around JSON API are able to take advantage of its features around
efficiently caching responses, sometimes eliminating network requests entirely.

For full information on the spec, plus examples, see http://jsonapi.org.

Tutorial and Documentation

Want a tutorial to get started? Read the
How to JSON:API Laravel tutorial.

Full package documentation is available on
Read the Docs.

Demo

A demo application is available at here.

Laravel Versions, Laravel, This Package, ---, ---, ^6.0, ^1.4, 5.8.*, ^1.0, 5.7.*, ^1.0, 5.6.*, ^1.0, 5.5.*, ^1.0, Make sure you consult the Upgrade Guide

when upgrading between major or pre-release versions.

You may notice that there are 2.0.0-alpha tags. We do not recommend using these versions
until we hit beta releases.

Lumen

Currently we have not integrated the package with Lumen. We do not have any active projects that use Lumen,
so if you do and can help, please let us know on
this issue.

License

Apache License (Version 2.0). Please see License File for more information.

Installation

Installation is via composer. See the documentation for complete instructions.

Contributing

Contributions are absolutely welcome. Ideally submit a pull request, even more ideally with unit tests.
Please note the following:

  • Bug Fixes - submit a pull request against the master branch.
  • Enhancements / New Features - submit a pull request against the develop branch.

We recommend submitting an issue before taking the time to put together a pull request.

主要指标

概览
名称与所有者cloudcreativity/laravel-json-api
主编程语言PHP
编程语言PHP (语言数: 1)
平台
许可证Apache License 2.0
所有者活动
创建于2015-09-08 23:16:13
推送于2025-03-21 21:32:17
最后一次提交
发布数81
最新版本名称v7.2.0 (发布于 2025-03-21 21:22:20)
第一版名称v0.1.0 (发布于 )
用户参与
星数785
关注者数29
派生数107
提交数1k
已启用问题?
问题数542
打开的问题数26
拉请求数87
打开的拉请求数0
关闭的拉请求数22
项目设置
已启用Wiki?
已存档?
是复刻?
已锁定?
是镜像?
是私有?