精通Grails: 文件上传和Atom联合 - 编程入门网
le}</g:link></h2>
<p>${entryInstance.summary}</p> <g:displayFile
filename="${entryInstance.filename}"
user="${entryInstance.author.login}" /></div>
重新启动 Grails,并再次上传 Grails 徽标。在添加对其他文件类型的支持之前,应该确保 TagLib 重构没有破坏已有的功能。 现在,可以确信仍可以上传图像。接下来就是添加对其他文件类型的支持,这只需在 switch 块中实 现适当的 case。清单 14 演示如何处理上传的 HTML 文件,以及为默认的 case 创建一个链接来下载该 文件: 清单 14. 完整的 switch/case 块 class EntryTagLib { def displayFile = {attrs, body-> def user = attrs ["user"] def filename = attrs["filename"] if(filename) { def extension = filename.split("\\.")[-1] def userDir = "payload/${user}" switch(extension.toUpperCase()){ case ["JPG", "PNG", "GIF"]: //SNIP break case "HTML": def webRootDir = servletContext.getRealPath("/") out << new File (webRootDir+"/"+userDir, filename).text break default: def html = """ <p> <a href="${createLinkTo(dir:''''+userDir, file:''''+filename)}">${filename}</a> </p> """ out << html break } }else{ out << "<!-- no file -->" } }} 精通Grails: 文件上传和Atom联合(9)时间:2011-08-02 IBM Scott Davis创建两个新的文本文件,以便测试这个新的行为:一个名为 test.html,另一个名为 noextension。 将清单 15 中的内容添加到适当的文件中,上传该文件,确认 TagLib 是否按预期显示每个文件: 清单 15. 用于上传的两个示例文件 //test.html<p>This is some <b>test</b> HTML.</p><p>Here is a link to the <a href="http://grails.org">Grails</a> homepage.</p><p>And here is a link to the <img src="http://grails.org/images/grails-logo.png">Grails Logo</img>.</p>//noextensionThis file doesn''t have an extension. Web 浏览器看上去应该如图 3 所示: 图 3. 显示所有 3 种类型的上传的文件 添加 Atom feed 至此,您应该明白一种截然不同的模式构成。对于添加到 Grails 应用程序的每个新特性,很可能都 要涉及模型、视图和控制器。您还可以额外添加局部模板或 TagLib。 将 Atom feed 添加到 Blogito 同样也遵从该模式。虽然不要求更改模型,但最终要做所有其他的事 情。您将: 在 Entry 控制器中添加一个闭包,以处理 Atom 请求。 创建一个新的 GSP 页面,用于以格式良好的 Atom 文档的形式呈现结果。 创建一个新的局部模板和一个新的定制标记,以加快进程。 本来您可以安装一个很好的 Feeds 插件,该插件可以为 Grails 应用程序添加 RSS 和 Atom 功能, 但是我认为您将发现,Atom 格式非常简单,您自己完全可以应付。为证明这一点,您可以查看已有的 Atom feed 的源代码,或者查看关于 Ato |
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |