2016-06-20 1 views
0

У меня есть сайт, сделанный в Genexus с транзакцией, включающей в себя элемент управления Uploadify, работающий на локальном сервере Tomcat, и он отлично работает с небольшими файлами, но когда я пытаюсь загрузить больше один (> 50 МБ), кажется, загружает файл, но затем возвращается к экрану транзакции.Genexus Uploadify не работает с большими файлами

Я проверил тест с помощью инструментов разработчика, включенных в Google Chrome, и заметил, что при попытке загрузить большие файлы возникает ошибка «500 - Internal Server Error». При нажатии на соответствующую строку на вкладке «Сеть» дает следующее:

HTTP Status 500 - 

type Exception report 

message 

description The server encountered an internal error() that prevented it from fulfilling this request. 

exception 

javax.servlet.ServletException: java.lang.NoSuchMethodError: org.apache.commons.fileupload.DefaultFileItem.cleanup()V 
at com.genexus.webpanels.HttpContextWeb.cleanup(Unknown Source) 
at com.genexus.webpanels.GXWebObjectBase.doExecute(Unknown Source) 
at br.com.procempa.spm.cauge.texpedientessoliceventosalter.doExecute(texpedientessoliceventosalter.java:21) 
at com.genexus.webpanels.GXWebObjectStub.callExecute(Unknown Source) 
at com.genexus.webpanels.GXWebObjectStub.doPost(Unknown Source) 
at javax.servlet.http.HttpServlet.service(HttpServlet.java:647) 
at javax.servlet.http.HttpServlet.service(HttpServlet.java:729) 
at org.apache.catalina.servlets.InvokerServlet.serveRequest(InvokerServlet.java:420) 
at org.apache.catalina.servlets.InvokerServlet.doPost(InvokerServlet.java:170) 
at javax.servlet.http.HttpServlet.service(HttpServlet.java:647) 
at javax.servlet.http.HttpServlet.service(HttpServlet.java:729) 
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:269) 
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:188) 
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:213) 
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:172) 
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127) 
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:117) 
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:108) 
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:174) 
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:873) 
at org.apache.coyote.http11.Http11BaseProtocol$Http11ConnectionHandler.processConnection(Http11BaseProtocol.java:665) 
at org.apache.tomcat.util.net.PoolTcpEndpoint.processSocket(PoolTcpEndpoint.java:528) 
at org.apache.tomcat.util.net.LeaderFollowerWorkerThread.runIt(LeaderFollowerWorkerThread.java:81) 
at org.apache.tomcat.util.threads.ThreadPool$ControlRunnable.run(ThreadPool.java:689) 
at java.lang.Thread.run(Unknown Source) 

com.genexus.webpanels.GXWebObjectStub.callExecute(Unknown Source) 
com.genexus.webpanels.GXWebObjectStub.doPost(Unknown Source) 
javax.servlet.http.HttpServlet.service(HttpServlet.java:647) 
javax.servlet.http.HttpServlet.service(HttpServlet.java:729) 
org.apache.catalina.servlets.InvokerServlet.serveRequest(InvokerServlet.java:420) 
org.apache.catalina.servlets.InvokerServlet.doPost(InvokerServlet.java:170) 
javax.servlet.http.HttpServlet.service(HttpServlet.java:647) 
javax.servlet.http.HttpServlet.service(HttpServlet.java:729) 
note The full stack trace of the root cause is available in the Apache Tomcat/5.5.28 logs. 

Apache Tomcat/5.5.28 

Поиск на некоторых веб-сайтах, я нашел предложения отредактировать web.xml приложения, добавив следующий тег внутри < сервлета > тег в TOMCAT-каталог /application-directory/WEB-INF/web.xml:

<multipart-config> 
    <max-file-size>1073741824</max-file-size> 
    <max-request-size>1073741824</max-request-size> 
    <file-size-threshold>0</file-size-threshold> 
</multipart-config> 

А затем отредактирован-каталог кот/конф/server.xml сделать Connector тег для порта 8080 выглядеть следующим образом:

<Connector port="8080" maxHttpHeaderSize="4096" maxPostSize="1073741824" 
      maxThreads="150" minSpareThreads="25" maxSpareThreads="75" 
      enableLookups="false" redirectPort="8443" acceptCount="100" 
      connectionTimeout="600000" disableUploadTimeout="true" /> 

И затем перезапустил Tomcat, но все же он дает мне ту же ошибку. Я что-то пропустил?

Заранее благодарен!

EDIT: На самом деле, мое приложение является Java одним, а используемый элемент управления не является истинным «Uploadify», он имеет класс «Изображение» и связан с BLOB-полем в базе данных. Не так ли изменить тип поля в форме транзакции?

ответ

0

Проверьте в своей форме свойство Uploadify «Ограничение по размеру».

В файле web.config maxRequestLength в <system.web> и requestLimits maxAllowedContentLength в <security>.

Пример:

<system.web> 
<httpRuntime requestValidationMode="2.0" executionTimeout="600" maxRequestLength="50000"/> 
</system.web> 

<system.webServer> 
<security> 
    <requestFiltering> 
    <hiddenSegments> 
    <add segment="PrivateTempStorage" /> 
    <add segment="private" /> 
    </hiddenSegments> 
    <requestLimits maxAllowedContentLength="50000000"/> 
    </requestFiltering> 
</security> 
</system.webServer>