Nodejs读取本地json文件,输出json数据接口方式

目录
  • Nodejs读取本地json文件,输出json数据接口
    • 第一步:准备本地JSON文件
    • 第二步:编写nodejs服务程序
    • 第三步: 测试请求接口数据
  • nodejs读取本地json文件中文乱码
    • 第一种方式
    • 第二种方式

Nodejs读取本地json文件,输出json数据接口

第一步:准备本地JSON文件

F:\nodejs\data\test.json

{
    "code": 0,
    "msg": "请求成功",
    "data": [
        {
            "name": "zhangsan",
            "age": 50
        },
        {
            "name": "lisi",
            "age": 32
        },
        {
            "name": "wangwu",
            "age": 17
        }
    ]
}

第二步:编写nodejs服务程序

F:\nodejs\express.js

var express = require('express'); //express框架模块
var path = require('path'); //系统路径模块
var fs = require('fs'); //文件模块
var bodyParser = require('body-parser'); //对post请求的请求体进行解析模块
var app = express();
app.use(bodyParser.urlencoded({ extended: false })); //bodyParser.urlencoded 用来解析request中body的 urlencoded字符,只支持utf-8的编码的字符,也支持自动的解析gzip和 zlib。返回的对象是一个键值

对,当extended为false的时候,键值对中的值就为'String'或'Array'形式,为true的时候,则可为任何数据类型。

//设置允许跨域请求
app.all('*', (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', (req, res) => {
    
    //console.log(req.body); //获取请求参数
    
    var file = path.join(__dirname, 'data/test.json'); //文件路径,__dirname为当前运行js文件的目录
    //var file = 'f:\\nodejs\\data\\test.json'; //也可以用这种方式指定路径
    
    //读取json文件
    fs.readFile(file, 'utf-8', function(err, data) {
        if (err) {
            res.send('文件读取失败');
        } else {
            res.send(data);
        }
    });
});
var hostName = '127.0.0.1'; //ip
var port = 8888; //端口
app.listen(port, hostName, () => {
    console.log(`服务器运行在http://${hostName}:${port}`);
});

第三步: 测试请求接口数据

axios.get('http://127.0.0.1:8888/api')
  .then((response) => {
    console.log(response);
  })
  .catch((error) => {
    console.log(error);
  });

nodejs读取本地json文件中文乱码

npm init
npm install 
npm install express  --save

express 文件名

app.js文件中修改:

第一种方式

const express = require('express')
const app = express()
var path = require('path')
var fs = require('fs')
var iconv = require('iconv-lite');
 
//设置跨域访问
app.all('*', function(req, res, next) {
   res.header("Access-Control-Allow-Origin", "*");
   res.header("Access-Control-Allow-Headers", "X-Requested-With");
   res.header("Access-Control-Allow-Methods","PUT,POST,GET,DELETE,OPTIONS");
   res.header("X-Powered-By",' 3.2.1');
   res.header("Content-Type", "application/json;charset=utf-8");
   next();
});
 
// var questions = path.join(__dirname, './test.json')
// var questions = [
// {
//     name:'张三',
//     age:12
// },
// {
//     name:'李四',
//     age:15
// },
// {
//     name:'柠檬',
//     age:13
// }
// ]
 
app.get('/123',function(req,res){
    res.status(200);
    // res.json(questions);
    //引入外部json文件
    fs.readFile('./test.json', {encoding:'binary'}, function(err, data) {
        if (err) {
            res.send('文件读取失败');
        } else {
            // res.send(data);
            var buf = Buffer.from(data,'binary');
            var str = iconv.decode(buf, 'GBK');
            res.send(str);
        }
    });
})
 
app.get('/', (req, res) => res.send('Hello World!'))
 
app.listen(3000, () => console.log('app listening on port 3000!'))

第二种方式

const express = require('express')
const app = express()
var path = require('path')
var fs = require('fs')
var iconv = require('iconv-lite');
 
//设置跨域访问
app.all('*', function(req, res, next) {
   res.header("Access-Control-Allow-Origin", "*");
   res.header("Access-Control-Allow-Headers", "X-Requested-With");
   res.header("Access-Control-Allow-Methods","PUT,POST,GET,DELETE,OPTIONS");
   res.header("X-Powered-By",' 3.2.1');
   res.header("Content-Type", "application/json;charset=utf-8");
   next();
});
 
// var questions = path.join(__dirname, './test.json')
// var questions = [
// {
//     name:'张三',
//     age:12
// },
// {
//     name:'李四',
//     age:15
// },
// {
//     name:'柠檬',
//     age:13
// }
// ]
 
app.get('/123',function(req,res){
    res.status(200);
    // res.json(questions);
    //引入外部json文件
    fs.readFile('./test.json', 'utf-8', function(err, data) {
        if (err) {
            res.send('文件读取失败');
        } else {
            res.send(data);
        }
    });
})
 
app.get('/', (req, res) => res.send('Hello World!'))
 
app.listen(3000, () => console.log('app listening on port 3000!'))

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • 用nodejs实现json和jsonp服务的方法

    一.JSON和JSONP JSONP的全称是JSON with Padding,由于同源策略的限制,XmlHttpRequest只允许请求当前源(协议,域名,端口)的资源.如果要进行跨域请求,我们可以通过使用html的script标记来进行跨域请求,并在相应中返回要执行的script代码,其中可以直接使用JSON传递javascript对象.这种跨域的通讯方式成为JSONP. 由此我们可以看出两者的区别: json: 一种轻量级的数据格式. jsonp:为实现跨域,而采用的一种脚本注入方法. 备

  • 使用nodejs解析json数据

    目录 nodejs解析json数据 第一 第二 第三 第四 node.js解析本地json 从文件读取json 解析json字符串为json对象 扩展 nodejs解析json数据 nodejs是服务器端的javascript的处理平台.json(JavaScript Object Notation) 是一种轻量级的数据交换格式.我们在写服务端的程序时往往需要使用json来处理数据. 这里我们用一个简单的例子来演示如何用nodejs来处理json数据文件. 第一 我们需要在ubuntu14.04

  • nodejs读写json文件的简单方法(必看)

    nodejs 读json文件 var fs=reauire('fs'); var file="d:\\0.json"; var result=JSON.parse(fs.readFileSync( file)); //操作对象 nodejs 写json文件 var coors = {}; coors.left_top = {}; coors.right_top = {}; coors.left_bottom = {}; coors.right_bottom = {}; //填充coor

  • Nodejs读取本地json文件,输出json数据接口方式

    目录 Nodejs读取本地json文件,输出json数据接口 第一步:准备本地JSON文件 第二步:编写nodejs服务程序 第三步: 测试请求接口数据 nodejs读取本地json文件中文乱码 第一种方式 第二种方式 Nodejs读取本地json文件,输出json数据接口 第一步:准备本地JSON文件 F:\nodejs\data\test.json {     "code": 0,     "msg": "请求成功",     "d

  • nodejs读取本地mp3和mp4等媒体文件并播放的案例

    本文主要讲解读取本地mp3文件并播放的案例 1.fs是必不可少的文件模块 // 首先引入fs模块 const fs = require("fs") 2.使用fs读取本地媒体文件 let path = "d:\\music.mp3" // 创建流对象(方法的第一个参数是文件路径,第二个参数是流的配置,具体查看node.js文档) let rs = fs.createReadStream(path, { flags: "r", encoding: n

  • 读取本地json文件,解析json(实例讲解)

    模拟用户登录 # data.json 文件同目录下 [ { "id": 1, "username": "zhangshan", "password": "123qwe", "lock": false }, { "id": 2, "username": "lisi", "password": "123

  • python读取json文件并将数据插入到mongodb的方法

    本文实例讲述了python读取json文件并将数据插入到mongodb的方法.分享给大家供大家参考.具体实现方法如下: #coding=utf-8 import sunburnt import urllib from pymongo import Connection from bson.objectid import ObjectId import logging from datetime import datetime import json from time import mktime

  • Vue中请求本地JSON文件并返回数据的方法实例

    目录 1.目录结构 2.检查一下自己是否安装了 json-server(以下截图代表安装了) 3.安装完成以后我们就可以运行自己的json文件了 4.看看浏览器里的数据呈现效果吧 5.为了保险起见,我还特地去 postman 上测试了一下(可以省略这步) 6.现在我们可以编写代码发送请求来获取数据啦 7.在控制台就可以看到我们数据请求回来了 总结 1.目录结构 直接在根目录下创建自己的JSON文件,在此我的JSON文件名为data.json 以下是我的JSON文件内容(此处是参照的黑马程序员的v

  • 读Json文件生成pandas数据框详情

    目录 前言 records格式 index格式 columns 类型 values格式 split 参数示例 压缩与编码 前言 本文讲解如何加载json文件或字符串为pandas数据框.pandas把json数据分成几种典型类型,希望对你实际数据应用开发有所启示. 有时可能需要转换json文件位pandas数据框.使用pandas内置的read_json()函数很容易实现, 其语法如下: read_json(‘path’, orient=’index’) path: json文件的路径 orie

  • Vue中如何获取json文件中的数据

    目录 场景 实现 场景 访问百度音乐API需要传递音乐类型参数,而这些参数是存在musictype.json中, 现在在组件listcate.vue需要获取json数据. json文件内容: 文件位置: 实现 musictype.json { "currentType":[1,2,11,21,22,23,24,25] } listcate.vue <template lang="html"> <div> <ListCate_List v

  • C++读取WAV音频文件的头部数据的实现方法

    C++读取WAV音频文件的头部数据的实现方法 前言: 在这里分享一下自己的心得,希望和大家一起分享技术,如果有什么不足,还请大家指正.写出这篇目的,就是希望大家一起成长,我也相信技术之间没有高低,只有互补,只有分享,才能使彼此更加成长. 实现代码: #include <iostream> #include <string> #include <fstream> using namespace std; using std::string; using std::fstr

  • 通过Javascript读取本地Excel文件内容的代码示例

    读取本地Excel文件内容的Javascript代码: 复制代码 代码如下: <script type="text/javascript">function read_excel(){ var filePath="D:\abcd9.com.xls"; //要读取的xls    var sheet_id=2; //读取第2个表    var row_start=3; //从第3行开始读取    var tempStr='';    try{       

  • python opencv 读取本地视频文件 修改ffmpeg的方法

    Python + opencv 读取视频的三种情况: 情况一:通过摄像头采集视频 情况二:通过本地视频文件获取视频 情况三:通过摄像头录制视频,再读取录制的视频 摄像头采集.本地视频文件的读取.写视频文件,网上都有代码. 我发现情况一和情况三都没有问题,大家注意读取自己通过摄像头录制的视频文件是没有问题的.但读取其他视频都会发现帧率为0(如果你获取视频的帧率并打印出来的话),并且退出读取.这时候读取是不成功的. 进去正题:如何解决读取视频失败的情况.这个问题很普遍,以至在官方教程的程序下面都提示

随机推荐