当前位置: 首页 > 面试题库 >

有条件地提供文件下载或显示导出验证错误消息

沈自珍
2023-03-14
问题内容

我一直在研究CRUD应用程序,我需要将数据从数据库导出到csv文件。为了导出,我不得不以以下代码所示的方式禁用ajax:

<p:commandButton value="Export" ajax="false" action="myController.export"/>

在调用的方法中,我创建文件并通过OmniFaces实用程序方法下载该文件:

Faces.sendFile(file, true);

使用相同的方法,我检查实际上是否有任何数据,并且如果没有任何数据,则显示警告对话框:

RequestContext.getCurrentInstance().showMessageInDialog(new FacesMessage(FacesMessage.SEVERITY_WARN, "Warning!", "No available data for export."));

现在,尽管所有这些操作都能按预期工作,但是问题在于,由于禁用了ajax,因此无法动态显示对话框,并且需要重新加载页面。如果启用了ajax,则会动态显示对话框,但文件下载不会开始。

我一直在尝试通过使用Monitor
download
或通过强制单击第二个按钮来解决此问题,但是到目前为止,我在此问题上尚未取得任何进展。

有没有普遍接受的解决此类问题的方法?


问题答案:

有没有普遍接受的解决此类问题的方法?

基本上,您首先要触发ajax请求,并在其oncomplete检查中是否成功,然后触发同步请求以下载文件(请注意,您无法使用ajax下载文件)。您可以使用FacesContext#validationFailed()(或OmniFaces
Faces.validationFailed())标记验证失败状态,该状态可以通过argsPrimeFaces在oncomplete函数上下文中注入的对象获得(请注意,与ajax相关的属性(例如,oncomplete禁用ajax时不起作用))。

像这样:

<p:commandButton 
    value="Export" 
    action="#{bean.export}" 
    oncomplete="if (args &amp;&amp; !args.validationFailed) PF('download').jq.click()" />
<p:commandButton 
    widgetVar="download" 
    styleClass="ui-helper-hidden" 
    action="#{bean.download}" ajax="false" />



public void export() {
    // Prepare file locally.

    if (fail) {
        // Show message your way and then set validation failed as below.
        Faces.validationFailed();
    }
}

public void download() throws IOException {
    Faces.sendFile(file, true);

    // Delete local file afterwards?
}

请注意,<p:commandButton>正在使用隐藏而不是<p:remoteCommand>后者不支持ajax="false"



 类似资料:
  • 我有一个服务类,用 我想在启动服务时显示一条自定义消息,内容如下 有办法做到这一点吗?由于bean没有加载,我不能使用或类似的东西

  • 问题内容: 我有一个带有两个输入文本框的表单,并且我包括了两个的jQuery验证规则: 我用过了: 突出显示错误控制。现在的问题是,在以下情况下,两个输入文本框都保持突出显示(背景色:红色): 在文本框1中输入少于5个字符的文本 将文本框2留空 点击提交 两个输入文本框的背景都将更改为红色(正确) 现在,在文本框1中输入一个包含6个字符的文本(有效输入) 将文本框2留空 点击提交 两个文本框的背景

  • 问题内容: 我有一个表格,如果单击“提交”,则需要显示验证错误消息。 这是一个工作的家伙 用户开始进行更改时,验证工作正常。但是它不会显示任何错误消息。如果单击“提交”而不输入任何内容。 有实现这个的想法吗?或者以其他方式如何在单击“提交”按钮时使每个输入字段$ dirty 问题答案: 我在http://jsfiddle.net/thomporter/ANxmv/2/上找到了这个小提琴,它巧妙地进

  • 因此,很明显,它识别出输入的名称太短,但我在视图中没有得到任何错误消息,正如这里所预期的:。

  • 问题内容: 我在隐藏的文本区域中有一些文本。单击按钮后,我希望提供文本作为文件下载。是否可以使用AngularJS或Javascript? 问题答案: 您可以使用进行类似的操作。 在您的控制器中: 为了启用URL: 请注意 每次调用createObjectURL()时,都会创建一个新的对象URL,即使您已经为同一对象创建了一个URL。当不再需要它们时,必须通过调用URL.revokeObjectU