私はnodejsを私のREST apiホストとして使用しています。全体的な機能はかなり基本的です。つまり、postgresdbクエリを実行する必要があるREST呼び出しを行います。データを返します。私が抱えている問題は、全体的なコード構成です。
基本的な初期化が行われているserver.jsがあります。さて、postgres接続をどこに配置し、必要なときにいつでもデータベースにクエリを実行するために呼び出す必要があります。現在の構成は以下のとおりです。だから私はpostgres接続コードをserver.jsに移動するべきだと思いますか?正しい構造はどうあるべきか
server.js
"use strict";
var express = require('express'),
app = express(),
port = process.env.PORT || 4001,
bodyParser = require('body-parser');
app.use(bodyParser.urlencoded({ extended: true }));
app.use(bodyParser.json());
app.use(function (req, res, next) {
// Website you wish to allow to connect
res.setHeader('Access-Control-Allow-Origin', '*')
// Request methods you wish to allow
res.setHeader('Access-Control-Allow-Methods', 'GET, POST, OPTIONS, PUT, PATCH, DELETE');
// Request headers you wish to allow
res.setHeader('Access-Control-Allow-Headers', 'X-Requested-With,content-type');
// Set to true if you need the website to include cookies in the requests sent
// to the API (e.g. in case you use sessions)
res.setHeader('Access-Control-Allow-Credentials', true);
// Pass to next layer of middleware
next();
});
var routes = require('./api/routes/pushRoutes');
routes(app);
app.listen(port);
console.log('Push notification server started on: ' + port);
pushController.js
'use strict';
exports.send_notification = function(req, res) {
console.log("start of send_notification ");
if (req.method == 'POST') {
var jsonString = '';
req.on('data', function (data) {
jsonString += data;
});
req.on('end', function () {
console.log(JSON.parse(jsonString));
var json = JSON.parse(jsonString);
var timeNow = json.message;
//get device token from db
var deviceToken = '';
var pg = require('pg')
var format = require('pg-format')
var PGUSER = 'deploy'
var PGDATABASE = 'oscpushserver'
var config = {
user: PGUSER, // name of the user account
database: PGDATABASE, // name of the database
max: 10, // max number of clients in the pool
idleTimeoutMillis: 30000
}
var pool = new pg.Pool(config)
var myClient
pool.connect(function (err, client, done) {
if (err) console.log(err)
app.listen(3000, function () {
console.log('listening on 3000')
})
myClient = client
var ageQuery = format('SELECT * from Push_table WHERE seq_id = 1')
myClient.query(ageQuery, function (err, result) {
if (err) {
console.log(err)
}
console.log("row data:" + result.rows[0])
console.log("device id from db:" + result.rows[0].device_id)
deviceToken =result.rows[0].device_id;
})
});
res.json(JSON.parse(jsonString));
});
}
};
Dbからデータを取得するだけのREST api)を作成したいとします。
server.js
ルートを正しく使用していないことを除いて、ほとんどの部分で問題なく表示されます。定義したルートを使用するには、app.useを使用します。
app.use('/', routes);
database.jsデータベースの資格情報を1つの場所に配置して、新しいプールを作成できる別のファイルを作成します。
var pg = require('pg')
var PGUSER = 'deploy'
var PGDATABASE = 'oscpushserver'
var config = {
user: PGUSER, // name of the user account
database: PGDATABASE, // name of the database
max: 10, // max number of clients in the pool
idleTimeoutMillis: 30000
}
var pool = new pg.Pool(config);
module.exports = pool;
pushController
Server.jsでこのファイルが必要だと思います。したがって、パスが「./api/routes/pushRoutes」ではなく「.../pushController」を指していることを確認してください。
const express = require('express');
const router = express.Router();
const format = require('pg-format');
const pool = require('../path/to/database.js');
router.get(function(req, res, next) {
pool.connect(function (err, client, done) {
if (err) throw new Error(err);
var ageQuery = format('SELECT * from Push_table WHERE seq_id = 1')
client.query(ageQuery, function (err, result) {
if (err) throw new Error(err);
res.json(result.rows[0]);
})
});
});
module.exports = router;
したがって、APIサーバーへのGETリクエストは、postgresデータベースからjsonオブジェクトを返す必要があります。
RESTノードとpostgresを使用したAPIの作成方法については、オンラインで多数の例があります。そのうちの1つは次のとおりです。 https://github.com/mjhea0/node-postgres- todo 。