Node.js之Express二
好久没写了,今天看博客,觉得有必要把node.js继续写完,善始善终。原本想着把小崔课堂继续讲下去,由于其他原因也就此耽搁下来,看看以后还有没有机会吧。废话不扯,123开始。
一.Exoress之Request对象
对于Request对象做过网络这块的应该都不陌生,ios、C#都会有,其他语言基本都会有,Node.js也不例外,毕竟都是HTTP协议。
var express = require('express');
var app = express();
app.listen();
app.get('/user/:userid', function (req, res) {
//请求的原始URL字符串
console.log("URL:\t " + req.originalUrl);
//协议的字符串 如http、https
console.log("Protocol: " + req.protocol);
//请求的IP地址
console.log("IP:\t " + req.ip);
//请求的URL的路径部分
console.log("Path:\t " + req.path);
//请求的主机名
console.log("Host:\t " + req.host);
//请求的方式 get、post等
console.log("Method:\t " + req.method);
//请求的查询字符串部分
console.log("Query:\t " + JSON.stringify(req.query));
//布尔值,当最后修改与当前匹配时为true
console.log("Fresh:\t " + req.fresh);
//布尔值,当最后修改与当前匹配时为false
console.log("Stale:\t " + req.stale);
//布尔值,建立TLS链接时为true
console.log("Secure:\t " + req.secure);
//一个方法,如果由charset指定的字符集受支持为true
console.log("UTF8:\t " + req.acceptsCharset('utf8'));
//返回header的值的方法
console.log("Connection: " + req.get('connection'));
//请求标头的对象形式
console.log("Headers: " + JSON.stringify(req.headers,null,));
res.send("User Request");
});
二、Exoress之Response对象
有请求一般都会有响应,所以Response来了。
1.设置标头
设置标头是制定适当的HTTP响应的一个重要组成部分。Response对象提供了几个方法来获取和设置发送的HTTP响应的标头值。
最常用的是get(header)和set(header,value),它们分别获取和设置任何标头值。
var oldType=res.get('Content-Type'); res.set('Content-Type','text/plain');
get(header):返回所指定的header参数的值
set(header,value):设置header参数的值
set(headerObj):接受一个对象,它包含多个'header':'value'属性。每个在headerObj参数中的标头都在response对象中被设置
location(path):把location标头设置为指定的path参数。该路径可以是URL路径:/login,完整的URL:http://server.net/,相对路径:../users或者是浏览器行为:back
type(type_string):根据type_string参数设置Content_Type标头。该参数可以是一个正常的内容类型:application/json,部分类型:png或文件扩展名html
attachment([filepath]):把Content-Disposition标头设置为attachment,并且如果知道filepath,则Content-Type头是基于文件扩展名设置的
2.设置状态
前面HTTP协议也有提到5种状态。1-5开头代表的不同的意思。通过res.status(number)来设置。
3.发送响应
上面是一些响应头,那发送响应就是要发送响应体了
发送响应通过send([body])方法。body是一string或buffer对象。如果是buffer对象,则内容类型自动设置为application/octet-stream(应用程序/八位字节流)
,除非明确设置为别的
res.set('Content-Type','text-html');
res.send(new Buffer('<html><body>HTML String</body></html>'));
一旦send()方法完成,就可设置res.finished和res.headerSent(私有这个要通过断点才能查到)属性值来验证相应是否发送、传输了多少数据等。
var express = require('express');
var url = require('url');
var app = express();
app.listen();
app.get('/', function (req, res) {
var response = '<html><head><title>Simple Send</title></head>' +
'<body><h1>Hello from Express</h1></body></html>';
res.status();
res.set({
'Content-Type': 'text/html',
'Content-Length': response.length
});
res.send(response);
console.log('Response Finished? ' + res.finished);
});
app.get('/error', function (req, res) {
res.status();
res.send("This is a bad request.");
});
4.发送JSON响应
有时候客户端页面的变化只是一些数据的变化,这样再从服务端请求html这样就会给服务端造成很大的压力,html客户端已经有了也没有这个必要,服务端只需把数据传给客户端就好了,于是有了json()和jsonp()方法,它们可以方便的发送json
res.json(status,[object]) res.json([body]) res.jsonp(status,[object]) res.jsonp([object])
var express = require('express');
var url = require('url');
var app = express();
app.listen();
app.get('/json', function (req, res) {
app.set('json spaces', );
res.json({name:"Smithsonian", built:'', items:'137M',
centers: ['art', 'astrophysics', 'natural history',
'planetary', 'biology', 'space', 'zoo']});
});
app.get('/error', function (req, res) {
res.json(, {status:false, message:"Internal Server Error"});
});
app.get('/jsonp', function (req, res) {
app.set('jsonp callback name', 'cb');
res.jsonp({name:"Smithsonian", built:'', items:'137M',
centers: ['art', 'astrophysics', 'natural history',
'planetary', 'biology', 'space', 'zoo']});
});
5.发送文件
sendfile(path,[options],[callback])使用一个函数调用来完成将文件发送到客户端需要做的事情。
1.基于文件扩展名设置Content-Type标头的类型
2.设置其他相应的标头,如Content-Length
3.设置响应状态
4.使用Response对象内部连接,把文件的内容发送的客户端
path:要发送给客户端的文件
options:一个对象,包含一个maxAge属性定义的最长期限的内容和root属性(它是用来支持path参数相对路径的根路径)
,当文件传输完成,回调函数被调用,并接受一个错误作为唯一的参数
var express = require('express');
var url = require('url');
var app = express();
app.listen();
app.get('/image', function (req, res) {
res.sendfile('arch.jpg',
{ maxAge: ***,
root: './views/'},
function(err){
if (err){
console.log("Error");
} else {
console.log("Success");
}
});
});
6.发送下载响应
download(path,[filename],[callback])工作原理类似sendfile()方法,download()把文件作为HTTP响应的附件发送。path:发送到客户端的文件 filename:指定一个应该在Content-Disposition标头中发送的不同的文件名。回调函数在文件下载完成后执行。
var express = require('express');
var app = express();
app.listen();
app.get('/download', function (req, res) {
res.sendfile('./views/word.docx', 'new.docx');
});
7.重定向响应
这个在C#中也是有的也挺简单的
var express = require('express');
var url = require('url');
var app = express();
app.listen();
app.get('/google', function (req, res) {
res.redirect('http://google.com');
});
app.get('/first', function (req, res) {
res.redirect('/second');
});
app.get('/second', function (req, res) {
res.send("Response from Second");
});
app.get('/level/A', function (req, res) {
res.redirect("/level/B");
});
app.get('/level/B', function (req, res) {
res.send("Response from Level B");
});
Node.js之Express二的更多相关文章
- Node.js、express、mongodb 入门(基于easyui datagrid增删改查)
前言 从在本机(win8.1)环境安装相关环境到做完这个demo大概不到两周时间,刚开始只是在本机安装环境并没有敲个Demo,从周末开始断断续续的想写一个,按照惯性思维就写一个增删改查吧,一方面是体验 ...
- node.js和express.js安装和使用步骤 [windows]
PS: NODEJS:https://nodejs.org NPM:https://www.npmjs.com/ 一.node.js安装与配置 到https://nodejs.org/en/downl ...
- Node.js系列-express(上)
前言 Node.js系列的第一篇:http,大概描述了通过使用node.js内置的api创建一个服务并监听request实现简单的增删改查.现在,我们就通过通读express官网及使用express框 ...
- node.js使用express框架进行文件上传
关于node.js使用express框架进行文件上传,主要来自于最近对Settings-Sync插件做的研究.目前的研究算是取得的比较好的进展.Settings-Sync中通过快捷键上传文件,其实主要 ...
- node.js之express框架
之前学习过node.js接触过express框架,最近为了编写一个mock server正好用到了express.下面正好就跟大家介绍一下关于express.今天的内容主要围绕这么几个方面? expr ...
- Node.js、express、mongodb 实现分页查询、条件搜索
前言 在上一篇Node.js.express.mongodb 入门(基于easyui datagrid增删改查) 的基础上实现了分页查询.带条件搜索. 实现效果 1.列表第一页. 2.列表第二页 3. ...
- Node.js基于Express框架搭建一个简单的注册登录Web功能
这个小应用使用到了node.js bootstrap express 以及数据库的操作 :使用mongoose对象模型来操作 mongodb 如果没了解过的可以先去基本了解一下相关概念~ 首先注 ...
- node.js框架express的安装
node.js框架express的安装 首先假定你已经安装了 Node.js,接下来为你的应用创建一个目录,然后进入此目录并将其作为当前工作目录. $ mkdir myapp $ cd myapp 通 ...
- node.js,express入门看详细篇
先最简单的代码 安装 npm install express app.js 代码内容 const express = require('express') const app = express() ...
随机推荐
- Visual Studio 6 (VC6)连接Team Foundation Server (TFS 2018),实现源代码的版本管理
1. 概述 Visual Studio 6(VB6, VC6, Foxpro-)是微软公司在1998年推出的一款基于Windows平台的软件开发工具,也是微软推出.NET开发框架之前的最后一个IDE工 ...
- .NET Core 运行时标识符 (RID) 目录
RID 是什么? RID 是运行时标识符的缩写. RID 用于标识其中将运行应用程序或资产(即程序集)的目标操作系统. 其外观类似如下:“ubuntu.14.04-x64”.“win7-x64”.“o ...
- BitAdminCore框架更新日志20180529
索引 NET Core应用框架之BitAdminCore框架应用篇系列 框架演示:http://bit.bitdao.cn 框架源码:https://github.com/chenyinxin/coo ...
- .net core2.2 跨域
Startup.cs 类 ConfigureServices中 //允许一个或多个具体来源: services.AddCors(options => { // Policy 名稱 CorsPol ...
- 命名空间“Microsoft”中不存在类型或命名空间名“Reporting”(是否缺少程序集引用?)
IDE升级到VS2017之后,出现了如题所示的报错,重新引用DLL的方法如下: 1.右键引用,选择添加引用. 2.左侧选择浏览,下面点击浏览按钮. 3.分别添加Microsoft.ReportView ...
- odoo:开源ERP/安装和初始设置
1.1 Odoo的结构 Odoo使用Web浏览器来访问Odoo服务,因此你的Odoo服务器可以部署在较远的地方(如另外一个城市),用户的计算机上只需安装谷歌.火狐或 IE9 以上的浏览器,所以Web客 ...
- 在kolla中配置cinder ceph多后端
原文链接:在kolla中配置cinder ceph多后端
- Flask的WTforms
一.简单介绍 WTForms是一个支持多个web框架的form组件,主要用于对用户请求数据进行验证. 类似于Django中的modelform 安装: pip3 install wtforms 二.简 ...
- Python面向对象(类的成员之属性)
day24 类的成员之属性 class Foo(): def bar(self): print("bar") @property def per(self): ') return ...
- 攻防组网之—-VMware路由器安装设置
本文作者:i春秋作家——红发香克斯 前言 VMWare功能很强大,我一直有个想法是能不能用一台高配的主机利用VM虚拟化出一个或多个真实的子网,或者子网里面还有子网,其中使用VM自动的功能可以实现多个网 ...