mirror of
https://github.com/typicode/json-server.git
synced 2025-07-30 05:31:41 +08:00
468 lines
11 KiB
Markdown
468 lines
11 KiB
Markdown
# JSON Server [](https://travis-ci.org/typicode/json-server) [](http://badge.fury.io/js/json-server) [](https://gitter.im/typicode/json-server?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
|
|
|
|
Get a full fake REST API with __zero coding__ in __less than 30 seconds__ (seriously)
|
|
|
|
Created with <3 for front-end developers who need a quick back-end for prototyping and mocking.
|
|
|
|
* [Egghead.io free video tutorial - Creating demo APIs with json-server](https://egghead.io/lessons/nodejs-creating-demo-apis-with-json-server)
|
|
* [JSONPlaceholder - Live running version](http://jsonplaceholder.typicode.com)
|
|
|
|
See also:
|
|
* :hotel: [hotel - Get local domains in seconds](https://github.com/typicode/hotel)
|
|
* :dog: [husky - Git hooks made easy](https://github.com/typicode/husky)
|
|
|
|
## Example
|
|
|
|
Create a `db.json` file
|
|
|
|
```json
|
|
{
|
|
"posts": [
|
|
{ "id": 1, "title": "json-server", "author": "typicode" }
|
|
],
|
|
"comments": [
|
|
{ "id": 1, "body": "some comment", "postId": 1 }
|
|
],
|
|
"profile": { "name": "typicode" }
|
|
}
|
|
```
|
|
|
|
Start JSON Server
|
|
|
|
```bash
|
|
$ json-server --watch db.json
|
|
```
|
|
|
|
Now if you go to [http://localhost:3000/posts/1](), you'll get
|
|
|
|
```json
|
|
{ "id": 1, "title": "json-server", "author": "typicode" }
|
|
```
|
|
|
|
Also when doing requests, its good to know that
|
|
- If you make POST, PUT, PATCH or DELETE requests, changes will be automatically and safely saved to `db.json` using [lowdb](https://github.com/typicode/lowdb).
|
|
- Your request body JSON should be object enclosed, just like the GET output. (for example `{"name": "Foobar"}`)
|
|
- Id values are not mutable. Any `id` value in the body of your PUT or PATCH request wil be ignored. Only a value set in a POST request wil be respected, but only if not already taken.
|
|
- A POST, PUT or PATCH request should include a `Content-Type: application/json` header to use the JSON in the request body. Otherwise it will result in a 200 OK but without changes being made to the data.
|
|
|
|
## Install
|
|
|
|
```bash
|
|
$ npm install -g json-server
|
|
```
|
|
|
|
## Routes
|
|
|
|
Based on the previous `db.json` file, here are all the default routes. You can also add [other routes](#add-routes) using `--routes`.
|
|
|
|
### Plural routes
|
|
|
|
```
|
|
GET /posts
|
|
GET /posts/1
|
|
POST /posts
|
|
PUT /posts/1
|
|
PATCH /posts/1
|
|
DELETE /posts/1
|
|
```
|
|
|
|
### Singular routes
|
|
|
|
```
|
|
GET /profile
|
|
POST /profile
|
|
PUT /profile
|
|
PATCH /profile
|
|
```
|
|
|
|
### Filter
|
|
|
|
Use `.` to access deep properties
|
|
|
|
```
|
|
GET /posts?title=json-server&author=typicode
|
|
GET /posts?id=1&id=2
|
|
GET /comments?author.name=typicode
|
|
```
|
|
|
|
### Paginate
|
|
|
|
Add `_page` and in the `Link` header you'll get `first`, `prev`, `next` and `last` links
|
|
|
|
```
|
|
GET /posts?_page=7
|
|
```
|
|
|
|
_10 items are returned by default_
|
|
|
|
### Sort
|
|
|
|
Add `_sort` and `_order` (ascending order by default)
|
|
|
|
```
|
|
GET /posts?_sort=views&_order=DESC
|
|
GET /posts/1/comments?_sort=votes&_order=ASC
|
|
```
|
|
|
|
### Slice
|
|
|
|
Add `_start` and `_end` or `_limit` (an `X-Total-Count` header is included in the response)
|
|
|
|
```
|
|
GET /posts?_start=20&_end=30
|
|
GET /posts/1/comments?_start=20&_end=30
|
|
GET /posts/1/comments?_start=20&_limit=10
|
|
```
|
|
|
|
### Operators
|
|
|
|
Add `_gte` or `_lte` for getting a range
|
|
|
|
```
|
|
GET /posts?views_gte=10&views_lte=20
|
|
```
|
|
|
|
Add `_ne` to exclude a value
|
|
|
|
```
|
|
GET /posts?id_ne=1
|
|
```
|
|
|
|
Add `_like` to filter (RegExp supported)
|
|
|
|
```
|
|
GET /posts?title_like=server
|
|
```
|
|
|
|
### Full-text search
|
|
|
|
Add `q`
|
|
|
|
```
|
|
GET /posts?q=internet
|
|
```
|
|
|
|
### Relationships
|
|
|
|
To include children resources, add `_embed`
|
|
|
|
```
|
|
GET /posts?_embed=comments
|
|
GET /posts/1?_embed=comments
|
|
```
|
|
|
|
To include parent resource, add `_expand`
|
|
|
|
```
|
|
GET /comments?_expand=post
|
|
GET /comments/1?_expand=post
|
|
```
|
|
|
|
To get or create nested resources (by default one level, [add routes](#add-routes) for more)
|
|
|
|
```
|
|
GET /posts/1/comments
|
|
POST /posts/1/comments
|
|
```
|
|
|
|
### Database
|
|
|
|
```
|
|
GET /db
|
|
```
|
|
|
|
### Homepage
|
|
|
|
Returns default index file or serves `./public` directory
|
|
|
|
```
|
|
GET /
|
|
```
|
|
|
|
## Extras
|
|
|
|
### Static file server
|
|
|
|
You can use JSON Server to serve your HTML, JS and CSS, simply create a `./public` directory
|
|
or use `--static`.
|
|
|
|
```bash
|
|
mkdir public
|
|
echo 'hello world' > public/index.html
|
|
json-server db.json
|
|
```
|
|
|
|
```bash
|
|
json-server db.json --static ./static
|
|
```
|
|
|
|
### Alternative port
|
|
|
|
You can start JSON Server on other ports with the `--port` flag:
|
|
|
|
```bash
|
|
$ json-server --watch db.json --port 3004
|
|
```
|
|
|
|
### Access from anywhere
|
|
|
|
You can access your fake API from anywhere using CORS and JSONP.
|
|
|
|
### Remote schema
|
|
|
|
You can load remote schemas.
|
|
|
|
```bash
|
|
$ json-server http://example.com/file.json
|
|
$ json-server http://jsonplaceholder.typicode.com/db
|
|
```
|
|
|
|
### Generate random data
|
|
|
|
Using JS instead of a JSON file, you can create data programmatically.
|
|
|
|
```javascript
|
|
// index.js
|
|
module.exports = function() {
|
|
var data = { users: [] }
|
|
// Create 1000 users
|
|
for (var i = 0; i < 1000; i++) {
|
|
data.users.push({ id: i, name: 'user' + i })
|
|
}
|
|
return data
|
|
}
|
|
```
|
|
|
|
```bash
|
|
$ json-server index.js
|
|
```
|
|
|
|
__Tip__ use modules like [faker](https://github.com/Marak/faker.js), [casual](https://github.com/boo1ean/casual) or [chance](https://github.com/victorquinn/chancejs).
|
|
|
|
### Add routes
|
|
|
|
Create a `routes.json` file. Pay attention to start every route with /.
|
|
|
|
```json
|
|
{
|
|
"/api/": "/",
|
|
"/blog/:resource/:id/show": "/:resource/:id"
|
|
}
|
|
```
|
|
|
|
Start JSON Server with `--routes` option.
|
|
|
|
```bash
|
|
json-server db.json --routes routes.json
|
|
```
|
|
|
|
Now you can access resources using additional routes.
|
|
|
|
```bash
|
|
/api/posts
|
|
/api/posts/1
|
|
/blog/posts/1/show
|
|
```
|
|
|
|
### Add middlewares
|
|
|
|
You can add your middlewares from the CLI using `--middlewares` option:
|
|
|
|
```js
|
|
// first.js
|
|
module.exports = function (req, res, next) {
|
|
res.Header('X-Hello', 'World')
|
|
}
|
|
```
|
|
|
|
```bash
|
|
json-server db.json --middlewares ./hello.js
|
|
json-server db.json --middlewares ./first.js ./second.js
|
|
```
|
|
|
|
### CLI usage
|
|
|
|
```
|
|
json-server [options] <source>
|
|
|
|
Options:
|
|
--config, -c Path to config file [default: "json-server.json"]
|
|
--port, -p Set port [default: 3000]
|
|
--host, -H Set host [default: "0.0.0.0"]
|
|
--watch, -w Watch file(s) [boolean]
|
|
--routes, -r Path to routes file
|
|
--middlewares, -m Paths to middleware files [array]
|
|
--static, -s Set static files directory
|
|
--read-only, --ro Allow only GET requests [boolean]
|
|
--no-cors, --nc Disable Cross-Origin Resource Sharing [boolean]
|
|
--no-gzip, --ng Disable GZIP Content-Encoding [boolean]
|
|
--snapshots, -S Set snapshots directory [default: "."]
|
|
--delay, -d Add delay to responses (ms)
|
|
--id, -i Set database id property (e.g. _id) [default: "id"]
|
|
--quiet, -q Suppress log messages from output [boolean]
|
|
--help, -h Show help [boolean]
|
|
--version, -v Show version number [boolean]
|
|
|
|
Examples:
|
|
json-server db.json
|
|
json-server file.js
|
|
json-server http://example.com/db.json
|
|
|
|
https://github.com/typicode/json-server
|
|
```
|
|
|
|
You can also set options in a `json-server.json` configuration file.
|
|
|
|
```json
|
|
{
|
|
"port": 3000
|
|
}
|
|
```
|
|
|
|
### Module
|
|
|
|
If you need to add authentication, validation, or __any behavior__, you can use the project as a module in combination with other Express middlewares.
|
|
|
|
#### Simple example
|
|
|
|
```js
|
|
// server.js
|
|
var jsonServer = require('json-server')
|
|
var server = jsonServer.create()
|
|
var router = jsonServer.router('db.json')
|
|
var middlewares = jsonServer.defaults()
|
|
|
|
server.use(middlewares)
|
|
server.use(router)
|
|
server.listen(3000, function () {
|
|
console.log('JSON Server is running')
|
|
})
|
|
```
|
|
|
|
```sh
|
|
$ node server.js
|
|
```
|
|
|
|
For an in-memory database, you can pass an object to `jsonServer.router()`.
|
|
Please note also that `jsonServer.router()` can be used in existing Express projects.
|
|
|
|
#### Custom routes example
|
|
|
|
Let's say you want a route that echoes query parameters and another one that set a timestamp on every resource created.
|
|
|
|
```js
|
|
var jsonServer = require('json-server')
|
|
var server = jsonServer.create()
|
|
var router = jsonServer.router('db.json')
|
|
var middlewares = jsonServer.defaults()
|
|
|
|
// Set default middlewares (logger, static, cors and no-cache)
|
|
server.use(middlewares)
|
|
|
|
// Add custom routes before JSON Server router
|
|
server.get('/echo', function (req, res) {
|
|
res.jsonp(req.query)
|
|
})
|
|
|
|
// To handle POST, PUT and PATCH you need to use a body-parser
|
|
// You can use the one used by JSON Server
|
|
server.use(jsonServer.bodyParser)
|
|
server.use(function (req, res, next) {
|
|
if (req.method === 'POST') {
|
|
req.body.createdAt = Date.now()
|
|
}
|
|
// Continue to JSON Server router
|
|
next()
|
|
})
|
|
|
|
// Use default router
|
|
server.use(router)
|
|
server.listen(3000, function () {
|
|
console.log('JSON Server is running')
|
|
})
|
|
```
|
|
|
|
#### Access control example
|
|
|
|
```js
|
|
var jsonServer = require('json-server')
|
|
var server = jsonServer.create()
|
|
var router = jsonServer.router('db.json')
|
|
var middlewares = jsonServer.defaults()
|
|
|
|
server.use(middlewares)
|
|
server.use(function (req, res, next) {
|
|
if (isAuthorized(req)) { // add your authorization logic here
|
|
next() // continue to JSON Server router
|
|
} else {
|
|
res.sendStatus(401)
|
|
}
|
|
})
|
|
server.use(router)
|
|
server.listen(3000, function () {
|
|
console.log('JSON Server is running')
|
|
})
|
|
```
|
|
|
|
#### Custom output example
|
|
|
|
To modify responses, overwrite `router.render` method:
|
|
|
|
```javascript
|
|
// In this example, returned resources will be wrapped in a body property
|
|
router.render = function (req, res) {
|
|
res.jsonp({
|
|
body: res.locals.data
|
|
})
|
|
}
|
|
```
|
|
|
|
#### Rewriter example
|
|
|
|
To add rewrite rules, use `jsonServer.rewriter()`:
|
|
|
|
```javascript
|
|
// Add this before server.use(router)
|
|
server.use(jsonServer.rewriter({
|
|
'/api/': '/',
|
|
'/blog/:resource/:id/show': '/:resource/:id'
|
|
}))
|
|
```
|
|
|
|
#### Mounting JSON Server on another endpoint example
|
|
|
|
Alternatively, you can also mount the router on `/api`.
|
|
|
|
```javascript
|
|
server.use('/api', router)
|
|
```
|
|
|
|
### Deployment
|
|
|
|
You can deploy JSON Server. For example, [JSONPlaceholder](http://jsonplaceholder.typicode.com) is an online fake API powered by JSON Server and running on Heroku.
|
|
|
|
## Links
|
|
|
|
### Video
|
|
|
|
* [Creating Demo APIs with json-server on egghead.io](https://egghead.io/lessons/nodejs-creating-demo-apis-with-json-server)
|
|
|
|
### Articles
|
|
|
|
* [Node Module Of The Week - json-server](http://nmotw.in/json-server/)
|
|
* [Mock up your REST API with JSON Server](http://www.betterpixels.co.uk/projects/2015/05/09/mock-up-your-rest-api-with-json-server/)
|
|
* [ng-admin: Add an AngularJS admin GUI to any RESTful API](http://marmelab.com/blog/2014/09/15/easy-backend-for-your-restful-api.html)
|
|
* [Fast prototyping using Restangular and Json-server](http://glebbahmutov.com/blog/fast-prototyping-using-restangular-and-json-server/)
|
|
* [Create a Mock REST API in Seconds for Prototyping your Frontend](https://coligo.io/create-mock-rest-api-with-json-server/)
|
|
|
|
### Third-party tools
|
|
|
|
* [Grunt JSON Server](https://github.com/tfiwm/grunt-json-server)
|
|
* [Docker JSON Server](https://github.com/clue/docker-json-server)
|
|
* [JSON Server GUI](https://github.com/naholyr/json-server-gui)
|
|
* [JSON file generator](https://github.com/dfsq/json-server-init)
|
|
|
|
## License
|
|
|
|
MIT - [Typicode](https://github.com/typicode)
|