一、request、response、cookie介绍和区别
成都创新互联是一家集网站建设,丹凤企业网站建设,丹凤品牌网站建设,网站定制,丹凤网站建设报价,网络营销,网络优化,丹凤网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。
request(中文“请求”的意思):可以理解为客户端向服务器请求的信息,就是客户端向服务器请求时,把自己的浏览器信息、HTTP变量和保存在客户端的Cookie告诉服务器,这样服务器就可以根据这些信息判断是谁请求的,之前有没有请求过,对应客户端的Session是什么等等。
response(中文“反应、响应”的意思):可以理解为服务器对客户端请求的响应,就是服务器接收到客户端的请求后,成生页面信息、Cookie(发到客户端后就保存在客户端)等发送到客户端。
cookie(中文“饼干”,在这里不能这样理解了):就是保存在客户端上的一些信息,可以用来验证用户信息,提高用户响应速度等等。
response.cookie是将内容写入到客户端的COOKIE里面 这个是在浏览器内的!
request.cookie是将内容从客户端浏览器里面读出来对应的COOKIE内容!
从请求中获取cookie就用Request.Cookies,
要给客户端写cookie就用Response.Cookies
二、express模块中的req,res参数的常用属性方法
const express = require('express');
const router = express.Router()
router.get('/',(req,res)=>{
// 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.cookie('zhangsan1','lisi2',{
// maxAge:900000,
// httpOnly:true,
// path: '/admin',
// secure: true,
// signed:true
// })
// res.clearCookie('zhangsan')
// res.download(文件的path路径) 跟attachment类似 用来处理文件下载的 参数是文件地址
// res.end http模块自带的
// res.format()协商请求文件类型 format匹配协商的文件类型
// res.format({
// 'text/plain': function(){
// res.send('hey');
// },
// 'text/html': function(){
// res.send('hey
');
// },
// '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
})
})
module.exports = router
二、EventEmitter
Node.js 所有的异步 I/O 操作在完成时都会发送一个事件到事件队列。
也就是,比如读取文件成功了,执行后面的回调函数,这个回调函数就是一个事件队列
Node.js 里面的许多对象都会分发事件:一个 net.Server 对象会在每次有新连接时触发一个事件, 一个 fs.readStream 对象会在文件被打开的时候触发一个事件。 所有这些产生事件的对象都是 events.EventEmitter 的实例。
EventEmitter 类
events 模块只提供了一个对象: events.EventEmitter。EventEmitter 的核心就是事件触发与事件监听器功能的封装
使用该对象前,先通过require("events");来访问该模块。
//引入事件模块
var events = require('events');
//创建EventEmitter对象
var eventEmitter = new events.EventEmitter();
//创建事件处理程序
var connectHandle = function () {
console.log('连接成功!')
}
// 绑定事件及事件的处理程序
eventEmitter.on('connect',connectHandle)
//触发事件
eventEmitter.emit('connect')
//结果 输出:连接成功!
PS.大多数时候我们不会直接使用 EventEmitter,而是在对象中继承它。包括 fs、net、 http 在内的,只要是支持事件响应的核心模块都是 EventEmitter 的子类。
三、Node.js模块系统【文件即模块,模块即文件】
为了让Node.js的文件可以相互调用,Node.js提供了一个简单的模块系统。
模块是Node.js 应用程序的基本组成部分,文件和模块是一一对应的。
换言之,一个 Node.js 文件就是一个模块,这个文件可能是JavaScript 代码、JSON 或者编译过的C/C++ 扩展
exports 和 module.exports 的使用
如果要对外暴露属性或方法,就用 exports就行,要暴露对象(类似class,包含了很多属性和方法),就用 module.exports。
举例:直接暴露属性或方法
//b.js
exports.world = function(){
console.log('你好')
}
//a.js
var hello = require('b');
hello.world(); // 你好
暴露对象
//b.js
var b = function(n){
this.name = n;
this.setName = function(n){
this.name = n;
}
this.getName = function(){
console.oog(this.name)
}
}
module.exports = b
//a.js
var hello = require('b');
var w = new hello();
w.getName();
四、Node.js 全局对象
全局对象:global对象
全局变量:global及其所有属性,可以在程序的任何地方访问到
//__filename 输出当前执行文件所在位置的绝对路径
console.log(__filename); //G:\nodeWork\global\index.js
//__dirname 输出当前执行文件所在目录的绝对路径。
console.log(__dirname);
五、url.parse方法
方法说明:
讲一个URL字符串转换成对象并返回。
语法:
url.parse(urlStr, [parseQueryString], [slashesDenoteHost]);
接收参数:
urlStr url字符串
parseQueryString 为true时将使用查询模块分析查询字符串,默认为false
slashesDenoteHost
默认为false,//foo/bar 形式的字符串将被解释成 { pathname: ‘//foo/bar' }
如果设置成true,//foo/bar 形式的字符串将被解释成 { host: ‘foo', pathname: ‘/bar' }
Eg:
var url = require('url');
var a = url.parse('http://localhost:8080/one?a=index&t=article');
console.log(a);
//输出结果:
{
protocol : 'http' ,
auth : null ,
host : 'localhost:8080' ,
port : '8080' ,
hostname : 'localhost' ,
hash : null ,
search : '?a=index&t=article',
query : 'a=index&t=article',
pathname : '/one',
path : '/one?a=index&t=article',
href : 'http://localhost:8080/one?a=index&t=article'
}