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匹配协商的文件类型

  1. res.cookie('zhangsan1','lisi2',{
  2. maxAge:900000, //cookie的过期时间
  3. httpOnly:true, //仅由服务端来设置cookie
  4. path: '/admin',
  5. secure: true,
  6. signed:true
  7. })
  8. res.format({
  9. 'text/plain': function(){
  10. res.send('hey');
  11. },
  12. 'text/html': function(){
  13. res.send('<p>hey</p>');
  14. },
  15. 'application/json': function(){
  16. res.send({ message: 'hey' });
  17. },
  18. 'default': function() {
  19. // log the request and respond with 406
  20. res.status(406).send('Not Acceptable');
  21. }
  22. });
  23. res.get('key') 获取响应header数据
  24. res.json() 返回json数据 会自动设置响应header Content-type json格式 application/json
  25. res.json({
  26. xx:100
  27. })
  28. res.json({
  29. xx:100
  30. })
  31. jsonp 利用的就是浏览器加载其他服务器的文件不会存在跨域问题
  32. ajax请求就会有跨域问题
  33. res.setHeader('Content-Type','text/javascript;charsert=utf8')
  34. res.end(`typeof ${req.query.callback} == 'function' ? ${req.query.callback}({aa:100}):null`)
  35. res.jsonp({aaa:100})
  36. 重定向 把访问的地址跳转到另一个地址上
  37. res.redirect(301,'/api/aes')
  38. express jade
  39. res.render('index',{title:"hehe",test:"23"})
  40. res.send('') 发送数据 可以是任意类型的数据
  41. res.sendFile() 发送文件的
  42. res.sendStatus(200) 设置发送时的状态码
  43. res.set('Content-Type', 'text/plain') //设置响应header
  44. res.status(200) // 设置状态码
  45. res.type('') // 直接设置响应的文件类型
  46. res.type('pdf')
  47. res.send({aa:100})
  48. res.end('ok')
  49. res.end({aa:100})
  50. res.end('你好')
  51. res.end(req.get('Accept-Language'))
  52. res.json({
  53. is:req.is('text/html')
  54. })
  55. res.json({
  56. type:req.baseUrl,
  57. hostname:req.hostname,
  58. // ip:req.ip,
  59. // ips:req.ips,
  60. // route:req.route,
  61. ct:req.get('Accept'),
  62. cs:'22'
  63. })
  64. router.get('/:id/:date',(req,res)=>{
  65. console.log(req.params)
  66. // res.json(req.params)
  67. res.end(req.param('date'))
  68. })
  69. router.get('/aes',(req,res)=>{
  70. res.json({
  71. type:req.baseUrl
  72. })
  73. })

express之req res的更多相关文章

  1. 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 ...

  2. Express 项目,res.cookie() 设置 Cookie 无法被保存在浏览器的 Application 中

    res.cookie() 给客户端响应头封装的 Cookie 无法被保存在客户端浏览器的 Application 中,只能在 Set-Cookie 中看到有这个值: 在前后端分离项目中,存在跨域问题, ...

  3. REq,RES编码设置

    import java.io.IOException; import javax.servlet.Filter;import javax.servlet.FilterChain;import java ...

  4. nodejs:express API之res.locals

    在从零开始nodejs系列文章中,有一个login.html文件 再来看它的get方法,我们并没有看到mess字段.那mess到底是从哪里来的呢? 接着我看到app.js文件里面: 只有这里出现了me ...

  5. nodejs express 框架解密3-中间件模块

    本文档是基于express 3.4.6 的 在上篇中我们提到了中间件,这篇主要解释这个模块,middleware.js 为: var utils = require('./utils'); /** * ...

  6. Express 的基本使用(创建一个简单的服务器)

    Express 的基本使用(创建一个简单的服务器) const express = require('express') // 创建服务器应用程序 // 相当于 http.creatServer co ...

  7. 从壹开始前后端分离 [ Vue2.0+.NET Core2.1] 二十五║初探SSR服务端渲染(个人博客二)

    缘起 时间真快,现在已经是这个系列教程的下半部 Vue 第 12 篇了,昨天我也简单思考了下,可能明天再来一篇,Vue 就基本告一段落了,因为什么呢,这里给大家说个题外话,当时写博文的时候,只是想给大 ...

  8. 从壹开始前后端分离 [ Vue2.0+.NetCore2.1] 二十六║Client渲染、Server渲染知多少{补充}

    前言 书接上文,昨天简单的说到了 SSR 服务端渲染的相关内容<二十五║初探SSR服务端渲染>,主要说明了相关概念,以及为什么使用等,昨天的一个小栗子因为时间问题,没有好好的给大家铺开来讲 ...

  9. Vue(服务端渲染)

    一.前言 1.服务端渲染图解                                                 2.简介服务端渲染                             ...

随机推荐

  1. 2018-2019-2 网络对抗技术 20165225 Exp3 免杀原理与实践

    2018-2019-2 网络对抗技术 20165225 Exp3 免杀原理与实践 一.实验说明 1.1 正确使用msf编码器(0.5分),msfvenom生成如jar之类的其他文件(0.5分),vei ...

  2. bootstrap-treeview树形图参数详解

    哈哈 找了半天找到了,需要的可以去看看! 直接放上博客链接:https://blog.csdn.net/hailangtuteng/article/details/80842730

  3. pymysql连接数据库报错:'NoneType' object has no attribute 'encoding'

    直接写 utf8 即可.

  4. 学号20175313 《实现Linux下cp XXX1 XXX2的功能(一)》第九周

    目录 MyCP 一.题目要求 二.题目理解 三.需求分析 四.设计思路 五.伪代码分析 六.代码链接 七.代码实现过程中遇到的问题 八.运行结果截图 九.参考资料 MyCP 一.题目要求 编写MyCP ...

  5. 初学Python(二)

    -----------------------------------------------------2019.3.5-00:59--------------------------------- ...

  6. SecureCRT通过密钥登录(网上也有很多教程,但是有些不详细,此教程本人亲测)

    1.先打开SecureCRT,标题标--工具---创建公钥,如图: 2.点击创建公钥,弹出选项点下一步 3.继续点下一步: 4.继续点下一步: 5.继续点下一步(密钥长度默认1024即可),生成密钥需 ...

  7. HVP plan

    HVP,hier verification plan,建立整个验证的plan,在验证后期,通过vcs的coverage db可以直接进行反标, 包括反标code coverage,function c ...

  8. keil在线烧录突然提示 No target connected #

    keil在线烧录突然提示 No target connected 运行环境 IDE:keil uvsion5 微处理器:STM32F0xx 系列 烧录器:ST-LINK/V2 问题描述 烧录新程序并进 ...

  9. vue命令行错误处理

    全局安装vue/cli时:npm install -g @vue/cli (1)Error: EACCES: permission denied, access '/usr/local/lib/nod ...

  10. socket的原理和实验

    1.socket原理 根据连接启动的方式以及本地套接字要连接的目标,套接字之间的连接过程可以分为三个步骤:服务器监听,客户端请求,连接确认. (1)服务器监听:是服务器端套接字并不定位具体的客户端套接 ...