欢迎光临
我们一直在努力

“asp.net ajax rc1(疑似缺陷)”及”url重写”及”浏览器缓存”三个凑到一块后的问题_asp.net技巧

建站超值云服务器,限时71元/月

小弟最近被迫使用Ajax,于是使用了asp.net ajax来实现,恩,那个简单呀,三下两下就搞定了…但问题也立马就出来了,和我的url重写冲突了,我的url重写模块是我自己写的,做了一个过滤器早就把服务器form的提交位置有错的问题解决过,但是现在只要是第2次使用ajax做回发,就会报告404错误,来cnblogs看到有人说到此问题,居然说通过修改action的方式可以解决,很纳闷,action那我早就解决过,而且看起来也是最好的解决办法…于是开了个钩子程序,抓了ie每次的最终post地址,发现在ajax第2次回发之后,就会将他的提交地(不是页面的action而是aspnet ajax内部用js生成的一个叫form._initialAction的东西)址改为相对路径,当然会有问题了,所以请发现url重写与ajax冲突的兄弟,注意测试好这个问题,不要让东西上了线才发现问题…更不要认为修改了action就万事大吉了…这个问题,其实我更认为是“ASP.NET AJAX RC1”的缺陷,为什么要用相对路径呢?老实点直接把action拿过来,不要搞那么多奇怪的处理不是更好吗?当然了,我并不了解他的设计原理,估计也是有他自己的理由吧,解决这个问题的相关代码如下:


    <!–Ajax脚本管理器–>
    <asp:ScriptManager ID=”ScriptManager1″ runat=”server”></asp:ScriptManager>
    <script type=”text/javascript”>
    Sys.Application.add_load(function()
    {
        var form = Sys.WebForms.PageRequestManager.getInstance()._form;
        var href = window.location.href;
        if(href.indexOf(“?”) > 0)
        {
            href += “&a=” + Math.random();
        }
        else
        {
            href += “?a=” + Math.random();
        }
       
        form._initialAction = href;
        form.action = href;
    });
    </script>
大家可能注意到了,这段代码给地址加了个随机数,其实是为了解决后面个问题(浏览器缓存冲突)的,不过并没有解决好。。。


OK,重写冲突解决了,第2个问题又发生了。。。经过推测,我觉得是浏览器缓存的问题,我做了一个tags的添加删除的功能,添加就不用多说了,删除就是在Repeater中放了个ImageButton,通过他的click事件,使用CommandName把当前tag传回去并删除掉,这时候问题出现了,当我添加多个tag后,点其中一个删除,updatepanel中的tags列表返回了添加第1个之前的状态,于是我很怀疑是浏览器缓存的问题,我又很傻的在server代码中加入了             Response.Cache.SetNoStore();
            Response.Cache.SetLastModified(DateTime.Now);希望可以解决问题,但事实上根本没用,呵呵,于是我又通过上面那段js代码,在赋予form._initialAction的时候给url的最后加了一个随机数,结果还是无效。。。猜想问题估计是出现在这个随机数并没有每次得到效果,但我又真是没时间去深入的理解asp.net ajax的原理,所以希望知道此问题如何解决的哥们先帮兄弟解决一下,小地回头再去研究。
http://www.cnblogs.com/cnlamar/archive/2007/01/08/614671.html

赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » “asp.net ajax rc1(疑似缺陷)”及”url重写”及”浏览器缓存”三个凑到一块后的问题_asp.net技巧
分享到: 更多 (0)