我正在尝试访问我正在处理的项目的Web服务。我正在使用JAX-WS,应用程序部署在weblogic上。当我尝试访问WS时,我得到以下异常:
javax.portlet.PortletException: javax.xml.ws.WebServiceException: Failed to access the WSDL at: http://xxx.xxxx.ro:40000/idm/ws/cup?wsdl. It failed with:
Response: '401: Unauthorized' for url: 'http://xxx.xxxx.ro:40000/idm/ws/cup?wsdl'.
at com.bea.portlet.container.PortletStub.processAction(PortletStub.java:346)
at com.bea.portlet.container.AppContainer.invokeProcessAction(AppContainer.java:678)
........
我阅读了很多关于问题的帖子,我尝试了不同类型的auth。我尝试在不同的用例中使用BindingProvider,basicHTTPAuth,禁用HostnameVerifier等但仍然没有结果。
下面是我的代码片段,作为最后一个尝试过的版本:
Authenticator.setDefault(new Authenticator() {
@Override
protected PasswordAuthentication getPasswordAuthentication() {
return new PasswordAuthentication(
username,
password.toCharArray());
}
});
ComputeUserProfileImplService computeUserProfileImplService = new ComputeUserProfileImplService(
new URL(null, endpointURL, new sun.net.www.protocol.http.Handler()),
new QName("http://xxx.xx.xxxxx.xxxxx.com/",
"ComputeUserProfileImplService"));
ComputeUserProfileImpl computeUserProfile = computeUserProfileImplService
.getComputeUserProfileImplPort();
ComputeUserProfileImplService代码如下所示:
private final static URL COMPUTEUSERPROFILEIMPLSERVICE_WSDL_LOCATION;
private final static Logger logger = Logger.getLogger(com.xxxxx.xxxxx.xx.xxxxx.cup.ComputeUserProfileImplService.class.getName());
static {
URL url = null;
try {
URL baseUrl;
baseUrl = com.xxxxx.xxxxx.xx.xxxxx.xxx.ComputeUserProfileImplService.class.getResource("");
url = new URL(baseUrl, "http://xxxx.xxxxx.ro:40000/idm/ws/cup?wsdl");
} catch (MalformedURLException e) {
logger.warning("Failed to create URL for the wsdl Location: 'xxxxxxxxxxxxxxxx', retrying as a local file");
logger.warning(e.getMessage());
}
COMPUTEUSERPROFILEIMPLSERVICE_WSDL_LOCATION = url;
}
很抱歉更换链接,但我没有授权发布它们,因为它是一个非常着名的组织..如果你可以帮我提出一些建议,我将不胜感激。我一直在寻找解决方案,但我被卡住了......我无法弄明白。它应该是适用于我的这个weblogic问题的解决方法......但我找不到它。如果你需要它,我会发布一些其他的片段。希望我对此非常清楚。
提前致谢!!
答案 0 :(得分:5)
不幸的是,Weblogic采用了不同的方法,它使用自己的URLStreamHandler,由于某种原因忽略了身份验证。
尝试使用Sun的实现:
而不是
url = new URL(address); // use WebLogic handler
使用
url = new URL(null, address, new sun.net.www.protocol.http.Handler()); // use Sun's handler
答案 1 :(得分:4)
我在Weblogic中遇到了同样的问题。 我可以向你确认,Paulius Matulionis建议的解决方案在Weblogic 11中为我工作:
import my.MyPortType;
import javax.xml.namespace.QName;
import javax.xml.ws.BindingProvider;
import javax.xml.ws.Service;
import javax.xml.ws.handler.MessageContext;
import java.net.Authenticator;
import java.net.MalformedURLException;
import java.net.PasswordAuthentication;
import java.net.URL;
import java.util.Collections;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class MyWebServiceClient {
public static void main(String[] args) {
URL url = null;
try {
url = new URL("http://host:10001/mycontext/ws?WSDL");
} catch (MalformedURLException e) {
e.printStackTrace();
}
try {
final String username = "some";
final String password = "other";
Authenticator.setDefault(new Authenticator() {
@Override
protected PasswordAuthentication getPasswordAuthentication() {
return new PasswordAuthentication(
username,
password.toCharArray());
}
});
QName qname = new QName("http://whatevertheqname/", "whatevertheservicename");
Service service = Service.create(url, qname);
MyPortType proxy = service.getPort(MyPortType.class);
Map<String, Object> requestContext = ((BindingProvider) proxy).getRequestContext();
requestContext.put(BindingProvider.ENDPOINT_ADDRESS_PROPERTY, url.toString());
requestContext.put(BindingProvider.USERNAME_PROPERTY, username);
requestContext.put(BindingProvider.PASSWORD_PROPERTY, password);
Map<String, List<String>> headers = new HashMap<String, List<String>>();
headers.put("Timeout", Collections.singletonList("10000"));
requestContext.put(MessageContext.HTTP_REQUEST_HEADERS, headers);
String result = proxy.myMethod23");
System.out.println("Result is: " + result);
} catch (Exception e) {
e.printStackTrace();
throw new RuntimeException("Error occurred in operations web service client initialization", e);
}
}
}
答案 2 :(得分:2)
我没有在WebLogic中尝试过这个,但是在Tomcat,Glassfish,Apache Karaf上,对Web服务的过度调用需要基本的身份验证,这很有用:
/**
* Proxy.
*/
private OperationsService proxy;
/**
* Operations wrapper constructor.
*
* @throws SystemException if error occurs
*/
public OperationsWrapper()
throws SystemException {
try {
final String username = getBundle().getString("wswrappers.operations.username");
final String password = getBundle().getString("wswrappers.operations.password");
Authenticator.setDefault(new Authenticator() {
@Override
protected PasswordAuthentication getPasswordAuthentication() {
return new PasswordAuthentication(
username,
password.toCharArray());
}
});
URL url = new URL(getBundle().getString("wswrappers.operations.url"));
QName qname = new QName("http://hltech.lt/ws/operations", "Operations");
Service service = Service.create(url, qname);
proxy = service.getPort(OperationsService.class);
Map<String, Object> requestContext = ((BindingProvider) proxy).getRequestContext();
requestContext.put(BindingProvider.ENDPOINT_ADDRESS_PROPERTY, url.toString());
requestContext.put(BindingProvider.USERNAME_PROPERTY, username);
requestContext.put(BindingProvider.PASSWORD_PROPERTY, password);
Map<String, List<String>> headers = new HashMap<String, List<String>>();
headers.put("Timeout", Collections.singletonList(getBundle().getString("wswrappers.operations.timeout")));
requestContext.put(MessageContext.HTTP_REQUEST_HEADERS, headers);
} catch (Exception e) {
LOGGER.error("Error occurred in operations web service client initialization", e);
throw new SystemException("Error occurred in operations web service client initialization", e);
}
}
我不认为WebLogic有什么不同。这应该有用。
答案 3 :(得分:0)
以下是可以解决您问题的建议:
1)更改WEBLOGIC脚本setDomainEnv.sh以强制WEBLOGIC使用 String s1 = new String("hello");
String s2 = s1;
String s3 = new String("hello");
System.out.println(s1==s2); // it prints true
System.out.println(s1==s3); // it prints false
。
或
2)使用shell脚本/批处理文件从命令提示符调用webservice。
或
3)在您的网络服务SunHttpHandler
或
4)编写自己的sun http处理程序。
或
5)尝试通过在其中添加新创建的Web服务来更新您的weblogic-webservice.xml。
或
6)尝试使用jax-rpc而不是jax-ws。
希望前两个中的任何一个都能解决您的问题,但其他选项也很有帮助。