• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >心得技巧 > 重复提交、重复刷新、防止后退的问题以及处理方式分析

重复提交、重复刷新、防止后退的问题以及处理方式分析

作者:佚名 字体:[增加 减小] 来源:互联网 时间:2017-08-06

本文主要包含重复提交,重复刷新,防止后退等相关知识,佚名 希望在学习及工作中可以帮助到您
一。前言
你在任何一个比较专业的BBS都会看到这样的问题,即使你Google一下,也会发现有很多的人在关注和询问,但大家给出的解决方法却都是千差万别,(有的人主张采用脚本来解决;有的则想重定向到别的页面;有的则将此问题提升到Token的角度)为什么会有如此大的差异呢?
二。问题场景
首先,我们应该先了解为什么要处理这样的问题?或者专业一点就是它适合的场景是什么?(似乎只有人来问没有人来解释)
1。重复提交、重复刷新的场景
重复提交、重复刷新都是来解决系统重复记录的问题。也就是说某个人在多次的提交某条记录(为什么?也许是闲了没有事情干的;最有可能是用户根本就不知道自己的提交结果是否已经执行了?!)。
但出现了这样的问题并不见得就必须处理,要看你所开发的系统的类别而定。比如你接手的是某个资源管理系统,系统本身从需求的角度根本就不允许出现"重复"的记录,在这样需求的约束条件下,去执行重复的提交动作只会引发“业务级异常”的产生,根本就不可能执行成功也就无所谓避免不避免的问题了。
2。防止后退的场景
了解了重复刷新、重复提交的场景,我们来了解一下"防止后退"操作的原因是什么?比如你在开发某个投票系统,它有很多的步骤,并且这些步骤之间是有联系的,比如第一步会将某些信息发送给第二步,第二步缓存了这些信息,同时将自身的信息发送给了第三步。。。。。等等,如果此时用户处在第三步骤下,我们想象一下某个淘气用户的用户点击了后退按钮,此时屏幕出现了第二步骤的页面,他再次的修改或者再次的提交,进入到下一个步骤(也就是第三步骤),错误就会在此产生?!什么错误呢?最为典型的就是这样的操作直接导致了对于第一个步骤信息的丢失!(如果这样的信息是依靠Request存放的话,当然你可以存放在Session或者更大的上下文环境中,但这不是个好主意!关于信息存放的问题,下次在就这个问题详细的讨论)
三。如何处理的问题
当然很多的系统(比如订票系统从需求上本身是允许个人重复订票的)是必须要避免重复刷新、重复提交、以及防止后退的问题的,但即使是这样的问题,也要区分如何处理以及在哪里处理的(网上只是告诉你如何处理,但很少去区分在哪里处理的),显然处理的方式无非是客户端或者服务器端两种,而面对不同的位置处理的方式也是不同的,但有一点要事先声明:任何客户端(尤其是B/S端)的处理都是不可信任的,最好的也是最应该的是服务器端的处理方法。
客户端处理:
面对客户端我们可以使用Javascript脚本来解决,如下
1。重复刷新、重复提交
Ways One:设置一个变量,只允许提交一次。

防止网页后退--新开窗

您可能想查找下面的文章:

  • 重复提交、重复刷新、防止后退的问题以及处理方式分析

相关文章

  • 2018-08-23实战案例!新功能引导页设计思路总结
  • 2018-08-23好习惯学起来!帮新手提高效率的Sketch高频使用技巧
  • 2018-08-23更好的表单设计,从这6个设计策略开始
  • 2018-08-23不会自学,你永远只能是个三流设计师
  • 2018-08-23ofo小黄车是如何打造情感化设计的?来看总监的自述!
  • 2018-08-23产品设计前的「问题洞察」,你做到位了吗?
  • 2017-08-06重复提交、重复刷新、防止后退的问题以及处理方式分析
  • 2018-08-23关于六一儿童节页面设计,你早就该换个思路了!
  • 2017-08-06门户网站改版之用户体验
  • 2018-08-23UX设计师常用的英文单词汇总(持续更新)

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • 反馈机制这样设计,才能不让用户厌烦
    • 学会宜家效应,给你一个全新的设计思维!
    • Google对话式交互规范指南(八):通过确认和应答给予用户信心
    • 腾讯干货!如何从用户体验设计角度提升产品的安全感?
    • 整理CSS中遇到的一些常见问题(Hack标识/固定容器/图片垂直居中)
    • 紧跟趋势!聊聊C4D 在电商设计中的实战运用
    • Helvetica 字体60岁了,它是如何变成了人们生活中的日常?
    • 用一篇文章,帮你看懂微软最新发布的「流畅设计体系」!
    • 漫山遍野的多边形元素,正在入侵每一份设计稿
    • 超强干货!如何更加科学地提高文本可读性?

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有