美文网首页
Day13 通信协议、cookie

Day13 通信协议、cookie

作者: azure_1122 | 来源:发表于2018-01-15 11:20 被阅读0次

通信协议

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

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

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

相关文章

网友评论

      本文标题:Day13 通信协议、cookie

      本文链接:https://www.haomeiwen.com/subject/zbproxtx.html