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)前運行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ù)器運行在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-11nodejs中解決異步嵌套循環(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-11Node.js中使用mongoose操作mongodb數(shù)據(jù)庫的方法
如何利用mongoose將數(shù)據(jù)寫入mongodb數(shù)據(jù)庫呢?操作方法很簡單,下面小編給大家分享Node.js中使用mongoose操作mongodb數(shù)據(jù)庫的方法,感興趣的朋友一起看看吧2017-09-09