`
leyifree
  • 浏览: 14565 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论
阅读更多
javascript操作cookie
转自:http://blog.sina.com.cn/s/blog_4909c13c010003wx.html
正如我们所知道的,在网络词汇中,cookie是一个特殊的信息,虽然只是服务器存于用户计算机上的一个文本文件,但由于其内容的不寻常性(与服务器有一定的互交性,且常会存储用户名,甚至口令,或是其它一些敏感信息,例如在江湖或是一些社区中,常会用cookie来保存用户集分,等级等等)。因而成为一些高手关注的对像,借此来取得特殊权限,甚至攻克整个网站。本人出些拙作,以java script中对cookie的应用,来说初步说明cookie欺骗的实现过程及具体应用。 
   
   (一)cookie的建立 
   
  在讲如何建立cookie之前,我们先来了解一下cookie的基本格式: 
   
  cookiename+cookievalue;expire=expirationdategmt;path=urlpath;domain=sitedomain 
   
  其中各项以;分开,首先是指定cookie的名称,并为其赋值。接下来分别是cookie的有效期,url路径以及域名,在这几项中,除了第一项以外,其它部分均为可先项。 
  下面我们来看一段代码,了解一下cookie究竟是怎样建立的: 
   
  <HTML> 
  <HEAD> 
  <TITLE>Set a cookie based on a form</TITLE> 
  <SCRIPT LANGUAGE="java script" TYPE="TEXT/java script"> 
  <!-- Hide script from older browsers 
   
  expireDate = new Date 
  expireDate.setMonth(expireDate.getMonth()+6) 
   
  userName = "" 
  if (documents .cookie != "") { 
  userName = documents .cookie.split("=")[1] 
  } 
   
  function setCookie() { 
  userName = document.myform.nameField.value 
  documents .cookie = "userName="+userName+";expires=" + expireDate.toGMTString() 
  } 
   
  // End hiding script --> 
  </SCRIPT> 
  </HEAD> 
  <BODY BGCOLOR="WHITE" onLoad="document.myform.nameField.value = userName"> 
  <form NAME="myform"> 
  <H1>Enter your name:<INPUT TYPE="TEXT" NAME="nameField" onBlur="setCookie()"></H1> 
  </form> 
  </BODY> 
  </HTML> 
   
  这是一锻简单的建立cookie的脚本。 
   
  1,<SCRIPT LANGUAGE="java script" TYPE="TEXT/java script"> 
   
  脚本开始的标记,由此一句告诉浏览器以下将是java script. 
   
  2,<!-- Hide script from older browsers 
   
  为了防止浏览器不能识别脚本,而让浏览器误以为是HTML注释而忽略它。 
   
  3,expireDate = new Date 
   
  获取当前日期,并存入变量expireDate中。 
   
  4,expireDate.setMonth(expireDate.getMonth()+6) 
   
  获取当前月份值,将其加6后设置为expireDate的月份总值部分。这意味着本cookie的有效期为6个月。 
   
  5,if (documents .cookie != "") 
   
  如果document的值不为空,相当于检查用户硬盘上是否已经有了cookie。 
   
  6,userName = documents .cookie.split("=")[1] 
   
  此处用到了split("=")函数,它的功能是把cookie记录分割为数组,cookie的名为cookie[0],值为cookie[1],以此累推。所以此处documents .cookie.split("=")[1]返回的值是此cookie的值。在此句中将值赋给了变量username。 
   
  7,function setCookie() 
   
  设置名为setCookie的函数。 
   
  8,documents .cookie = "userName="+userName+";expires=" + expireDate.toGMTString() 
   
  此句是将设置好的cookie写入用户硬盘。expireDate.toGMTString()把expireDate中的值转换为文本字符串,这 
  样才能写入cookie中。 
   
  9,onLoad="document.myform.nameField.value = userName" 
   
  当页面载入时,把username的值写入文本框(如果有的话)。 
   
  10,onBlur="setCookie()" 
   
  当用户离开文本框时,onBlur调用函数setCookie。 
   
  结合上面的注释,读那段代码相信不成问题吧!既然我们可以建立cookie,那么读取也不是什么难事,请接着往下看! 
   
   (二)读取和显示cookie 
   
  一般来说,cookie的作者并不希望cookie被显示出来,这是当然的!天知道里面写了些什么!?然而这也是我们想要读出它的原因!~~~:D 
   
  <HTML> 
  <HEAD> 
  <TITLE>Cookie Check</TITLE> 
  </HEAD> 
  <BODY BGCOLOR="WHITE"> 
  <H2> 
  <SCRIPT LANGUAGE="java script" TYPE="TEXT/java script"> 
  <!-- Hide script from older browsers 
   
  if (documents .cookie == "") { 
  document.write("There are no cookies here") 
  } 
  else { 
  thisCookie = documents .cookie.split("; ") 
   
  for (i=0; i<thisCookie.length; i++) { 
  document.write("Cookie name is '"+thisCookie.split("=")[0]) 
  document.write("', and the value is '"+thisCookie.split("=")[1]+"'<BR>") 
  } 
  } 
   
  // End hiding script --> 
  </SCRIPT> 
  </H2> 
  </BODY> 
  </HTML> 
   
  以上的便是一段读取cookie的名字和值的脚本。上文中解释过的语句在此不多赘述,且看有什么新的语法: 
   
  1,thisCookie = documents .cookie.split("; ")[注意:并非前文中出现过的split("=")。 
   
  split("; ")可以产生数组的结果,本句中,由documents .cookie.split("; ")来获取cookie的值,并将这个数组赋值缎带变量:thisCookie。 
   
  2,for (i=0; i<thisCookie.length; i++) 
   
  设置计算器变量i的值为0,如果其值小于thisCookie.length(thisCookie中值的个数),将i的值加1。 
   
  3,document.write("Cookie name is '"+thisCookie.split("=")[0]) 
   
  此句中thisCookie.split("=")[0]较难理解,上面的脚本中,thiscookie已经被赋值为一个数组的值,那么thisCookie是指数组中第i个值,也就是第i个cookie,而由上文可知split("=")[0]是指cookie的名字。 
  这样thisCookie.split("=")[0]便是第i的cookie中cookie的名字! 
   
  4,document.write("', and the value is '"+thisCookie.split("=")[1] 
   
  跟3极为相似,即是第i个cookie中 cookie的值。 
   
  到此,我们已经熟悉了如何建立cookie以及它的读取。这些也正是cookie欺骗也需要的主要技术!
   
   (三)cookie欺骗的实现 
   
  要做到cookie欺骗,最重要的是理解目标cookie中的储值情况,并设法改变它。由上面的学习我们知道,基于cookie的格式所限,一般来说,只有在Cookie.split("=")[0]和Cookie.split("=")[1]中的值对我们才是有用的。也就是说只需改变这两处或是处的值即可达到我们的目的。 
  而在实际操作中,还得先解决另一个问题。 
  由于受浏览器的内部cookie机制所限,每个cookie只能被它的原服务器所访问!可我们总不能跑到人家服务器上操作吧!这里就需要一个小技巧了。 
  在上面我们提到过cookie的格式,最后两项中分别是它的url路径和域名。不难想到,服务器对cookie的识别靠的就是这个! 
  而在平时,我们要浏览一个网站时,输入的url便是它的域名,需要经过域名管理系统dns将其转化为IP地址后进行连接的。这其中就有一个空当。如果能在dns上做手脚,把目标域名的IP地址对应到其它站点上,我们便可以非法访问目标站点的cookie了! 
  做到这一点并不难,当然我不并不是要去操纵dns,而且那也是不可能的事情。在win9下的安装目录下,有一名为hosts.sam的文件,以文本方式打开后会看到这样的格式: 
  127.0.0.1 lockhost #注释 
  利用它,我们便可以实现域名解析的本地化!而且其优先权高于网络中的dns! 
  具体使用时,只需将IP和域名依上面的格式添加,并另存为hosts即可!(注意:此文件无后赘名,并非hosts.sam 文件本身!) 
   
  到此,cookie欺骗所需的所以知识已经齐备。下面以一个“假”的例子,演示一下如何进入实战.(不便给出真实地址,以免引起犯罪!~~~:P) 
  假设目标站点是 www.xxx.com 
  www.self.com是自己的站点。(可以用来存放欺骗目标所需的文件,用来读取和修改对方的cookie.) 
  首先ping出www.self.com的IP地址: 
  ping www.self.com 
   
  Reply from 12.34.56.78: bytes=32 time=20ms TTL=244 
   
  然后修改hosts.sam文件如下: 
   
  12.34.56.78 www.xxx.com 
  并保存为hosts。 
   
  将用来读取cookie的页面传至www.self.com(脚本如二所示)。 
  此时连上www.xxx.com。由于我们已经对hosts动过手脚,这时来到的并不是www.xxx.com,而是www.self.com 
  www.xxx.com设在本地的cookie便可被读出!~~:D 
  然后根据具体情况修改一的脚本,用同样的方法,向此cookie中写入数据。修改完毕后,删掉hosts文件,再重新进入www.xxx.com,此时已经大功告成,可享受你的hack成果了!~~~:) 
   
  [编后] 
  cookie欺骗是一种发现较早,且较难使用的hack手法,除了java script 可以控制以外,asp等也可以用来对其进进设置。所以在此声名,未必能对所有站点有较。但技术真实,无须置疑! 
   
  补充:在win2000中hosts文件的建立与win98不同,需要c:\winnt\system32\drivers\etc文件夹中创建!
分享到:
评论

相关推荐

    javascript 操作cookie.js

    javascript 操作cookiejavascript 操作cookiejavascript 操作cookie

    Javascript Cookie操作类的封装

    接下来,我们来创建一个名为`CookieManager`的JavaScript类,用于封装Cookie的操作。这个类需要包含以下方法: 1. **setCookie**:用于设置Cookie。需要传入键(key)、值(value)以及可选的过期时间(days)和...

    javascript 对cookie 的读写操作

    javascript对cookie的日常操作

    C#和javascript操作cookie

    本文将详细探讨如何在C#后端和JavaScript前端中操作Cookie。 首先,C#在ASP.NET中处理Cookie主要通过`HttpCookie`类。创建一个Cookie的基本步骤如下: 1. **创建Cookie对象**:使用`new HttpCookie(string name)`...

    javascript cookie 操作框架 XCookie

    JavaScript Cookie 操作框架 XCookie 是一个用于方便地管理和操作浏览器cookies的工具,它简化了JavaScript中处理cookie的复杂性。在Web开发中,cookies经常被用来存储用户状态、会话信息或其他临时数据,而XCookie...

    javascript操作cookie

    ### JavaScript操作Cookie知识点详解 #### 一、Cookie简介 Cookie是一种小型的数据文件,通常由服务器发送到客户端(浏览器),客户端将这些数据存储在本地硬盘上,并在后续与该服务器进行交互时将数据发送回...

    CookiesjsJavaScript客户端的Cookie操作库

    "CookiejsJavaScript客户端的Cookie操作库" 指的是一种JavaScript库,专门用于在客户端(即用户浏览器)进行Cookie的操作。Cookiejs是这个库的名称,它提供了一组简单易用的API,帮助开发者方便地管理用户的Cookie。...

    javascript实现操作cookie实现的可记忆菜单

    javascript实现操作cookie实现的可记忆菜单

    使用JavaScript实现Cookie的增删改查操作

    JavaScript作为浏览器端的主要脚本语言,提供了操作Cookie的功能。本文将详细介绍如何使用JavaScript实现Cookie的增删改查操作。 首先,理解Cookie的基本概念是必要的。Cookie由服务器端设置,并发送到用户的浏览器...

    javascript实现cookie功能

    JavaScript是Web开发中的重要脚本语言,用于处理客户端的交互逻辑。在网页中实现Cookie功能是JavaScript的一个...通过学习和掌握JavaScript操作Cookie的方法,可以更好地理解和实践Web开发中的用户状态管理和会话管理。

    javascript针对cookie的基本操作实例详解.docx

    #### JavaScript操作Cookie的基本技巧 ### 一、设置Cookie 设置Cookie通常包括添加和修改功能。如果原有的Cookie名称已经存在,则添加此Cookie就相当于修改了此Cookie。设置Cookie时还可能包含一些额外的选项,例如...

    javascript操作cookie_获取与修改代码

    ### 知识点二:JavaScript操作Cookie的方法 在JavaScript中,我们可以直接通过操作`document.cookie`来读取和写入cookie值。不过这种方式较为原始,不方便维护和扩展。为了更好地管理cookie,我们可以封装一些方法...

    【JavaScript源代码】详解操作cookie的原生方法cookieStore.docx

    随着浏览器技术的发展,Chrome引入了一种新的API——`cookieStore`,它提供了更加便捷和安全的方式来操作Cookie。 1. 平时如何操作Cookie 通过`document.cookie`,我们可以实现对Cookie的读取、设置和删除。例如:...

    javascript操作Cookie(设置、读取、删除)方法详解

    通过以上三种操作Cookie的方法,开发者可以利用JavaScript在浏览器端灵活地管理Cookie。需要注意的是,Cookie的大小有限制,通常不超过4KB,并且在使用Cookie时还需要考虑用户隐私和安全的问题,避免存储敏感信息。...

    javascript 中Cookie读、写与删除操作.docx

    ### JavaScript中的Cookie读、写与删除操作详解 #### 前言 在现代Web开发中,前后端分离架构越来越流行,这导致了浏览器与服务器之间的数据交换变得尤为重要。Cookie作为一种简单而有效的方式,在用户状态管理方面...

    JavaScript数据存储 Cookie篇

    4. **操作Cookie的JavaScript方法** 在JavaScript中,我们可以通过`document.cookie`属性来读取和设置Cookie。然而,这个属性并不直接支持设置多个参数,所以通常需要自定义函数来处理: ```javascript var ...

    JS Cookie的操作

    你可以打开这个示例,了解在实际场景中如何使用JavaScript操作Cookie。 总结,了解和掌握JavaScript中的Cookie操作对于Web开发人员来说是必不可少的技能,它能帮助我们实现用户会话管理、个性化设置等功能。通过本...

    JQuery对cookie操作

    在提供的`cookieHandlerDom`文件中,可能包含了用于DOM操作的示例代码,演示了如何结合DOM元素和jQuery操作Cookie。例如,它可能包含一个按钮,当点击时,会在Cookie中存储一个值,然后在页面上显示这个值。通过分析...

    cookiejs一个用于处理浏览器cookie的简单轻量级JavaScriptAPI

    Cookie.js是一个专为JavaScript开发者设计的轻量级库,主要用于管理和操作浏览器中的cookie。这个库的主要优点是它的简洁性和低资源占用,使得它成为处理cookie的理想选择,尤其适用于那些对性能和加载速度有较高...

Global site tag (gtag.js) - Google Analytics