[nodejs]读取本地json文件,输出json api

本地测试用,提高效率。

1安装环境

npm install express
npm install body-parser

2test.json文件

{
    "code"200,
    "msg""请求成功",
    "data": [
        {
            "name""name01",
            "age"50
        },
        {
            "name""name02",
            "age"32
        },
        {
            "name""name03",
            "age"17
        }
    ]
}

3express.js

let express = require('express'); //express框架模块
let path = require('path'); //系统路径模块
let fs = require('fs'); //文件模块
let bodyParser = require('body-parser'); //对post请求的请求体进行解析模块
let app = express();
app.use(bodyParser.urlencoded({extendedfalse})); //bodyParser.urlencoded 用来解析request中body的 urlencoded字符,只支持utf-8的编码的字符,也支持自动的解析gzip和 zlib。返回的对象是一个键值对,当extended为false的时候,键值对中的值就为'String'或'Array'形式,为true的时候,则可为任何数据类型。

//设置允许跨域请求
app.all('*'function (req, res, next{
    res.header('Access-Control-Allow-Origin''*'); //访问控制允许来源:所有
    res.header('Access-Control-Allow-Headers''Origin, X-Requested-With, Content-Type, Accept'); //访问控制允许报头 X-Requested-With: xhr请求
    res.header('Access-Control-Allow-Metheds''PUT, POST, GET, DELETE, OPTIONS'); //访问控制允许方法
    res.header('X-Powered-By''nodejs'); //自定义头信息,表示服务端用nodejs
    res.header('Content-Type''application/json;charset=utf-8');
    next();
});

//创建get接口
app.get('/api'function (req, res{

    //console.log(req.body); //获取请求参数

    let file = path.join(__dirname, './test.json'); //文件路径,__dirname为当前运行js文件的目录
    //let file = 'f:\nodejs\data\test.json'; //也可以用这种方式指定路径

    //读取json文件
    fs.readFile(file, 'utf-8'function (err, data{
        if (err) {
            res.send('文件读取失败');
        } else {
            res.send(data);
        }
    });
});

let hostName = '127.0.0.1'//ip
let port = 8888//端口
app.listen(port, hostName, function ({
    console.log(`服务器运行在http://${hostName}:${port}`);
});

4请求数据

$.ajax({
    url'http://127.0.0.1:8888/api',
    type'get',
    successfunction(jsonObj{
     console.log(rs);
    }
});


原文始发于微信公众号(豆子前端):[nodejs]读取本地json文件,输出json api

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/56653.html

(0)
小半的头像小半

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!