• ASP.NET WebForm 检测页面刷新(Refresh)


    本文是翻译贴, 原文参见Detecting browser 'Refresh' from Code behind in C#

    浏览器的"刷新"常会导致问题, 特别是当页面和数据库有交互的时候, 结果可能更糟. 因为, 每次页面刷新, 如果没有经过代码处理, 就会重复做一次数据库操作.

    这就可能导致数据的不一致, 甚至程序挂掉.

    检测"刷新"的一种方法就是用JavaScript禁用掉F5和右击事件. 但就算这么做了, 终端用户还是有N种其它方法来刷新页面的, 比如, Ctrl+R.

    最好的防止"刷新"是代码被重复调用的方法还是在服务器端做检查, 并经行处理.

    下面的代码放在page_load方法中, 它可以检测"刷新":

    bool IsPageRefresh = false;
    //this section of code checks if the page postback is due to genuine submit by user or by pressing "refresh"
    if (!IsPostBack)
    {
        ViewState["ViewStateId"] = System.Guid.NewGuid().ToString();
        Session["SessionId"] = ViewState["ViewStateId"].ToString();
    }
    else
    {
        if (ViewState["ViewStateId"].ToString() != Session["SessionId"].ToString())
        {
            IsPageRefresh = true;
        }
        Session["SessionId"] = System.Guid.NewGuid().ToString();
        ViewState["ViewStateId"] = Session["SessionId"].ToString();
    }     

    (译注: 它是怎么工作的? 自己试试看吧 -- 有时候当搞清楚了问题本身, 解决问题的方法也就有了)

    之后, 就可以在后台代码中用"IsPageRefresh"来判断一个PostBack是来自用户点击按钮还是浏览器的"刷新"啦.

    希望对你有所帮助!

  • 相关阅读:
    云服务器迁移的那些事之一
    《编译原理》(第二版)第一章的学习笔记(一)
    vs 实用扩展
    SQL多的是,你不知道的事
    Entity Framework 批量插入 提速
    oracle 回收已删除的表
    发现一个奇怪的问题!
    看到易办网的希望...
    asp.net不认为数据库字段的空值为null
    什么是伪url?
  • 原文地址:https://www.cnblogs.com/Freeway/p/detecting-browser-refresh-from-code-behind-in-asp-dotnet.html
Copyright © 2020-2023  润新知