Peter, 

I am very reluctant to accept any changes that extend the API so late in
the release process, especially since there's a solution to this problem
that does not require any changes in HttpClient at all, albeit much less
elegant. One can simply wrap the input stream returned by
HttpMethod#getResponseAsStream to measure the incoming data and provide
a custom RequestEntity to measure the outgoing data

HttpClient 4.0 will provide a better architecture allowing custom
extensions to be injected without braking the existing components.

Oleg


On Thu, 2005-06-23 at 16:50 +1200, Peter Bryant wrote:
> Hi.  I needed to count the bytes sent/received for each http connection.
> 
> The approach I wanted to take was to grab the input and output streams 
> of the http connection when they were created and wrap them in byte 
> counting input/output streams.
> 
> I did not see a mechanism to do this, so I added a new interface and an 
> extra parameter object to the httpconnectionparamters class.
> 
> The same approach may be useful, e.g., for someone to plug in i/o 
> streams that debug output what is going out/in on the wire.
> 
> I submit the following code/idea to be included in the httpclient code. 
>   (As then I won't have to maintain my own codebase with this change in it).
> 
> 
> diff -Naur 
> ../commons-httpclient-3.0-rc2/src/java/org/apache/commons/httpclient/HttpConnection.java
>  
> commons-httpclient-3.0-rc2/src/java/org/apache/commons/httpclient/HttpConnection.java
> --- 
> ../commons-httpclient-3.0-rc2/src/java/org/apache/commons/httpclient/HttpConnection.java
>  
>     2005-06-23 15:38:01.000000000 +1200
> +++ 
> commons-httpclient-3.0-rc2/src/java/org/apache/commons/httpclient/HttpConnection.java
>  
>        2005-04-10 15:04:09.000000000 +1200
> @@ -741,11 +741,6 @@
>               }
>               inputStream = new 
> BufferedInputStream(socket.getInputStream(), inbuffersize);
>               outputStream = new 
> BufferedOutputStream(socket.getOutputStream(), outbuffersize);
> -            IOWrapper ioWrapper = 
> (IOWrapper)this.params.getParameter("iowrapper");
> -            if(ioWrapper!=null) {
> -                inputStream = ioWrapper.wrapInput(inputStream);
> -                outputStream = ioWrapper.wrapOutput(outputStream);
> -            }
>               isOpen = true;
>           } catch (IOException e) {
>               // Connection wasn't opened properly
> @@ -804,11 +799,6 @@
>           }
>           inputStream = new BufferedInputStream(socket.getInputStream(), 
> inbuffersize);
>           outputStream = new 
> BufferedOutputStream(socket.getOutputStream(), outbuffersize);
> -        IOWrapper ioWrapper = 
> (IOWrapper)this.params.getParameter("iowrapper");
> -        if(ioWrapper!=null) {
> -            inputStream = ioWrapper.wrapInput(inputStream);
> -            outputStream = ioWrapper.wrapOutput(outputStream);
> -        }
>           usingSecureSocket = true;
>           tunnelEstablished = true;
>       }
> @@ -1372,8 +1362,4 @@
> 
>       /** The local interface on which the connection is created, or 
> null for the default */
>       private InetAddress localAddress;
> -    public interface IOWrapper {
> -        InputStream wrapInput(InputStream is);
> -        OutputStream wrapOutput(OutputStream os);
> -    }
>   }
> 
> 
> Sample code to use it:
>      public static class ByteCountingWrapper implements 
> HttpConnection.IOWrapper {
>          int read;
>          int sent;
>          private IOUtil.CountInputStream cis;
>          private IOUtil.CountOutputStream cos;
>          public InputStream wrapInput(InputStream is) {
>              if(cis!=null) {
>                  read+=cis.getBytesRead();
>              }
>              return cis = new IOUtil.CountInputStream(is);
>          }
>          public OutputStream wrapOutput(OutputStream out) {
>              if(cos!=null) {
>                  sent+=cos.getCount();
>              }
>              return cos = new IOUtil.CountOutputStream(out);
>          }
>      }
>          HttpClient client = new HttpClient();
>          HttpConnectionManager mgr = client.getHttpConnectionManager();
>          HttpConnectionManagerParams params = mgr.getParams();
>          ByteCountingWrapper bcw = new ByteCountingWrapper();
>          params.setParameter("iowrapper", bcw);
> ...
> 
> Regards, Peter
> http://pingability.com - Web Site Monitoring Service
> 
> ---------------------------------------------------------------------
> To unsubscribe, e-mail: [EMAIL PROTECTED]
> For additional commands, e-mail: [EMAIL PROTECTED]
> 
> 


---------------------------------------------------------------------
To unsubscribe, e-mail: [EMAIL PROTECTED]
For additional commands, e-mail: [EMAIL PROTECTED]

Reply via email to