Piszę mały program Java, aby uzyskać wyniki dla danego wyszukiwanego hasła. Z jakiegoś powodu w Javie dostaję 403 Forbidden, ale otrzymuję właściwe wyniki w przeglądarkach internetowych. Kod:403 Zabrania się używania Javy, ale nie przeglądarki internetowej?
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.URL;
public class DataGetter {
public static void main(String[] args) throws IOException {
getResultAmount("test");
}
private static int getResultAmount(String query) throws IOException {
BufferedReader r = new BufferedReader(new InputStreamReader(new URL("https://www.google.com/search?q=" + query).openConnection()
.getInputStream()));
String line;
String src = "";
while ((line = r.readLine()) != null) {
src += line;
}
System.out.println(src);
return 1;
}
}
i błąd:
Exception in thread "main" java.io.IOException: Server returned HTTP response code: 403 for URL: https://www.google.com/search?q=test
at sun.net.www.protocol.http.HttpURLConnection.getInputStream(Unknown Source)
at sun.net.www.protocol.https.HttpsURLConnectionImpl.getInputStream(Unknown Source)
at DataGetter.getResultAmount(DataGetter.java:15)
at DataGetter.main(DataGetter.java:10)
Dlaczego to robi?
może mieć coś wspólnego z sesjami? – kishu27
Dlaczego używasz punktu końcowego SSL? – Perception
@Perception um ... jaki jest punkt końcowy SSL? (przepraszam, nie mam pojęcia o takich rzeczach) – Doorknob