You are viewing a plain text version of this content. The canonical link for it is here.
Posted to java-user@axis.apache.org by "Mohit.Gupta" <Mo...@india.rsystems.com> on 2005/08/17 12:51:53 UTC
RE: [SPAM_EMAIL] - Using global variables in Axis (HttpSession andServletContext) - Email has different SMTP TO: and MIME TO: fields in the email addresses
Hi,
Solution is purely dependent on your requirements and the scenarios.
If you are not using the thread pools:
- Install a handler on your request path.
- Maintain a InheritableThreadLocal with this handler.
- Set the session to this thread local variable whenever a request is received by this handler.
- Expose a method to get the session - getSession.
- Now the main thread and all its child thread can access this property.
But if you are using thread pools, then the problem is complicate. And the possible solution is
- Maintain a Inheritable thread local variable i.e. property store in every component or taskwhich can be started in a new thread.
- Modify the thread pool in such a way that any parameter can be passed to the thread pool.
- Use this parameter to set the thread local variable of the task i.e. the component, after starting the task in a thread.
- This may help you to get the access for this property.
Thanks
Mohit.
-----Original Message-----
From: Juha Kononen [mailto:Juha.Kononen@savonia-amk.fi]
Sent: Wednesday, August 17, 2005 3:58 PM
To: axis-user@ws.apache.org
Subject: [SPAM_EMAIL] - Using global variables in Axis (HttpSession
andServletContext) - Email has different SMTP TO: and MIME TO: fields in
the email addresses
Thanks for advise!
Too bad that it's not possible to get an access to MessageContext in
user's own threads.
Does this mean that the session mechanism can be used only partially in
axis (because there is no
way to get HttpSession in threads)? I had an idea to use HttpSession as
a global variable in each session where to
store session-specific information (data sent by a client) for each
client. This global
session-specific storage would help me to get data directly instead of
passing it
to objects and threads via many function parameters (in contrast to
HttpSession I use ServletContext as a global variable
for storing a reference to a database pool). Of course, I could get the
data sent by a client via a static class variable
in my DSServiceSOAPBindingImpl class. But unfortunately class variables
are shared with all sessions, so that will not work if
I want my class variables to be session-spefic. So is there any way I
can use a global, session-specific variable anywhere in
my server-side code (including those threads)? Java doesn't have global
variables, but don't we still need them? :)
Juha
>>> jgreif@alumni.princeton.edu 08/16 4:18 >>>
The message context returned from this method is held in a thread-local
variable of the thread handling the web service request. This is the
way a
static method can be used to return a message context correctly for
simultaneously-handled web service requests of various kinds. However,
it
only works in the request-handling threads (i.e., the ones in which the
implementation method of the web service operation is called).
Jeff
----- Original Message -----
From: Juha Kononen
To: axis-user@ws.apache.org
Sent: Tuesday, August 16, 2005 4:03 AM
Subject: The static MessageContext.getCurrentContext method
doesn'twork
Hi, I have a problem with using the MessageContext.getCurrentContext
method
in my server-side code.
I would like to get the current context to able to get an access to the
current session. Well, everything works just fine if I use the
getCurrentContext method in one of my own objects, but something
strange
happends when I'm trying to use this method inside a thread. Everytime
I
call the MessageContext.getCurrentContext method in a thread it returns
only
null. Is this a bug? As I told, the the
MessageContext.getCurrentContext
method works great, I can get my MessageContext object, if I don't use
the
method in threads. Have you guys got this method working in threads?
Even if
I can pass a MessageContext reference into a thread via a static
variable
the getCurrentContext doesn't work. There's got to be something wrong
with
this method. Because of this problem it's impossible to make use of the
session mechanism in threads.