谢谢
但是还有两个问题
1,返回之后没有刚才输入的值了,这样对于用户不太方便~~~
2,我传送的是用户名密码,如果放在url里是不是不太合适?为什么另外一个post发送的叶面不会过期呢?奇怪
我是将它提交到了一个php叶面,然后php根据得到的信息返回另外一个叶面让用户确认自己刚输入的信息,同意就继续,否则返回,这样就正常,返回仍然文本匡里都有值跟那个老过期的叶面好像就这点区别~其他地方好像就没有了~~

解决方案 »

  1.   

    尽量不用history.go(-1)
    你用post传递后取一下显示就可以.页面过期是IE缓冲的问题.或者放到客户cookie中.
      

  2.   

    //你用post传递后取一下显示就可以.
    在我这边实现起来却是挺麻烦的~~~
    我用另外的函数调用魔板,错误的话显示错误的魔板并且用history.go返回,但是如果根据post来显示就需要再加一些代码并且再加一个魔板文件(用来显示用户刚才填写的信息)
    有没有什么别的方法呢??
    IE的这个确实很奇怪,post完了之后他到把数据放到什么地方了??为什么有时候返回还可以正常显示
      

  3.   

    用这样子就没问题啊. PHP不熟悉 :)
    直接用Post如果不成功弹出个提示框,然后,用history.go(-1)返回到输入页面
    这样的话,刚才输入的信息就还在.demo.htm<form action="demo.asp" method="post">
    用户名:<input type="text" name="userid"/>
    密码:<input type="text" name="pwd"/>
    <input type="submit">
    </form>demo.asp<%
    if Request.Form("userid") <> "wanghr100" or Request.Form("pwd") <> "bao"  then
     Response.Write "<script>alert('用户或密码有错.');history.go(-1)</script>"
    else
     Response.Write "登陆成功"
    end if
    %>
      

  4.   

    demo.php
    <?
       if ($_POST['userid'] != "wanghr100" || $_POST['pwd'] != "bao")
       {
           echo "<script>alert('用户或密码有错.');history.go(-1)</script>";
        }
       else
         echo "登录成功";
    ?>
      

  5.   

    抱歉~现在本本不在身边~我回头试一下~~history.back()跟那个原理不是一样的么?
      

  6.   

    谢谢!用alert弹出窗口没问题~!
    请原谅我再多句嘴,返回时不会过期了,但是输入的数据没有了~这样对用户来说很麻烦~有没有什么办法呢?
      

  7.   

    又不行了!~~~现在我放到网上了请大家指教http://haohan.bdcf.net/shop/register.php?step=threedeadcat这个用户名是注册过得可用来做测试
    我的用意是,如果用户名重复就返回~~结果返回拉就过期了~~
      

  8.   

    在IE中如何让用户按“后退”键后使“向前”键失效?????  
    ---------------------------------------------------------------  
     
    二、禁止缓存    
     
        在我找到的许多方案中,其中有一种建议禁止页面缓存。具体是使用服务器端脚本,如下所示:    
     
    <%    
     
    Response.Buffer  =  True    
     
    Response.ExpiresAbsolute  =  Now()  -  1    
     
    Response.Expires  =  0    
     
    Response.CacheControl  =  "no-cache"    
     
    %>    
     
        这种方法非常有效!它强制浏览器重新访问服务器下载页面,而不是从缓存读取页面。使用这种方法时,编程者的主  
    要任务是创建一个会话级的变量,通过这个变量确定用户是否仍旧可以查看那个不适合通过后退按钮访问的页面。由于浏  
    览器不再缓存这个页面,当用户点击后退按钮时浏览器将重新下载该页面,此时程序就可以检查那个会话变量,看看是否  
    应该允许用户打开这个页面。    
     
        例如,假设我们有如下表单:    
    <%    
     
    Response.Buffer  =  True    
    Response.ExpiresAbsolute  =  Now()  -  1    
    Response.Expires  =  0    
    Response.CacheControl  =  "no-cache"    
    If  Len(Session("FirstTimeToPage"))  >  0  then    
    &single;  用户已经访问过当前页面,现在是再次返回访问。    
    &single;  清除会话变量,将用户重定向到登录页面。    
    Session("FirstTimeToPage")  =  ""    
    Response.Redirect  "/Bar.asp"    
    Response.End    
    End  If    
    &single;  如果程序运行到这里,说明用户能够查看当前页面    
    &single;  以下开始创建表单    
    %>    
    <form  method=post  action="SomePage.asp">    
    <input  type=submit>    
    </form>    
     
        我们借助会话变量FirstTimeToPage检查用户是否是第一次访问当前页面。如果不是第一次(即Session  
    ("FirstTimeToPage")包含某个值),那么我们就清除会话变量的值,然后把用户重新定向到一个开始页面。这样,当表单  
    提交时(此时SompePage.asp被打开),我们必须赋予FirstTimeToPage一个值。即,在SomePage.asp中我们需要加上下面  
    的代码:    
     
    Session("FirstTimeToPage")  =  "NO"    
     
        这样,已经打开SomePage.asp的用户如果点击后退按钮,浏览器将重新请求服务器下载页面,服务器检查到Session  
    ("FirstTimeToPage")包含了一个值,于是就清除Session("FirstTimeToPage"),并把用户重定向到其他页面。当然,所有  
    这一切都需要用户启用了Cookie,否则会话变量将是无效的。(有关该问题的更多说明,请参见For  session  variables    
    to  work,  must  the  Web  visitor  have  cookies  enabled?)    
        另外,我们也可以用客户端代码使浏览器不再缓存Web页面:    
     
    <html>    
    <head>    
    <meta  http-equiv="Expires"  CONTENT="0">    
    <meta  http-equiv="Cache-Control"  CONTENT="no-cache">    
    <meta  http-equiv="Pragma"  CONTENT="no-cache">    
    </head>    
     
        如果使用上面的方法强制浏览器不再缓存Web页面,必须注意以下几点:    
    只有在使用安全连接时“Pragma:  no-cache”才防止浏览器缓存页面。对于不受安全保护的页面,“Pragma:  no-cache”  
    被视为与“Expires:  -1”相同,此时浏览器仍旧缓存页面,但把页面标记为立即过期。    
    在IE  4或5中,“Cache-Control”META  HTTP-EQUIV标记将被忽略,不起作用。    
        在实际应用中我们可以加上所有这些代码。然而,由于这种方法不能适用于所有的浏览器,所以是不推荐使用的。但  
    如果是在Intranet环境下,管理员可以控制用户使用哪种浏览器,我想还是有人会使用这种方法。    
     
    三、其他方法    
        接下来我们要讨论的方法以后退按钮本身为中心,而不是浏览器缓存。这儿有一篇文章Rewiring  the  Back  Button很  
    值得参考。不过我注意到,如果使用这种方法,虽然用户点击一下后退按钮时他不会看到以前输入数据的页面,但只要点  
    击两次就可以,这可不是我们希望的效果,因为很多时候,固执的用户总是能够找到绕过预防措施的办法。    
        另外一种禁用后退按钮的办法是用客户端JavaScript打开一个没有工具条的窗口,这使得用户很难返回前一页面,但  
    不是不可能。一种更安全但相当恼人的方法是,当表单提交时打开一个新的窗口,与此同时关闭表单所在的窗口。但我觉  
    得这种方法不值得认真考虑,因为我们总不能让用户每提交一个表单就打开一个新窗口。    
        那么,在那个我们不想让用户返回的页面是否也可以加入JavaScript代码呢?在这个页面中加入的JavaScript代码可  
    用来产生点击前进按钮的效果,这样也就抵消了用户点击后退按钮所产生的动作。用于实现该功能的JavaScript代码如下  
    所示:    
     
    <script  language="JavaScript">    
    <!--    
    javascript:window.history.forward(1);    
    //-->    
    </script>    
     
        同样地,这种方法虽然有效,但距离“最好的方法”还差得很远。后来我又看到有人建议用location.replace从一个  
    页面转到另一个页面。这种方法的原理是,用新页面的URL替换当前的历史纪录,这样浏览历史记录中就只有一个页面,后  
    退按钮永远不会变为可用。我想这可能正是许多人所寻求的方法,但这种方法仍旧不是任何情况下的最好方法。使用这种  
    方法的实例如下所示:    
     
    <A  HREF="PageName.htm"  onclick="javascript:location.replace(this.href);    
     
    event.returnValue=false;  ">    
     
    禁止后退到本页面的链接</A>    
        禁止后退到本页面的链接!    
        这种方法的缺点在于:简单地运用Response.Redirect将不再有效,这是因为每次用户从一个页面转到另一个页面,  
    我们都必须用客户端代码清除location.history。另外还要注意,这种方法清除的是最后一个访问历史记录,而不是全部  
    的访问记录。    
        点击上面的链接,你将打开一个简单的HTML页面。再点击后退按钮,你可以看到这时打开的不是本页面,而是本页面  
    之前的页面!(当然,你必须在浏览器中启用了客户端JavaScript代码。)    
        经过一番仔细的寻寻觅觅之后,我发现仍旧无法找出真正能够完全禁用浏览器后退按钮的办法。所有这里介绍的方法  
    都能够在不同程度上、以不同的方式禁止用户返回前一页面,但它们都有各自的局限。由于不存在能够完全禁用后退按钮  
    的方法,所以最好的方案应该是:混合运用客户端脚本和服务器端脚本。    
     
    ---------------------------------------------------------------  
     
    你指的“后退”、“向前”到底是哪个键,不过不管哪个键,你都可以参见以下的方法实现:  
    用js,代码如下<body  onkeydown="if(event.keyCode==8)event.returnValue=false">上面的8为backspace的键码  
     
    你可以用下面的方法获得所需键码(键码显示在状态栏中)  
    <body  onkeydown="window.status=event.keyCode">