首页IT科技node.js读取文件和写文件的方法分别是什么(Nodejs读取本地json文件,输出json数据接口方式)

node.js读取文件和写文件的方法分别是什么(Nodejs读取本地json文件,输出json数据接口方式)

时间2025-08-03 08:39:23分类IT科技浏览6402
导读:Nodejs读取本地json文件,输出json数据接口 第一步:准备本地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!))

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

声明:本站所有文章                        ,如无特殊说明或标注                    ,均为本站原创发布            。任何个人或组织,在未征得本站同意时                    ,禁止复制                、盗用                        、采集        、发布本站内容到任何网站            、书籍等各类媒体平台                        。如若本站内容侵犯了原著者的合法权益                        ,可联系我们进行处理            。

创心域SEO版权声明:以上内容作者已申请原创保护,未经允许不得转载,侵权必究!授权事宜、对本内容有异议或投诉,敬请联系网站管理员,我们将尽快回复您,谢谢合作!

展开全文READ MORE
前端调用高德地图(前端加载高德离线地图的解决方案) 配置vue(vue项目配置env)