我在ManagedBean中开发https请求时遇到一些问题。问题是我得到了以下异常:
javax.net.ssl.SSLPeerUnverifiedException: Host name 'bitpay.com' does not match the certificate subject provided by the peer (CN=bitpay.com, O="BitPay, Inc.", L=Atlanta, ST=Georgia, C=US, SERIALNUMBER=5163966, OID.2.5.4.15=Private Organization, OID.1.3.6.1.4.1.311.60.2.1.2=Delaware, OID.1.3.6.1.4.1.311.60.2.1.3=US)
但是,如果我在纯Java客户端中尝试代码,它的工作原理非常好。 有谁知道我的失败在哪里?
我已使用此repository中的代码。
我自己的代码如下:
import model.BitPay;
import model.Invoice;
import javax.inject.Named;
import javax.enterprise.context.Dependent;
@Named(value = "bitPayMBean")
@Dependent
public class BitPayMBean {
private static final String API_KEY = "";
@Named(value = "returnUrl")
private String returnUrl = "URL";
public void setReturnUrl(String returnUrl) {
this.returnUrl = returnUrl;
}
public String getReturnUrl() {
return returnUrl;
}
public BitPayMBean() {
System.setProperty("javax.net.ssl.trustStore", "cacerts.jks");
System.setProperty("javax.net.ssl.trustStorePassword", "changeit");
}
public void transaction(double value) {
BitPay bitpay = new BitPay(API_KEY, "USD");
Invoice invoice = bitpay.createInvoice(value);
setReturnUrl(invoice.getUrl());
}
}
干杯并感谢您的建议
答案 0 :(得分:0)
所以我解决了我的问题。问题是在我的JDK版本8的证书文件中没有全部集成整合,这在我的JDK版本6的证书文件中。所以我在jdk8证书文件中集成了缺少的jdk6证书。这解决了我的问题