zoukankan      html  css  js  c++  java
  • 浏览器同源策略及Cookie的作用域

    所谓"同源"指的是"三个相同":

    1.协议相同
    2.域名相同
    3.端口相同

    当着三个地方相同才算同源

    例如:http://www.example.com:8888/dir/page.html

    协议是http://
    域名是www.example.com
    端口是8888

    采用同源策略的目的:是为了保证用户信息的安全,防止恶意的网站窃取数据。设想这样一种情况:A网站是一家银行,用户登录以后,又去浏览其他网站。

    如果其他网站可以读取A网站的 Cookie,会发生什么?如果 Cookie包含隐私(比如存款总额),这些信息就会泄漏。更可怕的是,Cookie 往往用来保存用

    户的登录状态,如果用户没有退出登录,其他网站就可以冒充用户,为所欲为。因为浏览器同时还规定,提交表单不受同源政策的限制。由此可见,"同源政

    策"是必需的,否则Cookie 可以共享,互联网就毫无安全可言了

    缺点:如果不是同源

    (1)Cookie、LocalStorage和IndexDB 无法读取
    (2)DOM无法获得
    (3)AJAX请求不能发送

    Cookie的作用域:

    Cookie有两个很重要的属性:Domain和Path,用来指示此Cookie的作用域:

      Domain告诉浏览器当前要添加的Cookie的域名归属,如果没有明确指明则默认为当前域名,比如通过访问www.vinceruan.info添加的Cookie的域名默认就是www.vinceruan.info,通过访问blog.vinceruan.info所生成的Cookie的域名就是blog.vinceruan.info

      Path告诉浏览器当前要添加的Cookie的路径归属,如果没有明确指明则默认为当前路径,比如通过访问www.vinceruan.info/java/hotspot.html添加的Cookie的默认路径就是/java/,通过blog.vinceruan.info/java/hotspot.html生成的Cookie的路径也是/java/

    浏览器提交的Cookie需要满足以下两点:

    1.当前域名或者父域名下的Cookie;
    2.当前路径或父路径下的Cookie

    要满足以上两个条件的Cookie才会被提交,例如:

    当访问blog.vinceruan.info时

    这里需要注意的是:在浏览器看来.

    www.vinceruan.info不是blog.vinceruan.info的父域名,而vinceruan.info才是blog.vinceruan.info的父域名,

    www.vinceruan.info也算是一个二级域名

    这点如果你提交过域名到DNS服务器商的应该会知道,一般我们需要显式提交www.vinceruan.info和vinceruan.info, 否则www.vinceruan.info==vinceruan.info是不成立的

    所以如果我们需要在所有二级域名下共享islogin=1的Cookie,用java代码如下:

    如果要在所有的二级域名下的/java/路径下共享silogin=1的Cookie,用java代码如下:

  • 相关阅读:
    test
    dd 命令 sd卡系统迁移
    关于庖丁分词
    Linux source命令
    Linux系统查看系统是32位还是64位方法总结 in 创新实训
    总结这两天连续干掉的bug In 创新实训 智能自然语言交流系
    穷举法应用——搬砖块
    判断素数类问题汇总
    统计计算学生成绩类问题汇总
    C语言简明数据类型指南
  • 原文地址:https://www.cnblogs.com/liaojie970/p/7606168.html
Copyright © 2011-2022 走看看