//server.js
var qs = require('querystring');
require('http').createServer(function(req, res){
var body = '';
req.on('data', function(chunk){
body += chunk;
});
req.on('end', function(){
res.writeHead(200);
res.end('Done');
console.log('\n got name \033[90m' + qs.parse(body).name + '\033[39m\n');
});
}).listen(3000);
//client.js
var http = require('http'), qs = require('querystring');
function send(theName){
http.request({
host: '127.0.0.1',
port: 3000,
url: '/',
method: 'POST'
}, function(res){
res.setEncoding('utf8');
//res.on('data', function(){return ;});
res.on('end', function(){
console.log('\n \033[90m request complete!\033[39m');
process.stdout.write('\n your name: ');
});
}).end(qs.stringify({name: theName}));
}
process.stdout.write('\n your name: ');
process.stdin.resume();
process.stdin.setEncoding('utf-8');
process.stdin.on('data', function(name){
send(name.replace('\n', ''));
});
-----------------------------------------------------------------------------------------------摘自《了不起的Node.js》P98 - P99
将client.js中监听data的事件注视掉的话 就不会执行end事件中的回调函数
希望能够帮忙解释一下, 谢谢.
顺便问一下 遇到这种问题应该如何解决 好让我下次能够自己解决, 谢谢.
高洛峰2017-04-17 13:52:21
我今天也遇到和題主一樣的問題。查到了你的問題突然明白了。因為在伺服器端讀取完請求資料後觸發伺服器端的end事件,於是伺服器端向客戶端發送了head和Done。因此在客戶端的流中還存在著來自伺服器端的資料沒有接收,因此是不會觸發end事件的~
你可以在end事件中
res.on('data', function(chunk){console.log(chunk)});
這樣你就會看到Done啦。接著就會觸發end事件