Day13 通信协议、cookie

2018-01-15  本文已影响0人  azure_1122

通信协议

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

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

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的使用

添加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对象中返回已解码的字符串  
例外字符:! * ( ) '
上一篇 下一篇

猜你喜欢

热点阅读