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

    unset火狐无效

    2016-06-23 13:55:21原创754
    unset($_SESSION['user']);
    火狐无效,谷歌是OK的,不知道为啥,火狐是不是有什么特别要求
    还有用火狐F12,会有安全问题,提示“密码字段出现在一个不安全的页面(http://)中。这是一个导致用户的登陆凭据可被窃取的安全风险。”
    使用POST提交的用户名和密码,但是用了iframe来获取处理登陆的php的内容,是不是这样做不安全


    回复讨论(解决方案)

    提示“密码字段出现在一个不安全的页面(http://)中。这是一个导致用户的登陆凭据可被窃取的安全风险。”
    意思就是你的密??出去?是明文,?有加密,容易被?取。用https就不?提示的。?句?可以不理的。

    是用?名和密?post到iframe ?面做???? 不?不安全啊。

    unset($_SESSION['user']) 不行?? ?句是在iframe?面?

    unset($_SESSION['user'])
    这句直接写在一个logout.php里,
    点击“退出”就会连接到这个文件,火狐里没法注销这个session,谷歌和360是正常的

    用firefox测试了一下。
    a.php



    b.php


    var_dump NULL 很正常。

    如果真的不能unset,可以执行$_SESSION['user'] = NULL;

    var_dump 输出是NULL
    找到原因了,原来是火狐回退不会刷新页面,判断登陆状态的js没有执行
    logout.php 里是这么写的
    unset($_SESSION['user']);
    echo "";

    火狐回退,$(document).ready(function(){}里的函数为啥不会运行呢
    谷歌是会运行的

    看?是你的firefox有??了。???了,一切正常。

    重新下了个火狐,还是一样,这情况是在太怪了

    以前写验证码类的时候碰到过这个问题
    window.onload的时候,我刷新了验证码图片
    火狐提交表单再后退验证码不变,IE刷新
    当时查了下资料,火狐的内核会为所有选项卡各自在内存中保存历史记录,当发生回退时其实仅仅读取了内存,js运行状态也就保存了下来。而IE内核的回退就好像是直接输入地址一样

    echo "";
    改成跳转header("Location:xx.php");试试

    session 是存放在服务器上的
    只要浏览器能传递正确的 sessionid ,其他的就与浏览器无关了

    unset($_SESSION['user']);
    并不能注销 session,而只是从 session中删去了 uesr 项
    显然这句是有条件执行的,所以你应检查删除的条件是否成立
    而传递删除条件就与浏览器有关了

    以前写验证码类的时候碰到过这个问题
    window.onload的时候,我刷新了验证码图片
    火狐提交表单再后退验证码不变,IE刷新
    当时查了下资料,火狐的内核会为所有选项卡各自在内存中保存历史记录,当发生回退时其实仅仅读取了内存,js运行状态也就保存了下来。而IE内核的回退就好像是直接输入地址一样


    那这个问题有啥办法解决不

    echo "";
    改成跳转header("Location:xx.php");试试


    改成这个就正常了。。

    session 是存放在服务器上的
    只要浏览器能传递正确的 sessionid ,其他的就与浏览器无关了

    unset($_SESSION['user']);
    并不能注销 session,而只是从 session中删去了 uesr 项
    显然这句是有条件执行的,所以你应检查删除的条件是否成立
    而传递删除条件就与浏览器有关了


    删除应该是成功的,因为火狐回退没效果,但是刷新一下就好了

    那这个问题有啥办法解决不



    像9楼那样,用php的header Location 或者window.location.href 避免程序中后退
    用户自己按后退那就是他的问题了

    用header('location: '.$_SERVER['HTTP_REFERER']);解决了,多谢大家

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:无效 火狐 unset
    上一篇:一些常用的PHP函数(整理) 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • 实例详解PHP统计代码行数及文件数量的方法• PHP命名空间和自动加载类,PHP命名空间加载类_PHP教程• PHP里8个鲜为人知的安全函数分析,php鲜为人知函数_PHP教程• PHP利用MySQL保存session的实现思路及示例代码,mysqlsession_PHP教程• 使用 PHP 限制下载速度_PHP教程
    1/1

    PHP中文网