java中的自定义ckeditor fileUpload with apache fileUpload parseRequest返回空列表

时间:2015-12-08 19:56:36

标签: java file-upload ckeditor seam apache-commons

我有一个接缝2.2.2应用程序,我正在尝试自定义ckeditor fileUpload插件。

我提出的解决方案是:

1)使用'editor'样式类为所有元素启动编辑器:

var elements = CKEDITOR.document.find('.editor');
for(var i = 0; i< elements["$"].length; i++){
        CKEDITOR.replace(elements["$"][i], {
            filebrowserUploadUrl: rootPath + "/cops/filebrowserUploadUrl.seam"
        });
    }

2)设置filebrowserUploadUrl.seam,除了执行之外什么都不做:

#{attachmentController.sendImageToServer()}

3)用apache commons fileUpload实现后端:

public void sendImageToServer()
{       
    HttpServletRequest request = ServletContexts.instance().getRequest();
    DiskFileItemFactory factory = new DiskFileItemFactory();

    File repository = (File) request.getAttribute("javax.servlet.context.tempdir");
    factory.setRepository(repository);
    ServletFileUpload upload = new ServletFileUpload(factory);

    try
    {
        List<FileItem> items = upload.parseRequest(request);
        processItems(items); //set the file data to specific att
        saveOpenAttachment(); //save the file to disk
    }

这个方法被称为好。我可以在请求中对上传参数(包含一些二进制数据)进行debbug,但upload.parseRequest(request)返回一个空列表。我已经搜索了这个问题,我做了我能做的一切,但我无法判断应用程序自定义FaceletViewHandler是否导致了这个问题。 虽然如果我能找到解决这个问题的方法,我会非常满意,我觉得这不是一个好的解决方案。也许将Seam与facelets集成可以为我提供更好的解决方案。我真的不知道。 有什么建议吗?

1 个答案:

答案 0 :(得分:0)

最终解决方案就像Seam多部分过滤器句柄请求:

ServletRequest request = (ServletRequest) FacesContext.getCurrentInstance().getExternalContext().getRequest();
try
{
  if (!(request instanceof MultipartRequest))
  {
     request = unwrapMultipartRequest(request);
  }

  if (request instanceof MultipartRequest)
  {
     MultipartRequest multipartRequest = (MultipartRequest) request;

     String clientId = "upload";
     setFileData(multipartRequest.getFileBytes(clientId));
     setFileContentType(multipartRequest.getFileContentType(clientId));
     setFileName(multipartRequest.getFileName(clientId));
     saveOpenAttachment();
  }
}

现在我处理像Seam那样的请求,并且不需要web:multipart-filter配置,它会破坏其他类型的请求。