Próbuję wysłać żądanie wpisu do adresu URL za pomocą HttpURLConnection (do używania cUrl w java). Treść żądania to xml, a na końcu aplikacja przetwarza xml i przechowuje rekord w bazie danych, a następnie odsyła odpowiedź w postaci ciągu xml. Aplikacja jest hostowana lokalnie na apache-tomcat.
Kiedy wykonuję ten kod z terminala, wiersz zostanie dodany do bazy danych zgodnie z oczekiwaniami. Ale wyjątek jest zgłaszany w następujący sposób podczas pobierania InputStream z połączenia
java.io.FileNotFoundException: http://localhost:8080/myapp/service/generate
at sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLConnection.java:1401)
at org.kodeplay.helloworld.HttpCurl.main(HttpCurl.java:30)
Oto kod
public class HttpCurl {
public static void main(String [] args) {
HttpURLConnection con;
try {
con = (HttpURLConnection) new URL("http://localhost:8080/myapp/service/generate").openConnection();
con.setRequestMethod("POST");
con.setDoOutput(true);
con.setDoInput(true);
File xmlFile = new File("test.xml");
String xml = ReadWriteTextFile.getContents(xmlFile);
con.getOutputStream().write(xml.getBytes("UTF-8"));
InputStream response = con.getInputStream();
BufferedReader reader = new BufferedReader(new InputStreamReader(response));
for (String line ; (line = reader.readLine()) != null;) {
System.out.println(line);
}
reader.close();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
}
Jest to mylące, ponieważ wyjątek jest śledzony w wierszu InputStream response = con.getInputStream();
i wydaje się, że nie ma żadnego pliku związanego z wyjątkiem FileNotFoundException.
Kiedy próbuję bezpośrednio otworzyć połączenie z plikiem xml, nie zgłasza tego wyjątku.
Aplikacja usługowa wykorzystuje Spring Framework i Jaxb2Marshaller do tworzenia odpowiedzi XML.
Klasa ReadWriteTextFile jest pobierana stąd
Dzięki.
Edycja: Cóż, zapisuje dane w bazie danych i odsyła kod statusu odpowiedzi 404 w tym samym czasie.
Spróbowałem też zrobić curl używając php i wydrukować, CURLINFO_HTTP_CODE
który okazuje się być 200.
Jakieś pomysły, jak mam to debugować? Usługa i klient znajdują się na serwerze lokalnym.
Rozwiązane: mogłem rozwiązać problem po zapoznaniu się z odpowiedzią dotyczącą samego SO.
Wygląda na to, że HttpURLConnection zawsze zwraca odpowiedź 404 podczas łączenia się z adresem URL z niestandardowym portem.
Dodanie tych linii rozwiązało problem
con.setRequestProperty("User-Agent","Mozilla/5.0 ( compatible ) ");
con.setRequestProperty("Accept","*/*");