您扩展Authenticator类并进行注册。链接上的javadocs解释了如何。
我不知道这是否可以通过nio方法获得问题的可接受答案,但是可以肯定,它适用于老式方法,即该方法的答案。
在Authenticator类实现中,您可能将使用PasswordAuthentication并重写Authenticator实现的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;}
然后将其注册到main方法中(或在调用URL之前的某处):
Authenticator.setDefault(new MyAuthenticator(properties));
用法很简单,但是我发现API令人费解,并且对于您通常如何看待这些事情有点倒退。非常典型的单例设计。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)