DSpace,Error edit-item,包含1000多个比特流

时间:2016-11-25 17:38:45

标签: java tomcat dspace

我在尝试使用1000个比特流编辑DSpace中文件的元数据字段时遇到错误。

我在使用Ubuntu 14.04的计算机上使用DSpace v5.1和Apache Tomcat 8.0.26。

我有一个包含超过3000个项目的存储库,每个项目具有不同数量的比特流(1到200)。我已经成功插入了一个包含1000个比特流的文档,但是当我要通过JSPUI编辑元数据字段时,服务器会返回一条内部错误消息。首先,我认为这是由于HTTP请求中的参数数量过多,因此我将Tomcat的HTTP连接器配置中的最大参数数量修改为小于零(在conf / server.xml处为maxParameterCount="-1") ,所以它没有参数数量的限制。当错误发生时,Tomcat的日志没有任何问题,所以我认为它与DSpace有关。

DSpace(dspace.log.2016-11-25文件)中的错误日志如下:

java.lang.NullPointerException
    at org.dspace.handle.HandleManager.findHandle(HandleManager.java:404)
    at org.dspace.app.webui.servlet.admin.EditItemServlet.doDSPost(EditItemServlet.java:207)
    at org.dspace.app.webui.servlet.DSpaceServlet.processRequest(DSpaceServlet.java:115)
    at org.dspace.app.webui.servlet.DSpaceServlet.doPost(DSpaceServlet.java:73)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:648)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:729)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:291)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:239)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at org.dspace.app.webui.filter.RegisteredOnlyFilter.doFilter(RegisteredOnlyFilter.java:66)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:239)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at org.dspace.utils.servlet.DSpaceWebappServletFilter.doFilter(DSpaceWebappServletFilter.java:78)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:239)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:219)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:106)
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:502)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:142)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:79)
    at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:616)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:88)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:518)
    at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1091)
    at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:673)
    at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1526)
    at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.run(NioEndpoint.java:1482)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
    at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
    at java.lang.Thread.run(Thread.java:745)

关于如何解决这个问题的任何想法?

非常感谢你的帮助

1 个答案:

答案 0 :(得分:0)

我刚遇到这个问题。感谢您的线索,我找到了解决方案。

你必须增加" maxPostSize"太。当存在许多比特流时,默认值2mb对于DSpace是不够的。我有大约300个比特流,编辑时它已超过2mb POST。