JSF 角色示例

2018-02-22 14:31 更新

JSF教程 - JSF角色示例


以下代碼顯示了如何在JSF應用程序中檢查用戶角色。

例子

以下代碼來自demo.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"
      xmlns:f="http://java.sun.com/jsf/core"
      >
      
   <f:event listener="#{user.isAdmin}" type="preRenderView" />
          
  <h:body>
   
      <h1>JSF 2 protected page example</h1>
  
  </h:body>

</html>

下面的代碼來自UserBean.java。

package cn.w3cschool.common;

 
import javax.faces.application.ConfigurableNavigationHandler;
import javax.faces.bean.ManagedBean;
import javax.faces.bean.SessionScoped;
import javax.faces.context.FacesContext;
import javax.faces.event.ComponentSystemEvent;
 
@ManagedBean(name="user")
@SessionScoped
public class UserBean{
 
  public void isAdmin(ComponentSystemEvent event){
        
    FacesContext fc = FacesContext.getCurrentInstance();
    
    if (!"admin".equals(fc.getExternalContext().getSessionMap().get("role"))){
      ConfigurableNavigationHandler nav 
      = (ConfigurableNavigationHandler) 
        fc.getApplication().getNavigationHandler();
    
      nav.performNavigation("access-denied");
    }
    
  }
  
}

以下代碼來自access-denied.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>
 
      <h1>Access Denied!</h1>
 
    </h:body>
 
</html>
下載 Role.zip

運行

將生成的WAR文件從目標文件夾復制到Tomcat部署文件夾,并運行Tomcat-Install-folder/bin/startup.bat。

Tomcat完成啟動后,在瀏覽器地址欄中鍵入以下URL。

http://localhost:8080/simple-webapp/demo.xhtml
以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號