Initialization and Cleanup of Event Processing Thread"

From Documentation
m (Created page with '{{ZKDevelopersGuidePageHeader}} __TOC__ === Initialization Before Processing Each Event === An event listener is executed in an event processing thread. Sometimes, you have to …')
 
m (correct highlight (via JWB))
 
(2 intermediate revisions by 2 users not shown)
Line 8: Line 8:
 
A typical example is to initialize the thread for the authentication. Some J2EE or Web containers store authentication information in the thread local storage, such that they could re-authenticate automatically when needed.
 
A typical example is to initialize the thread for the authentication. Some J2EE or Web containers store authentication information in the thread local storage, such that they could re-authenticate automatically when needed.
  
To initialize the event processing threads, you have to register a class, that implements the <tt>org.zkoss.zk.ui.event.EventThreadInit</tt> interface, to the <tt>listener</tt> element in the <tt>WEB-INF/zk.xml</tt> file<ref>It is described more detailedly in '''Appendix B''' in '''the Developer's Reference'''.</ref>.
+
To initialize the event processing threads, you have to register a class, that implements the <code>org.zkoss.zk.ui.event.EventThreadInit</code> interface, to the <code>listener</code> element in the <code>WEB-INF/zk.xml</code> file<ref>It is described more detailedly in '''Appendix B''' in '''the Developer's Reference'''.</ref>.
  
Once registered, an instance of the specified class is constructed in the main thread (aka., the servlet thread), before starting an event processing thread. Then, the <tt>init</tt> method of the instance is called at the context of the event processing thread before doing anything else.
+
Once registered, an instance of the specified class is constructed in the main thread (aka., the servlet thread), before starting an event processing thread. Then, the <code>init</code> method of the instance is called at the context of the event processing thread before doing anything else.
  
Notice that the constructor and the <tt>init</tt> method are invoked at different thread such that developers could retrieve thread-dependent data from one thread and pass to anther.
+
Notice that the constructor and the <code>init</code> method are invoked at different thread such that developers could retrieve thread-dependent data from one thread and pass to anther.
  
Here is an example for the authentication mechanism of JBoss<ref>http://www.jboss.org</ref>. In this example, we retrieve the information stored in the servlet thread in the constructor. Then, we initialize the event processing thread when the <tt>init</tt> method is called.
+
Here is an example for the authentication mechanism of JBoss<ref>http://www.jboss.org</ref>. In this example, we retrieve the information stored in the servlet thread in the constructor. Then, we initialize the event processing thread when the <code>init</code> method is called.
  
 
<source lang="java" >
 
<source lang="java" >
Line 40: Line 40:
 
</source>
 
</source>
 
   
 
   
Then, in <tt>WEB-INF/zk.xml</tt>, you have to specify as follows.
+
Then, in <code>WEB-INF/zk.xml</code>, you have to specify as follows.
  
 
<source lang="xml" >
 
<source lang="xml" >
Line 55: Line 55:
 
A typical example is to close the transaction, if it is not closed properly.
 
A typical example is to close the transaction, if it is not closed properly.
  
To cleanup the event processing threads, you have to register a listener class, that implements the <tt>org.zkoss.zk.ui.event.EventThreadCleanup</tt> interface, to the <tt>listener</tt> element in the <tt>WEB-INF/zk.xml</tt> file.
+
To cleanup the event processing threads, you have to register a listener class, that implements the <code>org.zkoss.zk.ui.event.EventThreadCleanup</code> interface, to the <code>listener</code> element in the <code>WEB-INF/zk.xml</code> file.
  
 
<source lang="xml" >
 
<source lang="xml" >
Line 64: Line 64:
 
</zk>
 
</zk>
 
</source>
 
</source>
 +
 +
=== Notes ===
 +
 +
<references />
  
 
{{ ZKDevelopersGuidePageFooter}}
 
{{ ZKDevelopersGuidePageFooter}}

Latest revision as of 10:40, 19 January 2022

DocumentationZK Developer's GuideZK in DepthEvent listening and processingInitialization and Cleanup of Event Processing Thread
Initialization and Cleanup of Event Processing Thread


Stop.png This documentation is for an older version of ZK. For the latest one, please click here.


Initialization Before Processing Each Event

An event listener is executed in an event processing thread. Sometimes, you have to initialize the thread before processing any event.

A typical example is to initialize the thread for the authentication. Some J2EE or Web containers store authentication information in the thread local storage, such that they could re-authenticate automatically when needed.

To initialize the event processing threads, you have to register a class, that implements the org.zkoss.zk.ui.event.EventThreadInit interface, to the listener element in the WEB-INF/zk.xml file[1].

Once registered, an instance of the specified class is constructed in the main thread (aka., the servlet thread), before starting an event processing thread. Then, the init method of the instance is called at the context of the event processing thread before doing anything else.

Notice that the constructor and the init method are invoked at different thread such that developers could retrieve thread-dependent data from one thread and pass to anther.

Here is an example for the authentication mechanism of JBoss[2]. In this example, we retrieve the information stored in the servlet thread in the constructor. Then, we initialize the event processing thread when the init method is called.

 import java.security.Principal;
 import org.jboss.security.SecurityAssociation;
 import org.zkoss.zk.ui.Component;
 import org.zkoss.zk.ui.event.Event;
 import org.zkoss.zk.ui.event.EventThreadInit;

 public class JBossEventThreadInit implements EventThreadInit {
     private final Principal _principal;
     private final Object _credential;
     /** Retrieve info at the constructor, which runs at the servlet thread. */
     public JBossEventThreadInit() {
         _principal = SecurityAssociation.getPrincipal();
         _credential = SecurityAssociation.getCredential();
     }
     //-- EventThreadInit --//
     /** Initial the event processing thread at this method. */
     public void init(Component comp, Event evt) {
         SecurityAssociation.setPrincipal(_principal);
         SecurityAssociation.setCredential(_credential);
     }
 }

Then, in WEB-INF/zk.xml, you have to specify as follows.

<zk>
    <listener>
        <listener-class>JBossEventThreadInit</listener-class>
    </listener>
</zk>

Cleanup After Processed Each Event

Similarly, you might have to clean up an event processing thread after it has processed an event.

A typical example is to close the transaction, if it is not closed properly.

To cleanup the event processing threads, you have to register a listener class, that implements the org.zkoss.zk.ui.event.EventThreadCleanup interface, to the listener element in the WEB-INF/zk.xml file.

<zk>
    <listener>
        <listener-class>my.MyEventThreadCleanup</listener-class>
    <listener>
</zk>

Notes

  1. It is described more detailedly in Appendix B in the Developer's Reference.
  2. http://www.jboss.org



Last Update : 2022/01/19

Copyright © Potix Corporation. This article is licensed under GNU Free Documentation License.