CDI"

From Documentation
m ((via JWB))
m (remove empty version history (via JWB))
 
(3 intermediate revisions by the same user not shown)
Line 27: Line 27:
 
Then, we could access it by specifying the variable resolver: <javadoc>org.zkoss.zkplus.cdi.DelegatingVariableResolver</javadoc> as shown below:
 
Then, we could access it by specifying the variable resolver: <javadoc>org.zkoss.zkplus.cdi.DelegatingVariableResolver</javadoc> as shown below:
  
<source lang="xml" high="1">
+
<source lang="xml" highlight="1">
 
<?variable-resolver class="org.zkoss.zkplus.cdi.DelegatingVariableResolver"?>
 
<?variable-resolver class="org.zkoss.zkplus.cdi.DelegatingVariableResolver"?>
 
<window title="ZK + CDI: Hello World" width="300px">
 
<window title="ZK + CDI: Hello World" width="300px">
Line 39: Line 39:
 
[http://docs.jboss.org/weld/reference/1.0.0/en-US/html/ Weld] is an implementation of CDI. Here is a brief installation instructions:
 
[http://docs.jboss.org/weld/reference/1.0.0/en-US/html/ Weld] is an implementation of CDI. Here is a brief installation instructions:
  
* Copy <tt>weld-servlet.jar</tt> to your application's <tt>WEB-INF/lib</tt> folder. You can find the jar file in [[https://sourceforge.net/projects/jboss/files/Weld/1.0.0.SP1/weld-1.0.0.SP1.zip/download  Weld 1.0 SP1].
+
* Copy <code>weld-servlet.jar</code> to your application's <code>WEB-INF/lib</code> folder. You can find the jar file in [[https://sourceforge.net/projects/jboss/files/Weld/1.0.0.SP1/weld-1.0.0.SP1.zip/download  Weld 1.0 SP1].
  
* Add in your application's <tt>WEB-INF/web.xml</tt> the following listener. This makes Weld bind with Tomcat.  
+
* Add in your application's <code>WEB-INF/web.xml</code> the following listener. This makes Weld bind with Tomcat.  
 
<source lang="xml">
 
<source lang="xml">
 
<listener>
 
<listener>
Line 48: Line 48:
 
</source>
 
</source>
  
* In your application's <tt>META-INF</tt> folder, creates a <tt>context.xml</tt> file with following contents. This provides a JNDI reference <tt>java:comp/env/BeanManager</tt> for the accessing to the Weld bean manager. The ZK CDI variable resolver will need this.  
+
* In your application's <code>META-INF</code> folder, creates a <code>context.xml</code> file with following contents. This provides a JNDI reference <code>java:comp/env/BeanManager</code> for the accessing to the Weld bean manager. The ZK CDI variable resolver will need this.  
 
<source lang="xml">
 
<source lang="xml">
 
<Context>
 
<Context>
Line 58: Line 58:
 
* Add  '''WEB-INF/beans.xml''' with empty content to the web root.
 
* Add  '''WEB-INF/beans.xml''' with empty content to the web root.
  
=Version History=
+
 
{{LastUpdated}}
 
{| class='wikitable' | width="100%"
 
! Version !! Date !! Content
 
|-
 
| &nbsp;
 
| &nbsp;
 
| &nbsp;
 
|}
 
  
 
{{ZKDevelopersReferencePageFooter}}
 
{{ZKDevelopersReferencePageFooter}}

Latest revision as of 04:33, 5 February 2024

CDI (JSR-299) is an emerging standard for contexts and dependency injection for Java EE.

Here we discuss how to use CDI with ZK, especially the use of DelegatingVariableResolver. It provides the basic support of CDI which allow a ZUML document to access variables defined in CDI. For more comprehensive support, please refer to another product: ZK CDI.

For more information, please refer to the following blogs:

Example

Here is a Hello World example. Suppose we have a Java class called HelloWorld as shown below.

@Named
@SessionScoped
public class HelloWorld implements Serializable {
    private final String text = "Hello World";
    public String getText() {
        return text;
    }
}

Then, we could access it by specifying the variable resolver: DelegatingVariableResolver as shown below:

<?variable-resolver class="org.zkoss.zkplus.cdi.DelegatingVariableResolver"?>
<window title="ZK + CDI: Hello World" width="300px">
    My weld-injected bean says: ${helloWorld.text}
</window>

DelegatingVariableResolver resolves all variables defined by CDI (with Java annotations). In other words, it makes them visible to the ZUML document, including EL expressions, data binding and zscript.

Setup Tomcat + Weld

Weld is an implementation of CDI. Here is a brief installation instructions:

  • Copy weld-servlet.jar to your application's WEB-INF/lib folder. You can find the jar file in [Weld 1.0 SP1.
  • Add in your application's WEB-INF/web.xml the following listener. This makes Weld bind with Tomcat.
<listener>
    <listener-class>org.jboss.weld.environment.servlet.Listener</listener-class>
</listener>
  • In your application's META-INF folder, creates a context.xml file with following contents. This provides a JNDI reference java:comp/env/BeanManager for the accessing to the Weld bean manager. The ZK CDI variable resolver will need this.
<Context>
    <Resource name="BeanManager" auth="Container"
        type="javax.enterprise.inject.spi.BeanManager"
        factory="org.jboss.weld.resources.ManagerObjectFactory"/>
</Context>
  • Add WEB-INF/beans.xml with empty content to the web root.




Last Update : 2024/02/05

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