जेएसएफ - पेज नेविगेशन

नेविगेशन नियम जेएसएफ फ्रेमवर्क द्वारा प्रदान किए गए नियम हैं जो बताते हैं कि बटन या लिंक पर क्लिक करने पर कौन सा दृश्य दिखाया जाना है।

नेविगेशन नियमों को जेएसएफ कॉन्फ़िगरेशन फ़ाइल में परिभाषित किया जा सकता है जिसका नाम चेहरे- config.xml है। उन्हें प्रबंधित फलियों में परिभाषित किया जा सकता है।

नेविगेशन नियमों में स्थितियां हो सकती हैं जिनके आधार पर परिणामी दृश्य दिखाया जा सकता है। JSF 2.0 निहित नेविगेशन प्रदान करता है जिसमें नेविगेशन नियमों को परिभाषित करने की आवश्यकता नहीं है।

निष्प्राण नेविगेशन

JSF 2.0 प्रदान करता है auto view page resolver तंत्र नाम implicit navigation। इस स्थिति में, आपको केवल एक्शन विशेषता में दृश्य नाम डालना होगा और JSF सही खोज करेगाview पृष्ठ स्वचालित रूप से परिनियोजित अनुप्रयोग में।

जेएसएफ पेज में ऑटो नेविगेशन

किसी भी JSF UI घटक की क्रिया विशेषता में दृश्य नाम सेट करें।

<h:form>
   <h3>Using JSF outcome</h3>
   <h:commandButton action = "page2" value = "Page2" />
</h:form>

यहाँ, जब Page2 बटन पर क्लिक किया जाता है, JSF दृश्य नाम को हल करेगा, page2 पेज 2.xhtml एक्सटेंशन के रूप में, और संबंधित दृश्य फ़ाइल ढूंढें page2.xhtml वर्तमान निर्देशिका में।

प्रबंधित बीन में ऑटो नेविगेशन

एक दृश्य नाम वापस करने के लिए प्रबंधित बीन में एक विधि को परिभाषित करें।

@ManagedBean(name = "navigationController", eager = true)
@RequestScoped

public class NavigationController implements Serializable {
   public String moveToPage1() {
      return "page1";
   }
}

प्रबंधित बीन का उपयोग करके किसी भी JSF UI घटक की एक्शन विशेषता में नाम देखें।

<h:form> 
   <h3> Using Managed Bean</h3>  
   <h:commandButton action = "#{navigationController.moveToPage1}" 
   value = "Page1" /glt; 
</h:form>

यहाँ, जब Page1 बटन पर क्लिक किया जाता है, JSF दृश्य नाम को हल करेगा, page1 Page1.xhtml एक्सटेंशन के रूप में, और संबंधित दृश्य फ़ाइल ढूंढें page1.xhtml वर्तमान निर्देशिका में।

सशर्त नेविगेशन

प्रबंधित बीन का उपयोग करके, हम बहुत आसानी से नेविगेशन को नियंत्रित कर सकते हैं। प्रबंधित बीन में निम्न कोड देखें।

@ManagedBean(name = "navigationController", eager = true)
@RequestScoped

public class NavigationController implements Serializable {
   //this managed property will read value from request parameter pageId
   @ManagedProperty(value = "#{param.pageId}")
   private String pageId;

   //condional navigation based on pageId
   //if pageId is 1 show page1.xhtml,
   //if pageId is 2 show page2.xhtml
   //else show home.xhtml
   
   public String showPage() {
      if(pageId == null) {
         return "home";
      }
      
      if(pageId.equals("1")) {
         return "page1";
      }else if(pageId.equals("2")) {
         return "page2";
      }else {
         return "home";
      }
   }
}

JSF UI घटक में पेजआईड को एक अनुरोध पैरामीटर के रूप में पास करें।

<h:form>
   <h:commandLink action = "#{navigationController.showPage}" value = "Page1">
      <f:param name = "pageId" value = "1" />
   </h:commandLink>
   <h:commandLink action = "#{navigationController.showPage}" value = "Page2">
      <f:param name = "pageId" value = "2" />
   </h:commandLink>
   <h:commandLink action = "#{navigationController.showPage}" value = "Home">
      <f:param name = "pageId" value = "3" />
   </h:commandLink>
</h:form>

यहां, जब "पेज 1" बटन पर क्लिक किया जाता है।

  • JSF पैरामीटर पेजId = 1 के साथ एक अनुरोध बनाएगा

  • तब JSF इस पैरामीटर को प्रबंधित कर देगा

  • अब navigationController.showPage () कहा जाता है जो पृष्ठ 1 की जाँच के बाद पृष्ठ 1 के रूप में दृश्य लौटाएगा

  • JSF पृष्ठ 1।xhtml एक्सटेंशन के रूप में दृश्य नाम, पेज 1 को हल करेगा

  • वर्तमान निर्देशिका में संबंधित दृश्य पृष्ठ page1.xhtml ढूँढें

कार्रवाई के आधार पर नेविगेशन को हल करना

JSF नेविगेशन रिज़ॉल्यूशन विकल्प प्रदान करता है, भले ही प्रबंधित बीन अलग-अलग तरीकों से एक ही दृश्य नाम देता हो।

प्रबंधित बीन में निम्न कोड देखें।

public String processPage1() { 
   return "page"; 
} 
public String processPage2() { 
   return "page"; 
}

विचारों को हल करने के लिए, निम्नलिखित नेविगेशन नियमों को परिभाषित करें faces-config.xml

<navigation-rule> 
   <from-view-id>home.xhtml</from-view-id> 
   
   <navigation-case> 
      <from-action>#{navigationController.processPage1}</from-action> 
      <from-outcome>page</from-outcome> 
      <to-view-id>page1.jsf</to-view-id> 
   </navigation-case> 
   
   <navigation-case> 
      <from-action>#{navigationController.processPage2}</from-action> 
      <from-outcome>page</from-outcome> 
      <to-view-id>page2.jsf</to-view-id> 
   </navigation-case> 

</navigation-rule>

यहां, जब Page1 बटन पर क्लिक किया जाता है -

  • navigationController.processPage1() कहा जाता है जो पृष्ठ के रूप में दृश्य लौटाएगा

  • JSF दृश्य नाम का समाधान करेगा, page1 जैसा कि नाम है page and from-action में faces-config is navigationController.processPage1

  • संबंधित दृश्य फ़ाइल ढूँढें page1.xhtml वर्तमान निर्देशिका में

फॉरवर्ड बनाम रीडायरेक्ट

JSF डिफ़ॉल्ट रूप से एक सर्वर पृष्ठ को किसी अन्य पृष्ठ पर नेविगेट करते समय आगे करता है और एप्लिकेशन का URL नहीं बदलता है।

पृष्ठ पुनर्निर्देशन सक्षम करने के लिए, संलग्न करें faces-redirect=true दृश्य नाम के अंत में।

<h:form>
   <h3>Forward</h3>
   <h:commandButton action = "page1" value = "Page1" />
   <h3>Redirect</h3>
   <h:commandButton action = "page1?faces-redirect = true" value = "Page1" />
</h:form>

यहाँ, जब Page1 के तहत बटन Forward क्लिक किया गया है, आपको निम्न परिणाम मिलेगा।

यहाँ जब Page1 के तहत बटन Redirect क्लिक किया गया है, आपको निम्न परिणाम मिलेगा।

उदाहरण अनुप्रयोग

आइए उपरोक्त सभी नेविगेशन उदाहरणों का परीक्षण करने के लिए एक परीक्षण JSF एप्लिकेशन बनाएं।

कदम विवरण
1 एक नाम के साथ एक प्रोजेक्ट बना HelloWorld एक के तहत पैकेज com.tutorialspoint.test के रूप में विस्तार से बताया JSF - आवेदन बनाएं अध्याय।
2 नीचे बताए अनुसार एक पैकेज com.tutorialspoint.test के तहत नेवीगेशनकंट्रोलरजवा बनाएं ।
3 WEB-INF फ़ोल्डर के तहत चेहरे-config.xml बनाएं और नीचे बताए अनुसार इसकी सामग्री को अपडेट करें।
4 WEB-INF फ़ोल्डर के तहत web.xml अपडेट करें जैसा कि नीचे बताया गया है।
5 Page1.xhtml और page2.xhtml बनाएं और नीचे बताए अनुसार एक webapp फ़ोल्डर के तहत home.xhtml को संशोधित करें।
6 यह सुनिश्चित करने के लिए एप्लिकेशन को संकलित करें और चलाएं कि व्यावसायिक तर्क आवश्यकताओं के अनुसार काम कर रहा है।
7 अंत में, एप्लिकेशन को युद्ध फ़ाइल के रूप में बनाएं और इसे Apache Tomcat Webserver में तैनात करें।
8 अंतिम चरण में नीचे बताए अनुसार उपयुक्त URL का उपयोग करके अपना वेब एप्लिकेशन लॉन्च करें।

NavigationController.java

package com.tutorialspoint.test;
  
import java.io.Serializable;  

import javax.faces.bean.ManagedBean; 
import javax.faces.bean.ManagedProperty; 
import javax.faces.bean.RequestScoped;  

@ManagedBean(name = "navigationController", eager = true) 
@RequestScoped 
public class NavigationController implements Serializable {  
   private static final long serialVersionUID = 1L;  
   @ManagedProperty(value = "#{param.pageId}")    
   private String pageId;  
   
   public String moveToPage1() {      
      return "page1";    
   }  
   
   public String moveToPage2() {       
      return "page2";    
   }  
   
   public String moveToHomePage() {      
      return "home";    
   }  
   
   public String processPage1() {       
      return "page";    
   }  
   
   public String processPage2() {       
      return "page";    
   } 
   
   public String showPage() {       
      if(pageId == null) {          
         return "home";       
      }       
      
      if(pageId.equals("1")) {          
         return "page1";       
      }else if(pageId.equals("2")) {          
         return "page2";       
      }else {          
         return "home";       
      }    
   }  
   
   public String getPageId() {       
      return pageId;    
   }  
   
   public void setPageId(String pageId) {       
      this.pageId = pageId;   
   } 
}

चेहरे-config.xml

<?xml version = "1.0" encoding = "UTF-8"?>

<faces-config
   xmlns = "http://java.sun.com/xml/ns/javaee"
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://java.sun.com/xml/ns/javaee
   http://java.sun.com/xml/ns/javaee/web-facesconfig_2_0.xsd"
   version = "2.0">
   
   <navigation-rule>
      <from-view-id>home.xhtml</from-view-id>
      <navigation-case>
         <from-action>#{navigationController.processPage1}</from-action>
         <from-outcome>page</from-outcome>
         <to-view-id>page1.jsf</to-view-id>
      </navigation-case>
      <navigation-case>
         <from-action>#{navigationController.processPage2}</from-action>
         <from-outcome>page</from-outcome>
         <to-view-id>page2.jsf</to-view-id>
      </navigation-case>
   </navigation-rule>

</faces-config>

web.xml

<!DOCTYPE web-app PUBLIC
   "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
   "http://java.sun.com/dtd/web-app_2_3.dtd" >

<web-app>
   <display-name>Archetype Created Web Application</display-name>

   <context-param>
      <param-name>javax.faces.PROJECT_STAGE</param-name>
      <param-value>Development</param-value>
   </context-param>
   <context-param>
      <param-name>javax.faces.CONFIG_FILES</param-name>
      <param-value>/WEB-INF/faces-config.xml</param-value>
   </context-param>
   
   <servlet>
      <servlet-name>Faces Servlet</servlet-name>
      <servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
   </servlet>
   <servlet-mapping>
      <servlet-name>Faces Servlet</servlet-name>
      <url-pattern>*.jsf</url-pattern>
   </servlet-mapping>

</web-app>

page1.xhtml

<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
   "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns = "http://www.w3.org/1999/xhtml"
   xmlns:h = "http://java.sun.com/jsf/html">
   
   <h:body>
      <h2>This is Page1</h2>
      <h:form>
         <h:commandButton action = "home?faces-redirect = true"
            value = "Back To Home Page" />
      </h:form>
   </h:body>
</html>

page2.xhtml

<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
   "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns = "http://www.w3.org/1999/xhtml"
   xmlns:h = "http://java.sun.com/jsf/html">
   
   <h:body>
      <h2>This is Page2</h2>
      <h:form>
         <h:commandButton action = "home?faces-redirect = true"
            value = "Back To Home Page" />
      </h:form>
   </h:body>
</html>

home.xhtml

<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns = "http://www.w3.org/1999/xhtml"
   xmlns:f = "http://java.sun.com/jsf/core"
   xmlns:h = "http://java.sun.com/jsf/html">

   <h:body>
      <h2>Implicit Navigation</h2>
      <hr />
      
      <h:form>
         <h3>Using Managed Bean</h3>
         <h:commandButton action = "#{navigationController.moveToPage1}"
            value = "Page1" />
         <h3>Using JSF outcome</h3>
         <h:commandButton action = "page2" value = "Page2" />
      </h:form>
      <br/>
      
      <h2>Conditional Navigation</h2>
      <hr />
      <h:form>
         <h:commandLink action = "#{navigationController.showPage}"
            value="Page1">
            <f:param name = "pageId" value = "1" />
         </h:commandLink>
              
         
         <h:commandLink action = "#{navigationController.showPage}"
            value="Page2">
            <f:param name = "pageId" value = "2" />
         </h:commandLink>
              
         
         <h:commandLink action = "#{navigationController.showPage}"
            value = "Home">
            <f:param name = "pageId" value = "3" />
         </h:commandLink>
      </h:form>
      <br/>
      
      <h2>"From Action" Navigation</h2>
      <hr />
      
      <h:form>
         <h:commandLink action = "#{navigationController.processPage1}"
         value = "Page1" />
              
         <h:commandLink action = "#{navigationController.processPage2}"
         value = "Page2" />
              
      </h:form>
      <br/>
      
      <h2>Forward vs Redirection Navigation</h2>
      <hr />
      <h:form>
         <h3>Forward</h3>
         <h:commandButton action = "page1" value = "Page1" />
         <h3>Redirect</h3>
         <h:commandButton action = "page1?faces-redirect = true"
         value = "Page1" />
      </h:form>
   </h:body>
</html>

एक बार जब आप सभी बदलावों के साथ तैयार हो जाते हैं, तो हमें एप्लिकेशन को संकलित करने और चलाने के लिए जैसा हमने JSF में किया था - एप्लिकेशन अध्याय बनाएं। यदि आपके आवेदन में सब कुछ ठीक है, तो यह निम्नलिखित परिणाम देगा।