Загрузите файл из Интернета с помощью java: как пройти проверку подлинности?
Благодаря этой теме Как загрузить и сохранить файл из Интернета с помощью Java?
Я знаю, как загрузить файл, теперь моя проблема в том, что мне нужно пройти аутентификацию на сервере, из которого я загружаю. Это http-интерфейс к серверу subversion. В каком поле нужно искать?
Используя код, отправленный в последнем комментарии, я получаю это исключение:
java.io.IOException: Server returned HTTP response code: 401 for URL: http://myserver/systemc-2.0.1.tgz
at sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLConnection.java:1305)
at java.net.URL.openStream(URL.java:1009)
at mypackage.Installer.installSystemc201(Installer.java:29)
at mypackage.Installer.main(Installer.java:38)
Спасибо,
Ответы
Ответ 1
Вы расширяете класс Authenticator и регистрируете его. Javadocs по ссылке объясняют, как.
Я не знаю, работает ли это с методом nio, который получил принятый ответ на вопрос, но он наверняка работает по старомодному способу, который был ответом под этим.
В рамках реализации класса аутентификатора вы, вероятно, собираетесь использовать PasswordAuthentication и переопределить метод getPasswordAuthentication() для вашей проверки подлинности чтобы вернуть его. Это будет класс, которому передано имя пользователя и пароль.
По вашему запросу здесь приведен пример кода:
public static final String USERNAME_KEY = "username";
public static final String PASSWORD_KEY = "password";
private final PasswordAuthentication authentication;
public MyAuthenticator(Properties properties) {
String userName = properties.getProperty(USERNAME_KEY);
String password = properties.getProperty(PASSWORD_KEY);
if (userName == null || password == null) {
authentication = null;
} else {
authentication = new PasswordAuthentication(userName, password.toCharArray());
}
}
protected PasswordAuthentication getPasswordAuthentication() {
return authentication;
}
И вы регистрируете его в основном методе (или где-то вдоль строки до вызова URL-адреса):
Authenticator.setDefault(new MyAuthenticator(properties));
Использование прост, но я нахожу API запутанным и отчасти обратным, как вы обычно думаете об этих вещах. Довольно типичный дизайн синглтон.
Ответ 2
Это код, который я написал, который извлекает веб-сайт и отображает содержимое в System.out. Он использует обычную проверку подлинности:
import java.net.*;
import java.io.*;
public class foo {
public static void main(String[] args) throws Exception {
URL yahoo = new URL("http://www.MY_URL.com");
String passwdstring = "USERNAME:PASSWORD";
String encoding = new
sun.misc.BASE64Encoder().encode(passwdstring.getBytes());
URLConnection uc = yahoo.openConnection();
uc.setRequestProperty("Authorization", "Basic " + encoding);
InputStream content = (InputStream)uc.getInputStream();
BufferedReader in =
new BufferedReader (new InputStreamReader (content));
String line;
while ((line = in.readLine()) != null) {
System.out.println (line);
}
in.close();
}
Проблемы с приведенным выше кодом:
foo.java:11: warning: sun.misc.BASE64Encoder is Sun proprietary API and may be removed in a future release
sun.misc.BASE64Encoder().encode(passwdstring.getBytes());
^ 1 warning
На самом деле нужно использовать класс Authenticator, но для жизни я не мог понять, как и я тоже не мог найти никаких примеров, которые просто показывают, что людям Java на самом деле это не нравится, когда вы используете свой язык, чтобы делать классные вещи.:-P
Таким образом, вышесказанное не является хорошим решением, но оно работает и может быть легко изменено позже.
Ответ 3
Напишите свой класс переопределения для Authenticator:
import java.net.Authenticator;
import java.net.PasswordAuthentication;
public class MyAuthenticator extends Authenticator {
private static String username = "";
private static String password = "";
protected PasswordAuthentication getPasswordAuthentication() {
return new PasswordAuthentication (MyAuthenticator.username,
MyAuthenticator.password.toCharArray());
}
public static void setPasswordAuthentication(String username, String password) {
MyAuthenticator.username = username;
MyAuthenticator.password = password;
}
}
Напишите свой основной класс:
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.Authenticator;
import java.net.MalformedURLException;
import java.net.URL;
public class MyMain{
public static void main(String[] args) {
URL url;
InputStream is = null;
BufferedReader br;
String line;
// Install Authenticator
MyAuthenticator.setPasswordAuthentication("Username", "Password");
Authenticator.setDefault (new MyAuthenticator ());
try {
url = new URL("Your_URL_Here");
is = url.openStream(); // throws an IOException
br = new BufferedReader(new InputStreamReader(is));
while ((line = br.readLine()) != null) {
System.out.println(line);
}
} catch (MalformedURLException mue) {
mue.printStackTrace();
} catch (IOException ioe) {
ioe.printStackTrace();
} finally {
try {
if (is != null) is.close();
} catch (IOException ioe) {
// nothing to see here
}
}
}
}
Ответ 4
Вы пытались создать свой URL-адрес в форме http://user:[email protected]/path?
Ответ 5
Я бы предложил проверить HttpClient из apache http://hc.apache.org/httpclient-3.x/, что упрощает загрузку/аутентификацию
Ответ 6
Эта библиотека с открытым исходным кодом, http://spnego.sourceforge.net, также содержит некоторые примеры использования класса SpnegoHttpURLConnection.
Один из конструкторов в классе позволяет вам вводить имя пользователя и пароль.
Взгляните на класс java doc для примеров.