上篇介绍了注册的基本流程,下篇简单的讲讲登陆的流程以及Cookie的出现
当你在浏览器的输入框里输入localhost:8080/sign_in
的时候,会发起GET
请求,去访问sign_in.html
javascript
if (path === '/sign_up' && method === 'GET') { let string = fs.readFileSync('./sign_up.html', 'utf8') response.statusCode = 200 response.setHeader('Content-Type', 'text/html;charset=utf-8') response.write(string) response.end() }
CSS布局与上篇的布局基本同样,略去不表~php
依然是上篇的套路,得到用户formdata后,分析数据,和数据库里面的比对html
var users = fs.readFileSync('./db/users', 'utf8') try { users = JSON.parse(users) //[] JSON也支持数组 } catch (exception) { users = [] } let found for (let i = 0; i < users.length; i++) { if (users[i].email === email && users[i].password === password) { found = true break } } if (found) { response.setHeader('Set-Cookie', `sign_in_email=${email};HTTPOnly`) response.statusCode = 200 } else { response.statusCode = 401 }
不一样的是引入了一个header
,也就是今天的主角--Cookiejava
其实这和日常上网的情形相似的,有时候咱们访问一些购物网站,并无登陆,可是你在购物车里面添加东西了,当你逛了之后再回来的时候,发现购物车里面有你的记录,帮你作这个事的也是cookie。node
由于 HTTP协议是无状态的,即 服务器不知道用户上一次作了什么,这严重阻碍了 交互式Web应用程序的实现。在典型的网上购物场景中,用户浏览了几个页面,买了一盒饼干和两瓶饮料。最后结账时,因为HTTP的无状态性,不经过额外的手段,服务器并不知道用户到底买了什么,因此Cookie就是用来绕开HTTP的无状态性的“额外手段”之一。服务器能够设置或读取Cookies中包含信息,借此维护用户跟服务器 会话)中的状态。
能够看出,当你在sign_in发起GET
请求并设置了Set-Cookie
以后,其余的同源的页面,又都会带上Cookie
,也就能保证同源的网页向服务器发起请求的时候,服务器可以明白,你己经是登陆的用户了,与那些没有拿到cookie的页面区别开来。git
为何要在cookie里面写上HttpOnly
呢,由于这个能够防止有些牛人使用JS
修改Cookie的内容。github
js
修改的写了HttpOnly
以后将没法修改数据库
这个是Chrome的功能,用于分析cookie的后端
每一部分的做用详见这里数组
经过上述的例子,能够总结几点重要的特色
固然了,还有几个问题须要解答一下。
默认有效期20分钟左右,不一样浏览器策略不一样
后端能够强制设置有效期
Set-Cookie: <cookie-name>=<cookie-value>; Expires=<date> Set-Cookie: <cookie-name>=<cookie-value>; Max-Age=<non-zero-digit>
具体语法看 Set-Cookie
既然你成功登陆,理应跳转到首页,并显示相应的界面。
$.post('/sign_in', hash) .then((response) => { window.location.href = '/' }, (request) => { alert('邮箱与密码不匹配') } )
而后首页的信息应该根据用户信息作出相应的变化
let cookies = request.headers.cookie.split('; ') //['email=..@..', 'a=1'] let hash = {} cookies.forEach((cookie) => { let parts = cookie.split('=') let key = parts[0] let value = parts[1] hash[key] = value }) let email = hash.sign_in_email let users = fs.readFileSync('./db/users', 'utf8') users = JSON.parse(users) let foundUser for (let i = 0; i < users.length; i++) { if (users[i].email === email) { foundUser = users[i] break } } if (foundUser) { string = string.replace('email', foundUser.email) } else { string = string.replace('恭喜,email你已成功登陆', '没有该用户') }
这里的代码逻辑与上篇的基本一致,惟一的不一样在于第一行代码
let cookies = request.headers.cookie.split('; ') //['email=..@..', 'a=1']
为何用;
字符来分割呢,这是由于能够有多个cookie
通常来讲常见的做用有以下两个:
localhost:8080
的时候,服务器会给A一个独一无二的id=00A
(这就是cookie),当用户A访问localhost:8080
的其余网页的时候,都会带着那个独一无二的id。当B用户来访问localhost:8080
的时候,服务器发现他没有任何标识,也会给他一个独一无二的id=00B
,因此借助cookie服务器端就可以分清楚谁是谁了。taobao.com
去买点东西,添加了一个热水壶、一部小米手机到购物车里面,那么服务器端能够改写你上面的cookie使之具体化「id=00A; cart=A1,A2」,表示你购物车里面买了俩东西。你过几天想起来了,去购物车里面看,热水壶、小米手机还在里面。浏览器并不会删除你存到硬盘上的cookie。接下来能够去搞一搞其余的,像什么session
LocalStorage
……(@ο@) 哇~
代码连接sign_in.html