我在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());
}
}
干杯,谢谢你的建议
最佳答案
所以我解决了我的问题。问题在于,在我的JDK版本8的证书文件中并没有集成所有证书,在我的JDK版本6的证书文件中的哪个地方。因此,我已将缺少的jdk6证书集成到我的jdk8证书文件中。那解决了我的问题