1

在有人抱怨之前,我不使用iframes(但在尝试修复错误时,我发现该问题与iframeIE9 中的一种奇怪行为有关,并且它是由其他人编码的)。

单击提交后,我有一个 JSON 被发送到 iframe:

    <a id="general_Submit.Label" class="formActionLink" href="javascript:submitAndSendEmail();"/>

    <form name="fileUploader" id="fileUploader" enctype="multipart/form-data" method="post" action="ajaxFileUploadAction.action" target="upload_target">
        <input type="file" name="upload" id="upload" size="40" onchange="dynFileUploader.uploadFile(this);" onkeyup="dynFileUploader.checkValidFile(this)" />
        <iframe name="upload_target" id="upload_target" src="" onload="javascript:dynFileUploader.uploadDone();"> </iframe>
    </form>

问题

操作正确返回了 JSON:

{"JSONClass":"com.lalala.process.email.util.FileContentHolder",
"contentType":"application/pdf","data":[],"fileLength":348364,
"fileName":"001a.<space>bla<space>refrigeration<space><space>-<space>aaa<space>- <space>Tenderer<space>Instructions.pdf",
"tempFileName":"C:\\Users\\humbleUser\\AppData\\Local\\Temp\\UPLOADED_7567343180347343279_001a.<space>bla<space>refrigeration<space><space>-<space>aaa<space>-<space>TendererInstructions.pdf"}

问题出在文件名中:在冷藏一词之后有两个空格。当我们将此 json 发送到 iframe 时,使用target="upload_target",它到达 iframe 时没有这些空格之一。例如:

如果我们有文件:test1.pdf,在 IE 中,它作为 test1.pdf 进入 iframe

为什么我们会有这种行为?当然,它不会发生在 Firefox 中。

4

1 回答 1

1

我可以看到没有人从未面对过它,我得出结论这是 IE 的另一种行为,它必须将连续的空格视为唯一一个。在搜索时,我注意到这是文件名的常见问题,正如我们在此链接中看到的那样。

无论如何,在我看来,这个问题的答案是它是来自 IE 的错误。我解决了我的错误(当用户试图上传一个文件名包含多个连续空格的文件时,它没有被正确保存,因为这些空格被减少到只有一个,所以我通过替换下划线的空格来修复它,它工作得很好!)

于 2013-03-27T14:01:31.160 回答