[ https://issues.apache.org/jira/browse/CONNECTORS-254?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=13104330#comment-13104330 ]
Karl Wright commented on CONNECTORS-254: ---------------------------------------- I fooled around with curl and found the command we need. Here it is (assuming hello.txt is a zero-length file): curl --trace dump.out -location -F "id=123" -F "file=@hello.txt" http://localhost:8983/solr/update/extract The --trace option dumps a trace file which is essentially equivalent to wireshark output. Good to know. Anyway, when I try this, I get the following in Solr: Sep 14, 2011 3:45:45 AM org.apache.solr.common.SolrException log SEVERE: org.apache.solr.common.SolrException: missing content stream at org.apache.solr.handler.ContentStreamHandlerBase.handleRequestBody(ContentStreamHandlerBase.java:50) at org.apache.solr.handler.RequestHandlerBase.handleRequest(RequestHandlerBase.java:129) at org.apache.solr.core.RequestHandlers$LazyRequestHandlerWrapper.handleRequest(RequestHandlers.java:238) at org.apache.solr.core.SolrCore.execute(SolrCore.java:1360) at org.apache.solr.servlet.SolrDispatchFilter.execute(SolrDispatchFilter.java:356) at org.apache.solr.servlet.SolrDispatchFilter.doFilter(SolrDispatchFilter.java:252) at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1212) at org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:399) at org.mortbay.jetty.security.SecurityHandler.handle(SecurityHandler.java:216) at org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:182) at org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:766) at org.mortbay.jetty.webapp.WebAppContext.handle(WebAppContext.java:450) at org.mortbay.jetty.handler.ContextHandlerCollection.handle(ContextHandlerCollection.java:230) at org.mortbay.jetty.handler.HandlerCollection.handle(HandlerCollection.java:114) at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152) at org.mortbay.jetty.Server.handle(Server.java:326) at org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:542) at org.mortbay.jetty.HttpConnection$RequestHandler.content(HttpConnection.java:945) at org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:756) at org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:212) at org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:404) at org.mortbay.jetty.bio.SocketConnector$Connection.run(SocketConnector.java:228) at org.mortbay.thread.QueuedThreadPool$PoolThread.run(QueuedThreadPool.java:582) Sep 14, 2011 3:45:45 AM org.apache.solr.core.SolrCore execute INFO: [] webapp=/solr path=/update/extract params={id=123} status=400 QTime=300 If this looks familiar, it's because we get the exact same trace when multi-part form posting from ManifoldCF. So there is apparently a bug in Solr, and there's no magic here. My suggestion is that you follow up by creating a Solr ticket, trying to be sure there isn't one already. I'll ping Simon and see if he knows anything. > Bad request when posting 0 byte file to Solr > -------------------------------------------- > > Key: CONNECTORS-254 > URL: https://issues.apache.org/jira/browse/CONNECTORS-254 > Project: ManifoldCF > Issue Type: Bug > Components: Lucene/SOLR connector > Affects Versions: ManifoldCF 0.1, ManifoldCF 0.2, ManifoldCF 0.3 > Reporter: Shinichiro Abe > Priority: Minor > Fix For: ManifoldCF 0.3 > > Attachments: CONNECTORS-254-1.patch, sample0byte.zip > > > It seems that httpposter brings about bad request when posting 0 byte file. > Solr log say the below. "missing content stream". Status code is 400. > On the other hand when using Solr request handler without MCF, this exception > is not thrown and the posting 0 byte files is indexed normally. > > 2011/09/13 12:30:40 org.apache.solr.core.SolrCore execute > ???: [] webapp=/solr path=/update/extract > params={literal.id=file:/Users/abe/Desktop/1/no-content/no-content.txt&literal.uri=/Users/abe/Desktop/1/no-content/no-content.txt} > status=400 QTime=367 > 2011/09/13 12:30:40 org.apache.solr.common.SolrException log > ?v???I: org.apache.solr.common.SolrException: missing content stream > at > org.apache.solr.handler.ContentStreamHandlerBase.handleRequestBody(ContentStreamHandlerBase.java:62) -- This message is automatically generated by JIRA. For more information on JIRA, see: http://www.atlassian.com/software/jira