admin管理员组

文章数量:1345584

I have a folder of JSON files that I'd like to use to create a simple API from.

Here's a simplified version of my folder structure:

/clients.json

/clients/1/client.json

/clients/2/client.json

...

my /clients.json file looks like this:

[
    {
        "id": 1,
        "name": "Jon Parker"
    },
    {
        "id": 2,
        "name": "Gareth Edwards"
    },
    ...
]

and my /clients/1/client.json file looks like this:

[
    {
        "date": "2014-09-12",
        "score": 40,
        ...
    },
    {
        "date": "2015-02-27",
        "score": 75,
        ...
    },  
    {
        "date": "2015-05-10",
        "score": 75,
        ...
    },
    {
        "date": "2016-08-27",
        "score": 60,
        ...
    }
]

The id from clients.json relates to the folder in which the associated details are.

I have a lot of JSON files in the clients folder and rather than loading these all individually on the client side, I wanted to create an API using Node.js that gives me more flexibility, i.e...

returning a list of client names and id's /clients

returning the client details /clients/:id/details

and most importantly returning all clients with there names and associated details /clients/all/details

I did begin playing with json-server, however it requires that your JSON be an object rather than an array, and I'm stuck with the format of this JSON unfortunately.

Appreciate any help!

I have a folder of JSON files that I'd like to use to create a simple API from.

Here's a simplified version of my folder structure:

/clients.json

/clients/1/client.json

/clients/2/client.json

...

my /clients.json file looks like this:

[
    {
        "id": 1,
        "name": "Jon Parker"
    },
    {
        "id": 2,
        "name": "Gareth Edwards"
    },
    ...
]

and my /clients/1/client.json file looks like this:

[
    {
        "date": "2014-09-12",
        "score": 40,
        ...
    },
    {
        "date": "2015-02-27",
        "score": 75,
        ...
    },  
    {
        "date": "2015-05-10",
        "score": 75,
        ...
    },
    {
        "date": "2016-08-27",
        "score": 60,
        ...
    }
]

The id from clients.json relates to the folder in which the associated details are.

I have a lot of JSON files in the clients folder and rather than loading these all individually on the client side, I wanted to create an API using Node.js that gives me more flexibility, i.e...

returning a list of client names and id's /clients

returning the client details /clients/:id/details

and most importantly returning all clients with there names and associated details /clients/all/details

I did begin playing with json-server, however it requires that your JSON be an object rather than an array, and I'm stuck with the format of this JSON unfortunately.

Appreciate any help!

Share Improve this question edited Dec 29, 2016 at 14:41 tremendows 4,3823 gold badges38 silver badges55 bronze badges asked Dec 9, 2016 at 0:36 DanVDanV 3,2504 gold badges34 silver badges48 bronze badges 1
  • you can transform an array into an object after loading the data; it shouldn't take too long to do JIT, and would give you the keying your API expects. – dandavis Commented Dec 30, 2016 at 21:36
Add a ment  | 

5 Answers 5

Reset to default 4 +25

Use the built-in file system module to get files from the file system.

Refer here

Here's an example.

var fs = require('fs');

exports.getClientDetail = function (id) {
  var result;
  fs.readFile('/clients/' + id + '/client.json', function (err, data) {
    if (err) throw err;

    result.push(JSON.parse(data));
  });
}
exports.getAllClientsDetail = function () {      
  // if the id is sequential, you can check if '/clients/' + id + '/client.json' exists for every i from 1 and up.  If it does - push it to an array of objects. if for a certain i it does not exist, quit the scan and return the array of objects.
}

You can require the json directly as an object in node, something like this:

app.get('/clients/:id/details', (req, resp) => {
  const id = req.params.id;
  const data = require(`./clients/${id}/client.json`); // or whatever path
  resp.send(data)
});

You aren't nearly as stuck as you think.

You'll have to wrap your arrays in an object. Then, in the front end, you just have to access the array property.

After all, JSON is an acronym for Javascript Object Notation.

EDIT: Okay, let's try something new...

Perhaps before using code from json-server, do a little preprocessing. Assuming that variable clientJson is the file you have already read, inserting this code before you use any code from json-server:

clientJson = "{root:"+clientJson+"}";

That will wrap the file in an object with the first property being root.

After that, it's pretty easy to get your array back:

clientData = clientData.root;

You should use Read streams from FS module to send data to the client,catch possible errors and cleaning memory after send.

You could do it without any code if you uploaded your folder structure to a cloud service (ex. Amazon S3 or Dropbox) and serve them from there. No code required.

本文标签: javascriptCreate Simple Nodejs API from JSON filesStack Overflow