express之req res
request对象和response对象
Request
req.baseUrl 基础路由地址
req.body post发送的数据解析出来的对象
req.cookies 客户端发送的cookies数据
req.hostname 主机地址 去掉端口号
req.ip 查看客户端的ip地址
req.ips 代理的IP地址
req.originalUrl 对req.url的一个备份
req.params 在使用/:id/:name 匹配params
req.path 包含请求URL的路径部分
req.protocol http 或https协议
req.query 查询字符串解析出来的对象 username=zhangsan&password=123 { username:zhangsan }
req.route 当前匹配的路由 正则表达式
req.params 获取路由匹配的参数
req.get 获取请求header里的参数
req.is 判断请求的是什么类型的文件
req.param(key名称) 用来获取某一个路由匹配的参数
Response
res.headersSent 查看http响应是否响应了http头
res.append(名称,value) 追加http响应头
res.attachment(文件路径) 响应文件请求
res.cookie() 设置cookie
res.setHeader('Content-Type','text/html;charset=utf8')
res.append('Content-Type','text/html;charset=utf8')
res.append('hehe','1008')
res.append('haha','1008')
res.attachment('./xx.zip') //Content-Disposition: attachment; filename="xx.zip"
res.clearCookie(cookiename) 删除cookie
res.cookie('zhangsan','lisi') 设置cookie
res.clearCookie('zhangsan') //清除cookie
res.download(文件的path路径) 跟attachment类似 用来处理文件下载的 参数是文件地址
res.end() http模块自带的
res.format() 协商请求文件类型 format匹配协商的文件类型
res.cookie('zhangsan1','lisi2',{
maxAge:900000, //cookie的过期时间
httpOnly:true, //仅由服务端来设置cookie
path: '/admin',
secure: true,
signed:true
})
res.format({
'text/plain': function(){
res.send('hey');
},
'text/html': function(){
res.send('<p>hey</p>');
},
'application/json': function(){
res.send({ message: 'hey' });
},
'default': function() {
// log the request and respond with 406
res.status(406).send('Not Acceptable');
}
});
res.get('key') 获取响应header数据
res.json() 返回json数据 会自动设置响应header Content-type 为json格式 application/json
res.json({
xx:100
})
res.json({
xx:100
})
jsonp 利用的就是浏览器加载其他服务器的文件不会存在跨域问题
ajax请求就会有跨域问题
res.setHeader('Content-Type','text/javascript;charsert=utf8')
res.end(`typeof ${req.query.callback} == 'function' ? ${req.query.callback}({aa:100}):null`)
res.jsonp({aaa:100})
重定向 把访问的地址跳转到另一个地址上
res.redirect(301,'/api/aes')
express jade
res.render('index',{title:"hehe",test:"23"})
res.send('') 发送数据 可以是任意类型的数据
res.sendFile() 发送文件的
res.sendStatus(200) 设置发送时的状态码
res.set('Content-Type', 'text/plain') //设置响应header
res.status(200) // 设置状态码
res.type('') // 直接设置响应的文件类型
res.type('pdf')
res.send({aa:100})
res.end('ok')
res.end({aa:100})
res.end('你好')
res.end(req.get('Accept-Language'))
res.json({
is:req.is('text/html')
})
res.json({
type:req.baseUrl,
hostname:req.hostname,
// ip:req.ip,
// ips:req.ips,
// route:req.route,
ct:req.get('Accept'),
cs:'22'
})
router.get('/:id/:date',(req,res)=>{
console.log(req.params)
// res.json(req.params)
res.end(req.param('date'))
})
router.get('/aes',(req,res)=>{
res.json({
type:req.baseUrl
})
})
express之req res的更多相关文章
- TypeError: Object function (req, res, next) { app.handle(req, res, next); } has no method 'configure'
TypeError: Object function (req, res, next) { app.handle(req, res, next); } has no method 'configure ...
- Express 项目,res.cookie() 设置 Cookie 无法被保存在浏览器的 Application 中
res.cookie() 给客户端响应头封装的 Cookie 无法被保存在客户端浏览器的 Application 中,只能在 Set-Cookie 中看到有这个值: 在前后端分离项目中,存在跨域问题, ...
- REq,RES编码设置
import java.io.IOException; import javax.servlet.Filter;import javax.servlet.FilterChain;import java ...
- nodejs:express API之res.locals
在从零开始nodejs系列文章中,有一个login.html文件 再来看它的get方法,我们并没有看到mess字段.那mess到底是从哪里来的呢? 接着我看到app.js文件里面: 只有这里出现了me ...
- nodejs express 框架解密3-中间件模块
本文档是基于express 3.4.6 的 在上篇中我们提到了中间件,这篇主要解释这个模块,middleware.js 为: var utils = require('./utils'); /** * ...
- Express 的基本使用(创建一个简单的服务器)
Express 的基本使用(创建一个简单的服务器) const express = require('express') // 创建服务器应用程序 // 相当于 http.creatServer co ...
- 从壹开始前后端分离 [ Vue2.0+.NET Core2.1] 二十五║初探SSR服务端渲染(个人博客二)
缘起 时间真快,现在已经是这个系列教程的下半部 Vue 第 12 篇了,昨天我也简单思考了下,可能明天再来一篇,Vue 就基本告一段落了,因为什么呢,这里给大家说个题外话,当时写博文的时候,只是想给大 ...
- 从壹开始前后端分离 [ Vue2.0+.NetCore2.1] 二十六║Client渲染、Server渲染知多少{补充}
前言 书接上文,昨天简单的说到了 SSR 服务端渲染的相关内容<二十五║初探SSR服务端渲染>,主要说明了相关概念,以及为什么使用等,昨天的一个小栗子因为时间问题,没有好好的给大家铺开来讲 ...
- Vue(服务端渲染)
一.前言 1.服务端渲染图解 2.简介服务端渲染 ...
随机推荐
- mysql--表数据操作
查询: 简单查询 ####查询的字段必须在表中存在 #### 对查询出来的数据进行修改时,不会修改原来的数据,只是修改了可视化的,我们看到的数据. # 查一个数据 select 字段名 from 表名 ...
- Vue.js中集成summernote
首先引用summernote样式及js: <!--summernote css --> <link href="${ctxPath}/static/css/summerno ...
- VisualStudioCode中用dotnet命令创建多个ASP.NET Core 项目、类库、控制台程序,并添加应用间的引用
一.准备工作 首先安装VisualStudioCode并且可以使用. 1.首先新创建空的MyApps文件夹,作为项目主目录,下面将在这个文件夹中创建多个web应用程序.类型.控制台程序等. 2.打开V ...
- vue页面无操作10分钟内调转到登录页面
https://blog.csdn.net/lbPro0412/article/details/83864454 页面在设定时间内无任何操作(鼠标的点击.滑动.路由的切换.是否请求接口等),跳转到登录 ...
- 如何增加Ubuntu交换空间swap
如何增加Ubuntu交换空间swap 1 使用命令查看系统内swap分区大小 green@green:~$ free -m total used free shared buff/cache ava ...
- IDEA开发工具的学习
1.设置jdk的版本 ,快捷键:ctrl + shirt +alt + s 打开项目的设置,选择Project 进行 jdk版本的设置. 2.鼠标移到项目上,右键,Show in Explorer 定 ...
- Excle中的使用小技巧
关于从数据库中拷贝来的数字,拷贝到excle中,那些数字都变成了科学计算法. 步骤1,鼠标右键选中的列,选择“设置单元格格式(F)” 2.从这里面选中这些是否有小数,如果没有小数就把这个改成0
- 查找字符在字符串中第N次出现的位置
1.查找字符串 @find 在字符串 @str 中第 (@n) 次出现的位置.没有第 (@n) 次返回 0. 返回@find在@str中第(@n)次出现的位置.没有第(@n)次返回0. ), ), ...
- C# 字段和属性
最大的疑惑就是:有了字段,为什么还要有属性呢? 如果在一个类中有一个公有字段,那么在这个类的外部我们可以自由无阻的使用这个字段,但是如果给这个字段赋了一个很“离谱”的值,那这对程序可能会造成很大的影响 ...
- vi / vim 命令集合
vim的命令太多了,不常用就会忘记,所以我决定把vim的各种命令整理下来,包括vim的插入删除.光标移动.多窗口编辑.复制粘贴.查找替换.以及一些常用命令 删除操作 dd 删除当前行 ndd ...