第7课 nodejs请求响应

1 server.js 接收请求接收请求参数 和接收完成需要对request增加两个监听事件

var http = require(‘http‘);
var url = require(‘url‘);
function start(route,handler)
{
function onRequest(request,res)
{
var postData ="";
var pathName = url.parse(request.url).pathname;
request.setEncoding("utf8");

request.addListener("data",function(postDataChunk)
{

//接收的参数累加 因为nodejs接收参数到达一定的大小会分片发过来
postData += postDataChunk;

console.log("Received POST data chunk ‘"+
postDataChunk +"‘.");
});

request.addListener("end",function()
{

//得到全部参数后 发给路由
route(pathName,handler, res, postData);
});
}

http.createServer(onRequest).listen(5000);
console.log(‘Server Started‘);
}

exports.start = start;

2 route.js

function route(pathName,handler,res,postData)
{
console.log(‘router user request url:‘+pathName+‘\n‘);
if(typeof handler[pathName]===‘function‘)
{
return handler[pathName](res,postData);
}else{
console.log(‘No request handler found for ‘+pathName);
return ‘404‘;
}
}
exports.route = route;

3 requestHandler.js

var querystring = require(‘querystring‘);
//使用 response直接输出 就不会阻塞其他请求
function start(response,postData){
console.log("Request handler ‘start‘ was called.");

var body =‘<html>‘+
‘<head>‘+
‘<meta http-equiv="Content-Type" content="text/html; ‘+
‘charset=UTF-8" />‘+
‘</head>‘+
‘<body>‘+
‘<form action="/upload" method="post">‘+
‘<textarea name="text" rows="20" cols="60"></textarea>‘+
‘<input type="submit" value="Submit text" />‘+
‘</form>‘+
‘</body>‘+
‘</html>‘;

response.writeHead(200,{"Content-Type":"text/html"});
response.write(body);
response.end();

}

function upload(response,postData){
console.log("Request handler ‘upload‘ was called.");
response.writeHead(200,{"Content-Type":"text/plain"});
response.write("You‘ve sent: "+ postData);//有特殊的编码
response.write(‘querystring:‘+querystring.parse(postData).text);//自动解析为中文
response.end();
}

exports.start = start;
exports.upload = upload;

4 index.js

var server = require(‘./server‘);
var route = require(‘./route‘);
var requestHandlers = require(‘./requestHandlers‘);
var handle ={}
handle["/"]= requestHandlers.start;
handle["/start"]= requestHandlers.start;
handle["/upload"]= requestHandlers.upload;

server.start(route.route,handle);

//注意输出的结果

response.write("You‘ve sent: "+ postData);//有特殊的编码
response.write(‘querystring:‘+querystring.parse(postData).text);//自动解析为中文

时间: 2024-10-12 23:00:11

第7课 nodejs请求响应的相关文章

【报文】理解HTTP协议的Request/Response(请求响应)模型

[报文]理解HTTP协议的Request/Response(请求响应)模型 系列目录 [简介]"请求/响应"模型 http://www.cnblogs.com/engraver-lxw/p/7550514.html [原理]理解HTTP协议的Request/Response(请求响应)模型 http://www.cnblogs.com/engraver-lxw/p/7550691.html [报文]理解HTTP协议的Request/Response(请求响应)模型--当前 http:/

iOS开发工具-如何使用网络封包分析工具Charles,通过配置proxy对http、https、tcp、udp 等协议的请求响应过程交互信息进行分析、判断、解决我们移动开发中的遇到的各种实际问题。

通过该方式同时也可以实现底层网络库AFNetworking及ASIHTTPRequest的代理设置.达到我们开发时的抓包分析及 IP地址指定访问开发/仿真任一台提供API接口服务器的目的. 首先下载Charles并配置我们的开发机iPhone终端的代理IP及Charles配置一下, 步骤如下: 1).取得mac本机的IP地址:如下图中的:192.168.1.106 如图: 2).通过下载的Charles来配置我们的代理服务器: 如下图: 将我们的开发机iphone终端代理设置成我们mac本的ip

Ajax的基本请求/响应模型

一.Ajax工作核心 Ajax的核心是JavaScript对象XMLHttpRequest(简称XHR).它是一种支持异步请求的技术.可以通过使用XHR对象向服务器提出请求并处理响应,而不阻塞用户. Ajax可以完成的功能有: 在不重新加载页面的情况下更新网页 在页面已加载后从服务器请求数据 在页面已加载后从服务器接收数据 在后台向服务器发送数据 1.1 Ajax简介 Ajax可以说 是目前最流行的 WEB 技术,它采用客户端脚本与 Web 服务器交换数据,也就是说,客户端的表单请求不是直接给

web请求响应

转载自:SanMaoSpace 1.Web开发的定义首先看看微软对Web开发的定义:Web开发是一个指代网页或网站编写过程的广义术语.网页使用 HTML.CSS 和 JavaScript编写.这些页面可能是类似于文档的简单文本和图形.页面也可以是交互式的,或显示变化的信息.编写交互式服务器页面略微复杂一些,但却可以实现更丰富的网站.如今的大多数页面都是交互式的,并提供了购物车.动态可视化甚至复杂的社交网络等现代在线服务. 通俗的说,Web开发就是我们说的做网站.它分为网页部分和逻辑部分也就是我们

基于请求响应的简单介绍

Http请求响应过程: Http是基于TCP/IP之上的协议. 基本流程: 浏览器      -------请求行/请求头/请求体---------> Web服务器 --> 应用代码(servlet/JSP/.html) <----- 响应状态/响应头/响应体----- 请求行: GET/POST URL?querystring请求头: Content-Length/Connection/User-Agent/Accept-Language/Referer/Cookie/Host...请

http请求 响应 详细过程

httpurlconnection 1. 配置connection对象2. connect() [根据配置设置请求头 outputStream 字符串流] 存储在内存缓冲区3. outputStream关闭时 生成http正文4. 调用getInputStream时 发送http请求 返回InputStream 从而读取此次http请求的返回信息 System.setProperty("sun.net.client.defaultConnectTimeout", "30000

使用新浪云(SAE)实现基于mySql和微信公众平台的关键字请求响应服务

本例是作者初次尝试微信公众平台开发之作,实现传统的关键字请求响应功能.即:用户发关键字,公众号通过关键字进行检索, 在mysql数据库中读取与关键字相关的信息,并返回给用户.本例在微信订阅号(开发者模式)上实现,目的是学习微信公众平台开发.验证SAE的功能,并研究SAE+微信公众平台的实用性及应用场景.因仅是进行技术学习的示例子,所以忽略公众号在非开发者模式下可以简单实现该功能的事实. 感谢方倍公作室的教程,让我一开始就站上一个高度:微信公众平台开发入门教程 应用比较简单,直接上代码了: <?p

基于请求响应的MVC框架调用分析

一,使用Servlet来处理请求响应 当客户端提交数据之后,接着发送请求,请求被封装成对象,服务器接收到请求,根据请求的URL,来判断将请求对象交由哪个Servlet处理.在servlet中,我们可以根据请求是从哪里发出的,来判断我们具体执行哪段处理表现层业务逻辑的if-else.或者,可能我们客户端会提交一个参数,我们可以根据参数来判断调用哪段代码去渲染表现层,返回给客户端.无论是怎么判断,中间的选择都是要得出我们要返回哪个表现层,例如,返回哪个JSP! 当表现层越来越多的时候,我们的选择逻辑

Fiddler-006-修改HTTP请求响应数据

在进行 App 测试时,经常需要修改请求参数,以获得不同的显示效果,以查看相应的页面显示处理.例如:电商购物App中商品都有好几种状态(在售.缺货.暂不销售.下 架等).同时,一般这几种状态均为同一个按钮对应的多种情况,那么测试商品详情时,需要测试按钮在商品不同状态下的显示效果,就需要构建不同状态的商品, 若是多人测试不同的状态下的操作,那么就不能使用同一件商品同时进行测试,因为测试时,需要修改商品的状态,那么多人测试时会有影响.此时,测试页面显示 的朋友,则可以通过修改获取商品详情的HTTP请