You are viewing a plain text version of this content. The canonical link for it is here.
Posted to java-dev@axis.apache.org by "Rich Scheuerle (JIRA)" <ji...@apache.org> on 2009/09/21 23:43:16 UTC

[jira] Resolved: (AXIS2-4502) JAX-WS Needs a property to prevent lossy transformations before the application handlers are called

     [ https://issues.apache.org/jira/browse/AXIS2-4502?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

Rich Scheuerle resolved AXIS2-4502.
-----------------------------------

    Resolution: Fixed

> JAX-WS Needs a property to prevent lossy transformations before the application handlers are called
> ---------------------------------------------------------------------------------------------------
>
>                 Key: AXIS2-4502
>                 URL: https://issues.apache.org/jira/browse/AXIS2-4502
>             Project: Axis 2.0 (Axis2)
>          Issue Type: Bug
>          Components: jaxws
>            Reporter: Rich Scheuerle
>            Assignee: Rich Scheuerle
>   Original Estimate: 24h
>  Remaining Estimate: 24h
>
> Problem:
> When a message is received, we want to quickly transform the message into the "final form" to reduce memory and increase speed.
> For example, in the JAX-WS server inbound case, the message payload is transformed into a JAXB object (which is what the JAXWS @WebService needs).
> However if the customer has installed a JAX-WS soap handler AND that handler inspects the message payload (the contents of the soap Body), then
> the JAXB object must be "re-transformed" into an SAAJ tree.
> This re-transformation is slow and is also "lossy".  For example, the namespaces in the original message and post-JAXB message may be different.
> Most SOAP Handlers don't touch the SOAP body.  The JAX-WS specification does not provide a mechanism to allow SOAP Handlers to tell the engine their "intent".
> So we want to expose an option that would allow a customer (developer or administrator) to preserve the original message.
> Solution:
> The Axis JAX-RPC web service engine had a property call "high fidelity".  The intention of the property was to preserve the original message.
> I am working on a fix to introduce a "jaxws.payload.highFidelity" property.  The property will be available for programatic property (used by the developer )or as a configuration parameter (used by an administrator).
> **
>      * Context Property:
>      * Name: jaxws.payload.highFidelity
>      * Value: Boolean.TRUE or Boolean.FALSE
>      * Default: null, which is interpreted as FALSE....engine may set this to TRUE in some cases.
>      * 
>      * Configuration Parameter
>      * Name: jaxws.payload.highFidelity
>      * Value: String or Boolean representing true or false
>      * Default: null, which is interpreted as FALSE
>      * 
>      * Description:
>      * If the value is false, the jax-ws engine will transform the message in the most
>      * performant manner.  In some cases these transformations will cause the loss of some information.
>      * For example, JAX-B transformations are lossy.  
>      * 
>      * If the value is true, the jax-ws engine will transform the message in the most loss-less manner.
>      * In some cases this will result in slower performance.  The message in such cases is "high fidelity",
>      * which means that it is a close replica of the original message.
>      * 
>      * Customers should accept the default behavior (false), and only set the value to true if it is
>      * necessary for a SOAP Handler or other code requires a high fidelity message.
>      * 
>      * The engine will first examine the Context property.  If not set, the value of the Configuration
>      * property is used.
>      */
>     public static final String JAXWS_PAYLOAD_HIGH_FIDELITY =
>         "jaxws.payload.highFidelity";

-- 
This message is automatically generated by JIRA.
-
You can reply to this email to add a comment to the issue online.