好不容易找到个wordpress的神器,结果发现被墙了,半夜三更导博客,绝了。
天资也不高,谁苦谁知道啊
果然还是希望把这个网站放在这啊https://polarbear997260416.wordpress.com/
一.定义
Node.js是构建在chromeV8的Js运行环境
二.特点
- 单线程:Nodejs不为每个客户连接创建一个新的线程,而仅仅使用一个线程,由用户连接,就触发一个线程单线程也能造成宏观上的并发。一个线程的崩溃会导致所有线程崩溃
- 非阻塞I/O:执行了访问数据库之后,立即执行后面的代码,把数据库返回结果放在回调函数中,提高执行效率线程利用率永远百分之百。
- 事件驱动:在node中,在一个时刻,只能执行一个事件的回调函数,但是在执行一个事件回调函数的中途,可以转而处理其他事件,然后返回继续执行原事件的回调函数,这种处理机制,称为事件环机制。
单线程:如果某一个事情,进入了,到那时被I/O阻塞了,所以这个线程就阻塞了。
非阻塞I/O不会傻等语句结束,会执行后面的语句。
但是如果执行一个业务在,另一个业务的I/O回调完成,会出现问题。
事件机制,事件环,所有事件进入事件环,等待调度,比如饭店服务员。
其他特性:
- 没有BOM和DOM
- 只有EcmaScript
- 服务端不操纵页面
- Npm node.js package ecosystem
三.http基本操作
1.必要操作
var http=require("http") 前一个http随便起名,后一个必须是http
2.创建服务器
var server=http.createServer(function(request,response){})
返回值是一个服务器实例
服务器的用途:
- 提供服务
- 发请求
- 接受请求
- 处理请求
- 给反馈(发送响应)
当客户端请求过来,自动触发request请求事件,执行第二个参数:回调函数
server.on("request",function(){})
3.写操作
response.write("abc");
写东西 修改后需要关闭服务器
response.end();
绑定端口号监听才能启动服务器
server.listen(端口号);
四.fs操作
var fs=require("fs")
读取文件,浏览器读取文件时为二进制的
fs.readFile(文件名,function(err,data){})
写文件,无需担心二进制文件,服务器可以重建为用户能看懂的形式
fs.writerFile(文件名,内容,回调函数)
由于是异步操作 fs中有读写文件可能会在end之后执行完毕
五.数据请求
1.GET
GET 数据在URL里
通过response.url获取传递的数据
2.POST
POST 数据在http中,不能通过URL直接获取
post数据很大,需要分段接收
data有一段数据到达(很多次)
req.on(‘data’,function(data){});
end数据全部到达(一次)
req.on(‘end’,function(){});
3.GET 和POST的区别
- 本质上的区别是语义的区别,根据HTTP规范,GET的语义是请求获取指定的资源。GET方法是安全、幂等、可缓存的。POST的语义是根据请求负荷(报文主体)对指定的资源做出处理,具体的处理方式视资源类型而不同。POST不安全,不幂等,(大部分实现)不可缓存。具体差别如下:get在后退刷新时是无害的,post会重新提交请求;
- get参数通过URL传递,post放在Request body中;
- get请求参数保留在浏览器历史记录中,post参数不会保留;
- get产生的URL地址可以被存为书签,而post不可以;
- 对参数的数据类型,get只接受ASCII字符,而post没有限制;
- get比post更不安全,因为发送的数据显示在URL上,在发送密码或其他敏感信息时绝不要使用get;
- get请求只能进行url编码,而post支持多种编码方式。
六.GET和POST相关
1.Querystring
querystring可以将"user=xxx&password=xxx"解析为json格式
.parse(str):对url查询参数(字符串)进行解析,生成易于分析的json格式。
.stringif():跟.parse()相反,用于拼接查询查询。
2.url
url可以将"xxx?user=xxx&password=xxx"解析
var obj=url.parse(地址,true)
其中obj.pathname为?前的网址部分,比如http://localhost:8080/1.html,pathname即为/1.html。
obj.query为user=xxx&password=xxx的json格式