Frage

Ich bin die Veröffentlichung der folgenden auf den Solr Server:

<add>
    <doc>
        <field name="uniqueid">5453543</field>
        <field name="modifieddate">2008-12-03T15:49:00Z</field>
        <field name="title">My Record</field>
        <field name="description">Descirption 
        Details
</field>
        <field name="startdate">2009-01-21T15:26:05.680Z</field>
        <field name="enddate">2009-01-21T15:26:05.697Z</field>
        <field name="Telephone_number">11111 111 111(text phone)</field>
        <field name="Telephone_number">11111 111 111</field>
        <field name="Mobile_number">1111111111</field>
    </doc>
</add>

Ich bin mit SolrNet die Dokumente senden Hier ist ein Auszug aus dem Code ( s ist es, die oben xml):

public string Post(string relativeUrl, string s) 
{
    var u = new UriBuilder(serverURL);
    u.Path += relativeUrl;
    var request = httpWebRequestFactory.Create(u.Uri);
    request.Method = HttpWebRequestMethod.POST;
    request.KeepAlive = false;
    if (Timeout > 0)
        request.Timeout = Timeout;
    request.ContentType = "text/xml; charset=utf-8";
    request.ContentLength = s.Length;
    request.ProtocolVersion = HttpVersion.Version10;
    try 
    {
        using (var postParams = request.GetRequestStream()) 
        {
            postParams.Write(xmlEncoding.GetBytes(s), 0, s.Length);
            using (var response = request.GetResponse()) 
            {
                using (var rStream = response.GetResponseStream()) 
                {
                    string r = xmlEncoding.GetString(ReadFully(rStream));
                    //Console.WriteLine(r);
                    return r;
                }
            }
        }
    } 
    catch (WebException e) 
    {
        throw new SolrConnectionException(e);
    }
}

Wenn es es scheiterte mit diesem Fehler request.GetResponse bekommt:

  

Basis   {System.InvalidOperationException} =   { "Der Remote-Server hat einen Fehler zurückgegeben:   (500) Internal Server Error. "}

Wenn ich mich auf dem Server in den Protokollen für Apache es folgenden Grund gibt:

  

Unerwartetes Ende des Eingangsblocks in Ende

Hier ist der vollständige Stack-Trace:

  

17. September 2009 10.13.53   org.apache.solr.common.SolrException   log SCHWEREN:   com.ctc.wstx.exc.WstxEOFException:   Unerwartetes Ende des Eingangsblockes in Ende   Tag auf [Zeile, Spalte {unknown-source}]:   [26,1266] an   com.ctc.wstx.sr.StreamScanner.throwUnexpectedEOB (StreamScanner.java:700)     beim   com.ctc.wstx.sr.StreamScanner.loadMoreFromCurrent (StreamScanner.java:1054)     beim   com.ctc.wstx.sr.StreamScanner.getNextCharFromCurrent (StreamScanner.java:811)     beim   com.ctc.wstx.sr.BasicStreamReader.readEndElem (BasicStreamReader.java:3211)     beim   com.ctc.wstx.sr.BasicStreamReader.nextFromTree (BasicStreamReader.java:2832)     beim   com.ctc.wstx.sr.BasicStreamReader.next (BasicStreamReader.java:1019)     beim   org.apache.solr.handler.XmlUpdateRequestHandler.processUpdate (XmlUpdateRequestHandler.java:148)     beim   org.apache.solr.handler.XmlUpdateRequestHandler.handleRequestBody (XmlUpdateRequestHandler.java:123)     beim   org.apache.solr.handler.RequestHandlerBase.handleRequest (RequestHandlerBase.java:131)     beim   org.apache.solr.core.SolrCore.execute (SolrCore.java:1204)     beim   org.apache.solr.servlet.SolrDispatchFilter.execute (SolrDispatchFilter.java:303)     beim   org.apache.solr.servlet.SolrDispatchFilter.doFilter (SolrDispatchFilter.java:232)     beim   org.apache.catalina.core.ApplicationFilterChain.internalDoFilter (ApplicationFilterChain.java:235)     beim   org.apache.catalina.core.ApplicationFilterChain.doFilter (ApplicationFilterChain.java:206)     beim   org.apache.catalina.core.StandardWrapperValve.invoke (StandardWrapperValve.java:233)     beim   org.apache.catalina.core.StandardContextValve.invoke (StandardContextValve.java:191)     beim   org.apache.catalina.core.StandardHostValve.invoke (StandardHostValve.java:128)     beim   org.apache.catalina.valves.ErrorReportValve.invoke (ErrorReportValve.java:102)     beim   org.apache.catalina.core.StandardEngineValve.invoke (StandardEngineValve.java:109)     beim   org.apache.catalina.connector.CoyoteAdapter.service (CoyoteAdapter.java:293)     beim   org.apache.coyote.http11.Http11AprProcessor.process (Http11AprProcessor.java:859)     beim   org.apache.coyote.http11.Http11AprProtocol $ Http11ConnectionHandler.process (Http11AprProtocol.java:574)     beim   org.apache.tomcat.util.net.AprEndpoint $ Worker.run (AprEndpoint.java:1527)     beim   java.lang.Thread.run (Thread.java:619)

Bitte beachten Sie die Solr-Server auf dem folgenden System ausgeführt wird:

Microsoft Windows Server 2003 R2 Apache Tomcat 6

Schließlich ist hier meine Frage:

Die XML-i sieht nicht gut aus für mich bin das Senden .. Hat jemand eine Idee, warum Solr diese Ausnahme wirft?

Danke

Dave

Bearbeiten Antwort lautet wie folgt:

public string Post(string relativeUrl, string s) 
{
    var u = new UriBuilder(serverURL);
    u.Path += relativeUrl;
    var request = httpWebRequestFactory.Create(u.Uri);
    request.Method = HttpWebRequestMethod.POST;
    request.KeepAlive = false;
    if (Timeout > 0)
        request.Timeout = Timeout;
    request.ContentType = "text/xml; charset=utf-8";
    request.ProtocolVersion = HttpVersion.Version10;
    try 
    {
        // Set the Content length after the size of the byte array has been calculated.
        byte[] data = xmlEncoding.GetBytes(s);
        request.ContentLength = s.Length;
        using (var postParams = request.GetRequestStream()) 
        {
            postParams.Write(data, 0, data.Length);
            using (var response = request.GetResponse()) 
            {
                using (var rStream = response.GetResponseStream()) 
                {
                    string r = xmlEncoding.GetString(ReadFully(rStream));
                    //Console.WriteLine(r);
                    return r;
                }
            }
        }
    } 
    catch (WebException e) 
    {
        throw new SolrConnectionException(e);
    }
}
War es hilfreich?

Lösung

Ich bin nicht viel vertraut mit .Net oder Solr oder .Net Hafen von Solr. Aber hier ist meine Vermutung.

postParams.Write(xmlEncoding.GetBytes(s), 0, s.Length);

Es gibt zwei mögliche Fehler berücksichtigt.

  1. Wenn Sie Bytes aus String bekommen, sollten Sie die Codierung angeben. Es könnte der Fall sein, dass die Standard-Kodierung unterscheidet sich von UTF8 ist, die Sie im Inhaltstyp-Header in Reaktion gesetzt haben.
  2. Der dritte Parameter in Write () probabably bezieht sich auf die Länge des Byte-Array, das Sie von GetBytes bekam (). Der Byte-Array länger sein könnte als die Länge der Zeichenfolge.
Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow
scroll top