And*_*rie 0 javascript lotus-notes xpages
生成存储在便笺文档中的附件的URL时,我遇到了一个奇怪的问题.
显示notes文档的Xpage有一个repeat,它使用以下代码从body字段中检索嵌入的对象:
var doc:NotesDocument = docEmail.getDocument();
if (doc.hasEmbedded()){
var rtItem:NotesRichTextItem = doc.getFirstItem("Body");
return rtItem.getEmbeddedObjects()
}
Run Code Online (Sandbox Code Playgroud)
然后我有一个隐藏的输入字段,用于存储此代码生成的URL(colBodyAttachments是重复集合名称):
var doc:NotesDocument = docEmail.getDocument();
var dbComms = doc.getParentDatabase();
var dbServer = ReturnSvrHostName(dbComms.getServer())
var dbPath = @ReplaceSubstring(dbComms.getFilePath(), '\\', '/');
var attachmentName = colBodyAttachments.getName()
return "http://" + dbServer + "/" + dbPath + "/0/" + doc.getUniversalID() + "/$FILE/" + attachmentName
Run Code Online (Sandbox Code Playgroud)
这在99.9%的文档上工作正常但是当我的附件具有这样的名称时它似乎没有正确生成URL:"120531.Whytes Invoice#701537.pdf"
生成的URL如下所示:
http://website.com/database.nsf/0/ABA667304AB04454CC257A4F0015D321/ $ FILE/120531.Whytes%20Invoice%20#701537.pdf
它不会在#之后对%20进行编码,即使我尝试这样做,我仍然会得到"未找到项目的例外".存在哈希时是否存在编码URL的问题?或者当存在哈希时多米诺骨牌找到附件?
#符号会破坏网址.它是位置和该位置内的位置之间的分隔符.你需要对它进行编码.xpages附件也遵循略有不同的格式.请参阅:http://www.wissel.net/blog/d6plinks/SHWL-86QKNM