node.js读取文件和写文件的方法分别是什么(Nodejs读取本地json文件,输出json数据接口方式)
导读: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版权声明:以上内容作者已申请原创保护,未经允许不得转载,侵权必究!授权事宜、对本内容有异议或投诉,敬请联系网站管理员,我们将尽快回复您,谢谢合作!