2010-11-20 16 views
1

System.Net.WebException: The remote server returned an error: (500) Internal Server Error. at System.Net.HttpWebRequest.GetResponse() at refill.btnRequestRefill_Click(Object sender, EventArgs e)Interner Server Fehler (500) httpwebrequest

Ich bekomme diesen Fehler beim Versuch, ein Formular zu senden. Hier ist mein Code:

Protected Sub btnRequestRefill_Click(ByVal sender As Object, ByVal e As System.EventArgs) Handles btnRequestRefill.Click 

    Try 
     Dim url As String = "www.domainname.com" 

     url += "lastName=" & LastName.Text 
     url += "&birthDate=" & Birthdate.Text 
     url += "&RxNumbers=" & RxNumber.Text 
     url += "&deliveryMethod=" & deliverymethod.SelectedValue 
     url += "&phone=" & PhoneNumber.Text 
     url += "&email=" & Email.Text 

     Dim myrequest As HttpWebRequest = TryCast(WebRequest.Create(url), HttpWebRequest) 

     Dim docresponse As WebResponse = myrequest.GetResponse() 
     Dim responsestream As Stream = docresponse.GetResponseStream() 
     Dim objXMLDoc As New XmlDocument() 
     Dim colElements As XmlNodeList 
     Dim colElements2 As XmlNodeList 
     Dim mywebclient As New WebClient() 
     Dim a As Object 
     Dim listingscount As Integer = 0 

     objXMLDoc.Load(responsestream) 
     colElements = objXMLDoc.GetElementsByTagName("script") 

     For Each objnode As XmlNode In colElements 
      Dim attCol As XmlAttributeCollection = objnode.Attributes 

      If objnode.Name = "script" Then 
       If attCol(0).Value = "false" Then 
        colElements2 = objXMLDoc.GetElementsByTagName("rxResponse") 
        For Each objnode2 As XmlNode In colElements2 
         Response.Write("<br/>" & objnode2.InnerText & "<br/>") 
        Next 
       Else 
        Response.Write("<br/>yay it when through<br/>") 

        Dim redir, mailto, mailfrom, subject, item, body, cc, bcc, message, html, template, usetemplate, testmode 
        subject = "Refill Submit - test" 

        usetemplate = False 

        Dim msg = Server.CreateObject("CDO.Message") 
        msg.subject = subject 
        msg.to = "[email protected],[email protected],[email protected]" 
        msg.from = "[email protected]" 

        For Each item In Request.Form 
         Select Case item 
          Case "redirect", "mailto", "cc", "bcc", "subject", "message", "template", "html", "testmode", "__EVENTTARGET", "__EVENTARGUMENT", "__VIEWSTATE", "__EVENTVALIDATION", "btnRequestRefill","__LASTFOCUS" 
          Case Else 
           If Not usetemplate Then 
            If item <> "mailfrom" Then body = body & item & ": " & Request.Form(item) & vbCrLf & vbCrLf 
           Else 
            body = Replace(body, "[$" & item & "$]", Replace(Request.Form(item), vbCrLf, "<br>")) 
           End If 
         End Select 
        Next 

        If usetemplate Then 'remove any leftover placeholders 
         Dim rx As New Regex("\[\$.*\$\]") 
         body = rx.Replace(body, "") 
        End If 

        If usetemplate And LCase(Request.Form("html")) = "yes" Then 
         msg.htmlbody = body 
        Else 
         msg.textbody = body 
        End If 

        msg.send() 
        msg = Nothing 
       End If 
      Else 
       Response.Write("<br/>" & "not script" & "<br/>") 
      End If 
      'Response.Write("<br/>" & objnode.Name & ": " & objnode.InnerText & "<br/>") 
     Next 
    Catch ex As Exception 
     Response.Write("<br/>" & ex.ToString & "<br/>") 

    End Try 
End Su 
+0

Haben Sie eine Möglichkeit, die Details der Remote-Server-Fehler zu erhalten? Und sind Sie sicher, dass die URL, die Sie erhalten möchten, gültig ist? In Ihrem Beispiel sieht es nicht so aus, als würden Sie eine gültige URL angeben. – Oded

+0

Ich musste die URL aus Gründen der Vertraulichkeit an den Kunden ändern –

Antwort

0

Ich wollte nur zur Kenntnis nehmen, dass ich diesen Code von einem anderen Entwickler übernahm. Ich habe von der Firma erfahren, dass dies vorher angenommen wurde, dass es tatsächlich eine fehlende Querystring gab, die vom Dienst benötigt wurde. nur durch Hinzufügen von URL + = "querystring =" & Wert es funktioniert.

Verwandte Themen