JAX RS скачать PDF - PullRequest
       13

JAX RS скачать PDF

0 голосов
/ 22 ноября 2018

Я пытаюсь загрузить файл PDF, доступный по одному из остальных URL-адресов, используя JAX RS и Джерси с авторизацией.

import org.apache.commons.io.IOUtils;
import javax.net.ssl.*;
import javax.ws.rs.WebApplicationException;
import javax.ws.rs.client.Client;
import javax.ws.rs.client.ClientBuilder;
import javax.ws.rs.client.Invocation;
import javax.ws.rs.client.WebTarget;
import javax.ws.rs.core.Response;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.io.File;
import java.security.SecureRandom;
import java.security.cert.X509Certificate;

public class ReportView {
    public void process(String authStringEnc) {

        System.setProperty("javax.net.ssl.trustStore","C:\\Users\\alim\\Desktop\\my-app\\stage\\npkeystore.jks");
        System.setProperty("javax.net.ssl.trustStorePassword","changeit");
        System.setProperty("javax.net.ssl.trustAnchors","C:\\Users\\alim\\Desktop\\my-app\\stage\\npkeystore.jks");

        Client client = ClientBuilder.newClient();
       // WebTarget target = client.target("https://x.x.x.x/api/profiler/1.0/reporting/reports/751252/").path("view");
        WebTarget target = client.target("https://x.x.x.x/api/profiler/1.0/reporting/reports/751252/view");

        Response resp = target.request("application/pdf,image/jpeg,application/xml,application/vnd.ms-excel").header("Authorization", authStringEnc).get(Response.class);


        System.out.println("Code : " + resp.getStatus());

        if(resp.getStatus() == Response.Status.OK.getStatusCode()) {
            InputStream is = resp.readEntity(InputStream.class);

            File downloadfile = new File("C://Users/alim/Downloads/view.pdf");
            try {

                byte[] byteArray = IOUtils.toByteArray(is);
                FileOutputStream fos = new FileOutputStream(downloadfile);
                fos.write(byteArray);
                fos.flush();
                fos.close();
            }catch(Exception e){
                e.getMessage();
            }

            IOUtils.closeQuietly(is);
            System.out.println("the file details after call:"+ downloadfile.getAbsolutePath()+", size is "+downloadfile.length());
        }
        else{
            throw new WebApplicationException("Http Call failed. response code is"+resp.getStatus()+". Error reported is"+resp.getStatusInfo());
        }
    }

Но приведенный выше фрагмент кода возвращает неверный запрос 400.Не уверен, правильно ли я указал URL.Использование того же URL-адреса в Postman возвращает файл PDF.

Exception in thread "main" javax.ws.rs.WebApplicationException: Http Call failed. response code is 400. Error reported is Bad Request

Кроме того, удаление блока сертификата возвращает мне исключение сертификации PKIX, хотя я уже определил его в основном классе и использую его в одном из подклассов.

Caused by: sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target

Концепции JAX-RS и Jersey довольно новы для меня.Не уверен, где я иду неправильно с точки зрения указания URL с аутентификацией, сертификатом и запросом.

Любая помощь / руководство по этому поводу действительно помогло бы.

Ответы [ 2 ]

0 голосов
/ 04 января 2019

Я попробовал другой способ и смог загрузить файлы PDF.Ниже приведен фрагмент кода для того же.

import com.sun.jersey.api.client.Client;
import com.sun.jersey.api.client.ClientResponse;
import com.sun.jersey.api.client.WebResource;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;


        String download_url = "https://x.x.x.x/api/profiler/1.0/reporting/reports/" + reportID +"/view";
        String name = "report";
        String password = "report";
        String authString = name + ":" + password;
        String authStringEnc = Base64.getEncoder().encodeToString(authString.getBytes());

        System.out.println(" Downloading " + name + " report");

        Client restClient = Client.create();
        WebResource webResource = restClient.resource(download_url);
        ClientResponse resp = webResource.header("Authorization", "Basic " + authStringEnc)
                .get(ClientResponse.class);


        if(resp.getStatus() != 200){
            System.err.println(" Failed : HTTP error code : " + resp.getStatus());
        }
        else
        {
            System.out.println(" Response : " + resp.getStatus() + " OK. Successfully Connected");
        }

        InputStream is = resp.getEntityInputStream();
        OutputStream os = new FileOutputStream(curDir + "\\" + country.toLowerCase() + "\\ReportsExtracted\\" + name + ".pdf");

        byte[] buffer = new byte[1024];
        int bytesRead;

        while((bytesRead = is.read(buffer)) != -1){
            os.write(buffer, 0, bytesRead);
        }
        is.close();

        //flush OutputStream to write any buffered data to file
        os.flush();
        os.close();

        System.out.println(" Downloaded " + name + " report");

Надеюсь, это поможет.

0 голосов
/ 25 ноября 2018

Может быть комментарием, но не может отформатировать его в комментарии.

Читая документацию, я вижу, что

Извлечение данных отчета.

После завершения отчета клиент может получить свои данные или предоставленную версию отчета в нескольких форматах.

Следующие ресурсыможет использоваться для извлечения визуализированной версии отчета:

/profiler/1.0/reporting/reports/{id}/view.pdf
/profiler/1.0/reporting/reports/{id}/view.csv

Они предназначены для версий PDF и CSV соответственно.

Не могли бы вы попробовать

WebTarget target = client
    .target("https://x.x.x.x/api/profiler/1.0/reporting/reports/751252/view.pdf");
Response resp = target
    .request("application/pdf,image/jpeg,application/xml,application/vnd.ms-excel")
    .header("Authorization", authStringEnc)
    .get(Response.class);
...