私はnode.jsプロキシサーバーを作成しました(githubのここにあります)
問題は、connect.bodyParser がうまく機能しないことです。このプロジェクトのために、私は独自の bodyParser を作成しました (ファイル 'server' を参照)。要するに、私は今次のようなものを持っています:
app.use(connect.bodyParser())
.use(connect.query())
.use(serveFromDB)
.use(actAsProxyServer)
.use(cacheContent)
.use(function(err, req, res, next) {
console.log("ERROR: " + JSON.stringify(err)) ;
console.log("URL=" + req.url) ;
console.dir(req.headers) ;
res.setHeader('Content-Type', 'application/json');
res.end(JSON.stringify(err));
}) ;
エラー関数からの出力は次のとおりです。
ERROR: {"status":400}
URL=/Client/rest/cache/Clients/user123/X7X1
{ host: 'localhost:8000',
connection: 'keep-alive',
'x-requested-with': 'XMLHttpRequest',
'user-agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_7_5) AppleWebKit/537.11 (KHTML, like Gecko) Chrome/23.0.1271.64 Safari/537.11',
'content-type': 'application/json; charset=utf-8',
accept: 'application/json, text/javascript, */*; q=0.01',
referer: 'http://localhost:8000/Client/index.jsp?cache=true',
'accept-encoding': 'gzip,deflate,sdch',
'accept-language': 'en-US,en;q=0.8',
'accept-charset': 'ISO-8859-1,utf-8;q=0.7,*;q=0.3',
cookie: 'JSESSIONID=d1cbd411e30bcfb759e29585ee23' }
この GET リクエストが行う唯一のことは、(パラメーターなしで) その URL を呼び出すことです。
bodyParserがこの GET リクエストでエラーをスローする理由はありますか?
乾杯
更新: bodyParser hereのコードを見つけました。json.js では、空の文字列 (本文がないため) を json に変換しようとしているため、最終的にエラーがスローされます。bodyParser は POST リクエスト専用ですが!!
UPDATE1: 問題が見つかりました: https://github.com/documentcloud/backbone/pull/267 GET リクエストにコンテンツ タイプがあると思います