这个问题困扰了我几天
一般的提交加查询等待好加啊:因为用ajax可以。可是这个excel导出我这只会用form提交的方式。
刚开始想像的挺好:在form提交的同时加一个ajax+interval 监听session中的变量(导出完成标志),监听到了改变就释放查询等待。后来一想不行啊,这不是对服务器的压力很大吗(若干毫秒ajax一次)
后来又想在ajax监听对应的action方法中加定时器轮询监听session中的变量,那不行,timer和ajax的返回是两条线了,失败了。
又改方法了:用synchronizded 同步,锁用的是session中的一个对象,就是用户信息。ajax监听wait着,等导出的快完了,notifyAll, ajax监听返回,页面上的查询等待去除掉了。
还有问题是,在页面上出现了下载提示框(浏览器的),当点击取消的时候,查询等待没反应。(因为点击取消后方法里写入outputstream的地方就停在那了,而点击下载或打开的时候,写入outputstream的地方才会进行下去),这怎么办,把notifyAll移到了写入outputstream之前。
这样,能实现了,虽然在出现下载框之前有一小段时间没遮罩(写入outputstream,时间很短的,不过眼睛还是能看到)。