Day13 通信协议、cookie

通信协议

通信协议是指双方实体完成通信或服务所必须遵循的规则和约定。

在计算机通信中,通信协议用于实现计算机与网络连接之间的标准,网络如果没有统一的通信 协议,电脑之间的信息传递就无法识别。 通信协议是指通信各方事前约定的通信规则,可以简 单地理解为各计算机之间进行相互会话所使用的共同语言。两台计算机在进行通信时,必须使 用的通信协议。

TCP/IP

Transmission Control Protocol/Internet Protocol的简写,中译名为传输控制协议/因特网互 联协议,又名网络通讯协议,是Internet最基本的协议、Internet国际互联网络的基础,由网 络层的IP协议和传输层的TCP协议组成。TCP/IP 定义了电子设备如何连入因特网,以及数据 如何在它们之间传输的标准。

HTTP

超文本传输协议(HTTP,HyperText Transfer Protocol)是互联网上应用最为广泛的一种网络 协议。所有的WWW文件都必须遵守这个标准。设计HTTP最初的目的是为了提供一种发布和 接收HTML页面的方法。

HTTP是一个客户端和服务器端请求和应答的标准(TCP)。客户端是终端用户,服务器端是网 站。通过使用Web浏览器、网络爬虫或者其它的工具,客户端发起一个到服务器上指定端口(默 认端口为80)的HTTP请求。

前端面试题:

1、 一个页面从输入 URL 到页面加载完的过程中都发生了什么事情?

  1. http客户端发起请求,创建一个端口,默认是80
  2. 然后http服务器在端口监听客户端的发送请求
  3. 最后服务器向客户端返回状态和内容
  4. 浏览器根据接收到的内容进行解析

2、一次完整的HTTP事务是怎样的一个过程?

a. 域名解析
b. 发起TCP的3次握手
c. 建立TCP连接后发起http请求
d. 服务器端响应http请求,浏览器得到html代码
e. 浏览器解析html代码,并请求html代码中的资源
f. 浏览器对页面进行渲染呈现给用户

3、HTTP和HTTPS

HTTP协议通常承载于TCP协议之上,在HTTP和TCP之间添加一个安全协议层(SSL或TSL), 这个时候,就成了我们常说的HTTPS。默认HTTP的端口号为80,HTTPS的端口号为443。

cookie的概念

Cookie(会话跟踪技术) 是在 HTTP 协议下,服务器或脚本可以维护客户工作站上信息的一种方式。Cookie 是由Web服务器保存在用户浏览器(客户端)上的小文本文件,它可以包含有关用户的信息。无论何时用户链接到服务器,Web 站点都可以访问 Cookie信息 。

  • 比如:自动登录、记住用户名,记住一些和用户相关的信息等
  • Cookie名称和值可以由服务器端开发自己定义。
  • 如果cookie不存在,输出undefined.

cookie的特点

  • 储存在用户本地终端上的数据
  • 禁用Cookie后,几乎所有需要用户登陆帐号的网站都因为Cookie的禁用而导致无法 正常登陆。
  • cookie是与浏览器相关的。这意味着即使访问的是同一个页面,不同浏览器之间所保存的cookie也是不能互相访问的;
  • cookie可能被删除。因为每个cookie都是硬盘上的一个文件,因此很有可能被用户删除;
  • cookie安全性不够高。所有的cookie都是以纯文本的形式记录于文件中,因此如果要保存用户名密码等信息时,最好事先经过加密处理。

cookie的使用

  • 保存用户登录状态。例如将用户id存储于一个cookie内,这样当用户下次访问该页面时就不需要重新登录了,现在很多论坛和社区都提供这样的功能。 cookie还可以设置过期时间,当超过时间期限后,cookie就会自动消失。
  • 跟踪用户行为。例如一个天气预报网站,能够根据用户选择的地区显示当地的天气情况。如果每次都需要选择所在地是烦琐的,当利用了 cookie后就会显得很人性化了,系统能够记住上一次访问的地区,当下次再打开该页面时,它就会自动显示上次用户所在地区的天气情况。因为一切都是在后台完成,所以这样的页面就像为某个用户所定制的一样,使用起来非常方便。
  • 定制页面。如果网站提供了换肤或更换布局的功能,那么可以使用cookie来记录用户的选项,例如:背景色、分辨率等。当用户下次访问时,仍然可以保存上一次访问的界面风格。
  • 创建购物车。使用cookie来记录用户需要购买的商品,在结账的时候可以统一提交。例如淘宝网就使用cookie记录了用户曾经浏览过的商品,方便随时进行比较。
    当然,上述应用仅仅是cookie能完成的部分应用。
    cookie的使用及封装(自己动手封装)

添加cookie

<script>
    1、添加cookie
            如果cookie值没有添加过期时间,关闭浏览器cookie消失
            document.cookie='username=zhangsan';
            document.cookie='age=100';
        给cookie添加过期时间
            var d=new Date();//获取当前的系统时间
            alert(d.getDate()+10);
            d.setDate(377);
            d.setDate(d.getDate()+1000);//当前的日期+7之后的日期。重新赋值给日期对象。
            alert(d.toLocaleString());
            document.cookie='password=12345;expires='+d;
        自定义key和value 
            
        encodeURI/decodeURI  
            encodeURI:方法返回一个已编码的 URI。
            如果将编码结果传递给 decodeURI,则将返回初始的字符串。
            encodeURI 不对下列字符进行编码:“:”、“/”、“;”和“?”。
            function setcookie(key,value,day){
                var d=new Date();
                d.setDate(d.getDate()+day);
                document.cookie=key+'='+encodeURI(value)+';expires='+d;
            }
            
            
            setcookie('name','李四',7);
            setcookie('grade','1710',7);
            setcookie('age','1000',7);
            setcookie('worder','boss',7);
            
            setcookie('username','尼古拉斯赵四',7);
            
</script>

获取cookie

<script>
    2.获取cookie
            alert(decodeURI(document.cookie));//取出所有的cookie
            name=李四; grade=1710; age=1000; worder=boss
            var arr=decodeURI(document.cookie).split(';');//将cookie转换成数组
            console.log(arr);//["name=李四", " grade=1710", " age=1000", " worder=boss"]
            var newarr=arr[0].split('=');//name=李四
            console.log(newarr);//["name", "李四"]
            function getcookie(key){
                var arr=decodeURI(document.cookie).split('; ');
                for(var i=0;i<arr.length;i++){
                    var newarr=arr[i].split('=');
                    if(key==newarr[0]){
                        return newarr[1];
                    }
                }
            }
            alert(getcookie('username'));
</script>

删除cookie

<script>
    3.删除cookie
            function delcookie(key){
                setcookie(key,'',-1);
            }
            
            delcookie('worder');
            delcookie('name');
            delcookie('age');
            delcookie('grade');
</script>

总结:

<script>
        alert(document.cookie);//跨页面获取cookie,其他的浏览器是无法获取的。
        
    1.cookie存放的是字符串,取出的也是字符串
    2.将一个数组存放到cookie里面。存入没有问题。取出的是字符串
        
    var arr=['apple','banana','orange','pear'];
        
        
        toString():将对象转换成字符串。
    setcookie('fruit',arr.toString(),7);
        
        var newarr=getcookie('fruit');//不是数组。
    var newarr=getcookie('fruit').split(',');
        console.log(newarr);
        newarr.push('hehe');
        console.log(newarr);
        console.log(typeof newarr);*///string
    3.将一个对象存放到cookie里面。
        var obj={
            name:'zhangsan',
            age:100,
            sex:'男'
        }
        alert(obj);//[object object]强制将对象转换成字符串
        alert(String(obj));//[object Object]
        
        alert(JSON.stringify(obj));//JSON.stringify():将对应的对象转换成json格式的字符串
    var objstr=JSON.stringify(obj);
    setcookie('duixing',objstr,7);
        console.log(getcookie('duixing'));
        console.log(typeof getcookie('duixing'));
        var obj1=getcookie('duixing');//字符串
    var obj1=JSON.parse(getcookie('duixing'));//JSON.parse():将JSON格式的字符串转换成对象格式。
    console====.log(obj1.name);
</script>

了解XSS攻击(cross site script:跨站脚本攻击)

XSS攻击全称跨站脚本攻击,是为了不和层叠样式表(Cascading Style Sheets, CSS)的缩写混淆,故将跨站脚本攻击缩写为XSS,XSS是一种在web应用中的计算机安全漏洞,它允许恶意web用户将代码植入到提供给其它用户使用的页面中。

如何预防xss攻击:

对应用户的输入(url)要进行过滤。后端对你传入的内容一定进行过滤。
对于输出进行转义。
==过滤输入,转义输出==

数组、对象cookie的存储和访问。

应用

1.一周内免登陆。

2.商品浏览记录。

3.记录图片位置(拖拽:松开鼠标记录位置,鼠标按下之前取cookie赋值)。

4.照片墙的记录。

综合应用

1 . 购物车的操作。

一、escape/unescape

escape:escape 方法返回一个包含 charstring 内容的字符串值(Unicode 格式)。
所有空格、标点、 重音符号以及任何其他非 ASCII 字符都用 %xx 编码替换,其中 xx 等于表示该字符的十六进制数

unescape:从用 escape 方法编码的 String 对象中返回已解码的字符串
例外字符: @ * / +

二、encodeURI/decodeURI

encodeURI:方法返回一个已编码的 URI。如果将编码结果传递给 decodeURI,则将返回初始的字符串。encodeURI 不对下列字符进行编码:“:”、“/”、“;”和“?”。请使用 encodeURIComponent 对这些字符进行编码
decodeURI:从用encodeURI方法编码的String对象中返回已解码的字符串
例外字符:! @ # $ & * ( ) = : / ; ? + '

三、encodeURIComponent/decodeURIComponent

encodeURIComponent:encodeURIComponent 方法返回一个已编码的 URI。如果将编码结果传递给decodeURIComponent,则将返回初始的字符串。因为 encodeURIComponent 方法将对所有字符编码  
decodeURIComponent:从用encodeURIComponent方法编码的String对象中返回已解码的字符串  
例外字符:! * ( ) '
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 220,137评论 6 511
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,824评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,465评论 0 357
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,131评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,140评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,895评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,535评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,435评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,952评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,081评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,210评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,896评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,552评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,089评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,198评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,531评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,209评论 2 357

推荐阅读更多精彩内容