Why are com.sun.net.HttpExchange attributes shared between instances?
Michael McMahon
michael.x.mcmahon at oracle.com
Wed Dec 11 09:48:10 UTC 2019
Hi,
I think I agree that the spec is not completely clear on this point.
While it doesn't explicitly say
that attributes are per-exchange, it does kind of imply that. My
preference would be to tighten
up the spec; make clear what is normative (the current behavior) and
distinguish from that
what is informative, (the example of how filters could use the mechanism).
Go ahead and file a bug and we can take it from there.
Thanks
Michael.
On 10/12/2019 11:10, Julien Royer wrote:
> Hi,
>
> I’m having some troubles understanding how com.sun.net.HttpExchange
> attributes (setAttribute and getAttribute methods) work. Looking at
> the Javadoc, I understood that these attributes were specific to a
> given HttpExchange instance:
>
> https://hg.openjdk.java.net/jdk/jdk/file/a4fb32538898/src/jdk.httpserver/share/classes/com/sun/net/httpserver/HttpExchange.java#l219
> Filter modules may store arbitrary objects with HttpExchange
> instances as an out-of-band communication mechanism.
>
>
> This was also my intuition since these methods are defined on
> HttpExchange and HttpContext (similar
> to javax.servlet.ServletRequest#setAttribute
> and javax.servlet.ServletContext#setAttribute).
>
> When using them on a project, I realised that my intuition was wrong
> though. The source code is very explicit:
>
> https://hg.openjdk.java.net/jdk/jdk/file/a4fb32538898/src/jdk.httpserver/share/classes/sun/net/httpserver/ExchangeImpl.java#l366
> if (attributes == null) {
> attributes = getHttpContext().getAttributes();
> }
>
>
> Is the code wrong or is my understanding of the Javadoc incorrect? If
> so, shouldn’t it be clarified somehow?
>
> Thank you,
> Julien
>
> P.S. this question was also asked on stackoverflow:
> https://stackoverflow.com/questions/59178977/are-com-sun-net-httpserver-httpexchange-attributes-broken
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://mail.openjdk.java.net/pipermail/net-dev/attachments/20191211/51618af8/attachment.htm>
More information about the net-dev
mailing list