html5 - 通过post抓取的页面数据 为啥不能展现在页面上
问题描述
这是node.js代码
var http = require('http'), fs = require('fs'), querystring = require('querystring'), url = require('url');http.createServer(function(req,res){ var postdata=''; var query='what'; var pathname = url.parse(req.url).pathname; req.setEncoding('utf8'); if(pathname=='/'){var indexPage = fs.readFileSync('表单.html');res.writeHead(200,{'Content-Type':'text/html'});res.end(indexPage); } if(pathname=='/about'){req.on('data',function(chunk){ postdata += chunk;});req.on('end',function() { console.log(postdata); query = querystring.parse(postdata); console.log(query);});res.writeHead(200, {'Content-Type':'text/plain'});console.log(query.Name);console.log(query.number);res.write(query.number+ 'and '+query.number);res.end(); } else{res.writeHead(404,{'Content-Type':'text/plain'});res.end('Can not find the source'); }}).listen(2000,'127.0.0.1');console.log('The server is running at port 2000');这是html代码<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <title>表单填写</title></head><body><form action='/about' method='post'> <p> Name: <input type='text' name='Name'></p> <p>SchoolNumber:<input type='text' name='number'></p> <p><input type='submit' value='提交'></p></form></body></html>执行结果图:
求大神解决 小弟感激不尽
问题解答
回答1:原因分析:回调函数执行顺序的问题, 加点打印信息看看
res.write()那一行返回的是你最开始定义的query并没有执行req.on()里面的操作,而这时的query还是你定义的字符串'what',它不是一个json对象,所以就没有number属性,所以是undefined。解决方案:你可以把res.write()写在req.on()里面,像这样:
回答2:怎么没见你判断请求方法啊?这个是我之前写的一个示例,你可以参考一下:
var http=require(’http’);var url=require(’url’);var fs=require(’fs’);var querystring=require(’querystring’);var mgd=require(’./mongodb.js’);http.createServer(function(req,res){ switch(req.method){case ’POST’: update(req,res); break;case ’GET’: get(req,res); break;default:break; }}).listen(8080);function update(req,res){ var pathname=url.parse(req.url).pathname; var postData=’’; /*接收评论*/ if(pathname==’/postComment’){req.addListener(’data’,function(data){ postData+=data;});req.addListener(’end’,function(){ var json=querystring.parse(postData); mgd(function(c){c.insert(’comment’,json,function(){ var json={} json.code=1; res.writeHead(’Content-Type:application/json;charset=UTF-8’); res.write(JSON.stringify(json)); res.end();}); });}) }}function get(req,res){ var pathname=url.parse(req.url).pathname;/*主页*/ if(pathname===’/’){fs.readFile(’test.html’,function(err,file){ res.end(file);}) } /*获取评论列表*/ if(pathname==’/comment’){mgd(function(c){ c.find(’comment’,{},function(data){var json={};if(data.length!=0){ json.code=1; json.data=data;}else{ json.code=0; json.data=null;}json=JSON.stringify(json)res.writeHead(’Content-Type:application/json;charset=UTF-8’);res.write(json);res.end(); }) }) }}
mongodb.js的代码需要的话可以在我的github上看一波,其实就是一个简单的评论demo
相关文章:
1. Docker for Mac 创建的dnsmasq容器连不上/不工作的问题2. golang - 用IDE看docker源码时的小问题3. 前端 - angular报错?4. docker images显示的镜像过多,狗眼被亮瞎了,怎么办?5. debian - docker依赖的aufs-tools源码哪里可以找到啊?6. dockerfile - 为什么docker容器启动不了?7. angular.js - $emit(,)的具体意思是什么作用呢?8. 在windows下安装docker Toolbox 启动Docker Quickstart Terminal 失败!9. 关docker hub上有些镜像的tag被标记““This image has vulnerabilities””10. docker网络端口映射,没有方便点的操作方法么?