Web系统的用户界面往往是通过html脚本在浏览器中显示出来,其中浏览器的刷新功能将重新提交当前页面的URL请求。这就会出现如下情况:从一个新增编辑页面存盘后返回到一个记录列表页面,在这个列表页面使用刷新键的时候,用户的意图应该是想刷新当前的记录列表,但是这时候提交的会是新增记录存盘的请求,这样就可能出现向服务器重复提交导致错误。 如何能够解决这个问题,首先要认识到提交存盘操作后的列表页面的URL请求与直接提交显示列表页面的URL请求对于客户端显示的刷新操作带来的不同效果,我们要是能将存盘操作后在客户端显示出的记录列表页面在客户端的页面属性和直接请求列表的的页面属性一样的话,就能够让刷新操作只提交列表显示的请求。我们可以利用java servlet所提供的redirect功能来将存盘功能和显示记录列表分开,在完成了存盘操作后给response设定显示记录列表的请求重定向返回到客户端浏览器,这样浏览器中显示的列表页面的请求属性是直接请求记录列表显示的URL,直接刷新页面的话则提交的也是记录列表页面显示的请求。 在目前流行的struts框架中,实现重定向很方便,只需要在配置文件struts-config.xml里面中的<forward脚本中加上redirect属性值为“true”,例如以下一个配置 <action path = "/saveRecord" type = "xxx.SaveRecordAction" name = "recordForm"> <forward name="success" path="/recordList.do" redirect="true"/> <forward name="fail" path="/recordEdit.do" redirect="true"/> </action> 设定记录存盘操作(/saveRecord.do)请求成功完成后,重定向到记录列表显示(/recordList.do)请求去,若操作失败则重定向到编辑界面(/recordEdit.do)继续修改。 需要注意的是重定向后的请求不会自动获得当前请求的request数据,当然包括各种form提交的数据,所以在实际运用中最烦人的可能是将重定向请求所需的各类参数设定到重定向的URL字串中。 对上面的配置例子,假设我们的/recordList.do请求需要一个参数是record_id=xxx,我们可以在xxx.SaveRecordAction里用以下代码来设定几个参数:
public ActionForward execute(ActionMapping mapping, ActionForm form, HttpServletRequest request, HttpServletResponse response) throws Exception { ...//略去处理存盘代码
ActionForward actForward = actionMapping.findForward("success"); String path = actForward.getPath(); path += "record_id=xxx"; return new ActionForward(actForward.getName(),path,true); //返回一个重定向ActionForword对象 }