system.setproperty(“javax.net.ssl.keystore”,)在api rest中不工作?

qrjkbowd  于 2021-07-06  发布在  Java
关注(0)|答案(1)|浏览(209)

我有下面的代码,如果我通过控制台运行它,它可以正常工作

public static void main(String[] args) throws MalformedURLException {
    // TODO Auto-generated method stub
    try {
        String jSonData = "xxx";

        String nombreCertificadoTicket = "CERTIFICADO.p12";
        String passCertificadoTicket = "PASSWORD";
        String pathCertificado = "/opt/tomcat/properties/"+nombreCertificadoTicket;
        String url_crearTicket = "URL SERVICE";

        System.setProperty("javax.net.ssl.keyStoreType", "pkcs12");
        System.setProperty("javax.net.ssl.keyStore", pathCertificado);
        System.setProperty("javax.net.ssl.keyStorePassword", passCertificadoTicket);

        URL urlCrearTicket = new URL(url_crearTicket);                                                  

        HttpURLConnection conexionCrearTicket = (HttpURLConnection) urlCrearTicket.openConnection();
        conexionCrearTicket.setDoOutput(true);
        conexionCrearTicket.setRequestMethod("POST");
        conexionCrearTicket.setRequestProperty("content-type", "application/json");

        OutputStream os = conexionCrearTicket.getOutputStream();
        os.write(jSonData.getBytes());
        os.flush();

        System.out.println("CODE :"+conexionCrearTicket.getResponseCode());

我通过consol执行这个类,它执行并返回代码ok
但是我将完全相同的代码放在rest服务中,它返回401 unauthorized错误,因此我假设它没有正确放置安全证书

@Path("PruebaCertificado")
public class PruebaCertificado {

@PUT
@Consumes(MediaType.APPLICATION_JSON)
@Produces(MediaType.APPLICATION_JSON)
public RespuestaWs recibe(InputStream entrada) {

    RespuestaWs respuesta = new RespuestaWs();

    try {

        String jSonData = "";

        String jSonData = "xxx";

        String nombreCertificadoTicket = "CERTIFICADO.p12";
        String passCertificadoTicket = "PASSWORD";
        String pathCertificado = "/opt/tomcat/properties/"+nombreCertificadoTicket;
        String url_crearTicket = "URL SERVICE";

        System.setProperty("javax.net.ssl.keyStoreType", "pkcs12");
        System.setProperty("javax.net.ssl.keyStore", pathCertificado);
        System.setProperty("javax.net.ssl.keyStorePassword", passCertificadoTicket);

        URL urlCrearTicket = new URL(url_crearTicket);                                                  

        HttpURLConnection conexionCrearTicket = (HttpURLConnection) urlCrearTicket.openConnection();
        conexionCrearTicket.setDoOutput(true);
        conexionCrearTicket.setRequestMethod("POST");
        conexionCrearTicket.setRequestProperty("content-type", "application/json");

        OutputStream os = conexionCrearTicket.getOutputStream();
        os.write(jSonData.getBytes());
        os.flush();

        System.out.println("CODE :"+conexionCrearTicket.getResponseCode());

我需要在tomcat或类似的东西中添加一些配置吗?
该环境具有ApacheTomcat8yJava1.8

vlurs2pr

vlurs2pr1#

我用我找到的另一个代码解决了它,我把它留着,以防它对别人有用。注意,我使用了httpsurlconnection

KeyManagerFactory keyManagerFactory = KeyManagerFactory.getInstance("SunX509");
        KeyStore keyStore = KeyStore.getInstance("PKCS12");
        InputStream keyInput = new FileInputStream(pathCertificado);
        keyStore.load(keyInput, passCertificadoTicket.toCharArray());
        keyInput.close();
        keyManagerFactory.init(keyStore, passCertificadoTicket.toCharArray());
        SSLContext context = SSLContext.getInstance("TLS");
        context.init(keyManagerFactory.getKeyManagers(), null, new SecureRandom());

        HttpsURLConnection conexionCrearTicket = (HttpsURLConnection) urlCrearTicket.openConnection();
        conexionCrearTicket.setSSLSocketFactory(context.getSocketFactory());
        conexionCrearTicket.setDoOutput(true);
        conexionCrearTicket.setRequestMethod("POST");
        conexionCrearTicket.setRequestProperty("content-type", "application/json");

相关问题