質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.45%
Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Express

ExpressはNode.jsのWebアプリケーションフレームワークです。 マルチページを構築するための機能セットおよびハイブリッドのWebアプリケーションを提供します。

Q&A

解決済

1回答

8889閲覧

nodejs+expressのAPIで発生する「Error: Can't set headers after they are sent.」エラーについて

kong

総合スコア181

Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Express

ExpressはNode.jsのWebアプリケーションフレームワークです。 マルチページを構築するための機能セットおよびハイブリッドのWebアプリケーションを提供します。

0グッド

2クリップ

投稿2017/10/23 07:48

nodejs(v6.5)+express(v4.14)の構成で、postgreSQLのデータを取得して返す、APIのサンプルを作ろうとしているのですが、上手く行きません。

以下のようなソースで、pg-promise(v7.0.2)モジュールを使用して、postgreSQLに接続しています。
db.any('select * from ・・・でクエリを投げて、 console.log(data[0]);の中身を見る限り、テーブルの値は取れています。

しかし、res.status(200)から、「Error: Can't set headers after they are sent.」が発生していて、レスポンスを返せません。

調べたところ、このエラーは既にレスポンスを投げているところに、再度レスポンスを投げようとすると発生するようですが、見た限りそのような動きが見られません。

何か原因について御存知の方がいましたら、ご教示いただけないでしょうか。
宜しくお願いします。

js

1'use strict'; 2 3/* node.jsモジュールの読み込み */ 4const express = require('express'); 5const router = express.Router(); 6const config = require('config'); 7const pgp = require('pg-promise')(); 8 9// postgreSQLの値を返すAPI 10router.get('/test', (req, res, next) => { 11 12 // postgreSqlの接続情報 13 let connection = { 14 host : 'localhost', 15 port : 5432, 16 database : 'test', 17 user : 'posgreuser', 18 password : 'pospospos' 19 }; 20 let db = pgp(connection); 21 22 23 db.any('select * from TEST_MASTER where key1= $1','aaa') 24 .then((data) => { 25 console.log(data[0]); 26 res.status(200) 27 .send(JSON.stringify({ 28 status : 'success', 29 results : data[0].key2, 30 })); 31 }) 32 .catch((e) => { 33 e.param = 'ng'; 34 next(e); 35 }) 36 .finally(() => { 37 console.log('fin'); 38 pgp.end(); // 接続プールの切断 39 }); 40}); 41 42module.exports = router; 43

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

pg-promiseのpromiseはPromises/A+でfinallyが無いので、finallyを使いたい場合はpg-promiseのサンプルの様にpromiseLibを置き換える必要があります。

js

1const promise = require('bluebird'); // or any other Promise/A+ compatible library; 2 3const initOptions = { 4 promiseLib: promise // overriding the default (ES6 Promise); 5}; 6const pgp = require('pg-promise')(initOptions);

Can't set headers after they are sent.とエラーが出るのは、finallyが存在しないのにfunctionとして使っているために、エラーを追加で出力しようとして出来なかったのでしょう。
レスポンス自体は最初のsendで完結しているはずなので、エラー出力のための送信の部分がCan't set headers after they are sent.のエラーを引き起こしています。

投稿2017/10/23 10:06

編集2017/10/23 10:18
shimitei

総合スコア799

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kong

2017/10/23 14:39

ありがとうございます、解決できました。 色んなサイト見ながらコピペで試すと、こんな事になるんですね。。 やはり英語でもオフィシャルを見て理解しないと。。 Promisesの正確な仕様や、Promises/A+等も知らなかったし、色々と勉強になりました。 本当にありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.45%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問