Postęp przesyłania klienta Jersey
Mam klienta dżersejowego, który musi przesłać plik wystarczająco duży, aby wymagał paska postępu.
Problem polega na tym, że w przypadku przesyłania, które wymaga kilku minut, widzę, że bajty przesłane do 100%jak tylko aplikacja zostanie uruchomiona. Następnie wydrukowanie ciągu „na gotowo” zajmuje kilka minut.
To tak, jakby bajty były wysyłane do bufora, a ja czytałem prędkość bufora transfert-a-zamiast rzeczywistej prędkości wysyłania. To sprawia, że pasek postępu jest bezużyteczny.
To jest bardzo prosty kod:
ClientConfig config = new DefaultClientConfig();
Client client = Client.create(config);
WebResource resource = client.resource("www.myrestserver.com/uploads");
WebResource.Builder builder = resource.type(MediaType.MULTIPART_FORM_DATA_TYPE);
FormDataMultiPart multiPart = new FormDataMultiPart();
FileDataBodyPart fdbp = new FileDataBodyPart("data.zip", new File("data.zip"));
BodyPart bp = multiPart.bodyPart(fdbp);
String response = builder.post(String.class, multiPart);
Aby uzyskać stan postępu, dodałem filtr ContainerListener, oczywiście przed wywołaniem builder.post:
final ContainerListener containerListener = new ContainerListener() {
@Override
public void onSent(long delta, long bytes) {
System.out.println(delta + " : " + long);
}
@Override
public void onFinish() {
super.onFinish();
System.out.println("on finish");
}
};
OnStartConnectionListener connectionListenerFactory = new OnStartConnectionListener() {
@Override
public ContainerListener onStart(ClientRequest cr) {
return containerListener;
}
};
resource.addFilter(new ConnectionListenerFilter(connectionListenerFactory));