Nodejs讀取本地json文件,輸出json數(shù)據(jù)接口方式
Nodejs讀取本地json文件,輸出json數(shù)據(jù)接口
第一步:準(zhǔn)備本地JSON文件
F:\nodejs\data\test.json
{
? ? "code": 0,
? ? "msg": "請求成功",
? ? "data": [
? ? ? ? {
? ? ? ? ? ? "name": "zhangsan",
? ? ? ? ? ? "age": 50
? ? ? ? },
? ? ? ? {
? ? ? ? ? ? "name": "lisi",
? ? ? ? ? ? "age": 32
? ? ? ? },
? ? ? ? {
? ? ? ? ? ? "name": "wangwu",
? ? ? ? ? ? "age": 17
? ? ? ? }
? ? ]
}第二步:編寫nodejs服務(wù)程序
F:\nodejs\express.js
var express = require('express'); //express框架模塊
var path = require('path'); //系統(tǒng)路徑模塊
var fs = require('fs'); //文件模塊
var bodyParser = require('body-parser'); //對post請求的請求體進(jìn)行解析模塊
var app = express();
app.use(bodyParser.urlencoded({ extended: false })); //bodyParser.urlencoded 用來解析request中body的 urlencoded字符,只支持utf-8的編碼的字符,也支持自動的解析gzip和 zlib。返回的對象是一個鍵值對,當(dāng)extended為false的時候,鍵值對中的值就為'String'或'Array'形式,為true的時候,則可為任何數(shù)據(jù)類型。
//設(shè)置允許跨域請求
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'); //自定義頭信息,表示服務(wù)端用nodejs
? ? res.header('Content-Type', 'application/json;charset=utf-8');
? ? next();
});
//創(chuàng)建get接口
app.get('/api', (req, res) => {
?? ?
?? ?//console.log(req.body); //獲取請求參數(shù)
?? ?
? ? var file = path.join(__dirname, 'data/test.json'); //文件路徑,__dirname為當(dāng)前運(yùn)行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(`服務(wù)器運(yùn)行在http://${hostName}:${port}`);
});第三步: 測試請求接口數(shù)據(jù)
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');
?
//設(shè)置跨域訪問
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');
?
//設(shè)置跨域訪問
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!'))以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
nodejs中使用archive壓縮文件的實現(xiàn)代碼
這篇文章主要介紹了nodejs中使用archive壓縮文件的實現(xiàn)代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11
nodejs中解決異步嵌套循環(huán)和循環(huán)嵌套異步的問題
本篇文章主要介紹了nodejs中解決異步嵌套循環(huán)和循環(huán)嵌套異步的問題,具有一定的參考價值,有興趣的可以了解一下2017-07-07
使用NODE.JS創(chuàng)建一個WEBSERVER(服務(wù)器)的步驟
在 node.js 中創(chuàng)建一個服務(wù)器非常簡單,只需要使用 node.js 為我們提供的 http 模塊及相關(guān) API 即可創(chuàng)建一個麻雀雖小但五臟俱全的web 服務(wù)器,相比 Java/Python/Ruby 搭建web服務(wù)器的過程簡單的很。本文簡單的講解下實現(xiàn)步驟2021-06-06
基于Alpine Linux構(gòu)建前端node-web鏡像步驟詳解
這篇文章主要為大家介紹了基于Alpine Linux構(gòu)建前端node-web鏡像步驟詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-11-11
Node.js中使用mongoose操作mongodb數(shù)據(jù)庫的方法
如何利用mongoose將數(shù)據(jù)寫入mongodb數(shù)據(jù)庫呢?操作方法很簡單,下面小編給大家分享Node.js中使用mongoose操作mongodb數(shù)據(jù)庫的方法,感興趣的朋友一起看看吧2017-09-09

