我有一个页面允许随着时间的推移逐步构建PDF文件(将信息保存到数据库)。我正在添加保存图像的功能。我目前有<g:uploadForm>
将文件发送回控制器中的upload
方法(然后调用服务)。但是,上传完成后,Grails会尝试呈现与upload
方法关联的视图,该视图最终成为空白页。我希望具有将文件发送到后端Grails的功能,而不需要重新加载视图(因为它将删除任何已输入但未保存的数据)。我还有一个使用JavaScript的工作版本向Grails服务器发出AJAX请求,但我更喜欢Grails解决方案。
以下是GSP的相关部分:
<g:uploadForm action="upload" useToken="true" id="5">
<div class="chooseFileButtonContainer">
<input type="file" name="imgfile" class="chooseFileButton" />
</div>
<div class="uploadFileButtonContainer">
<input type="button" value="Upload File" />
</div>
</g:uploadForm>
这是控制器:
def uploadToSP() {
if (params.imgfile) {
if (params.imgfile instanceof org.springframework.web.multipart.commons.CommonsMultipartFile) {
def (sectionID, reportID) = params.id.tokenize(':')
try {
Service.upload(params.imgfile, sectionID, reportID)
} catch (Exception e) {
System.err << "Upload Failed : " + e.getMessage() +"\n"
}
} else {
System.err << "Invalid file format\nExpected org.springframework.web.multipart.commons.CommonsMultipartFile\nGot ${params.imgfile.getClass()}\n"
}
} else {
System.err << "No file supplied\n"
}
response.sendError(200, "Done")
}
除了点击Upload
按钮后,所有内容都运行良好,它会转到mysite.com/myapplication/controller/upload/id:id
这样的网址,这只是一个空白页面(/id:id
部分是故意的)。
我可以使用JavaScript完成此操作,但我对Groovy / Grails-only解决方案感兴趣。 我的问题是如何在不加载新视图的情况下使用控制器方法。
答案 0 :(得分:1)
通常,听起来您需要查看请求和上传的ajax处理,而不仅仅是完整的请求/响应周期。有很多关于如何使用JQuery或普通javascript上传文件的示例,或者您想要使用的任何框架。看看其中一个,我想你会发现它提供了你正在寻找的解决方案。
答案 1 :(得分:0)
据我所知,很多研究都没有办法。它归结为Grails的“约定优于配置”。当调用控制器中的函数时,它总是想要渲染一个新视图,因为这就是Grails的工作方式。我可以得到的最接近的是再次渲染当前页面,但这并不完全相同。
实际上,解决方案是使用AJAX,但问题的答案是没有渲染新视图就无法调用控制器。