由於實施不當,JSF 表單提交時授權重定向失敗
在JSF 中實現自訂授權時,使用正確的工具和方法至關重要方法。在這種情況下,自訂 FacesServlet 不適合處理授權檢查。
出現此問題的原因是自訂 FacesServlet 攔截所有請求,包括 JSF 命令連結/按鈕提交。然而,這些提交通常會觸發 AJAX 請求,這些請求需要特定的 XML 回應來指示 JSF ajax 引擎重定向頁面。
透過向 AJAX 請求發送重新導向標頭,自訂 FacesServlet 可以有效地使回應無效,導致頁面未變更。相反,它應該會傳回一個特殊的 XML 回應來重新導向瀏覽器。
此外,通常不鼓勵使用自訂 FacesServlet 進行授權。 Servlet 過濾器是處理此任務的更合適的機制。它提供了更大的靈活性,並避免了與負責 JSF 處理的 FacesServlet 的潛在衝突。
使用 Servlet 過濾器的正確實作
Servlet 過濾器可以設定為在每個請求之前進行幹預,啟用授權檢查。請考慮以下範例:
<code class="java">@WebFilter("/*") public class AuthorizationFilter implements Filter { // Generate XML response for AJAX redirects private static final String AJAX_REDIRECT_XML = "..."; @Override public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws ... { HttpServletRequest request = (HttpServletRequest) req; HttpServletResponse response = (HttpServletResponse) res; HttpSession session = request.getSession(false); // Define authorization flags boolean loggedIn = ...; boolean loginRequest = ...; boolean resourceRequest = ...; boolean ajaxRequest = ...; // Handle authorization and redirection if (loggedIn || loginRequest || resourceRequest) { // Continue request chain.doFilter(request, response); } else if (ajaxRequest) { // Return XML response for AJAX redirects response.getWriter().printf(AJAX_REDIRECT_XML, loginURL); } else { // Perform synchronous redirect response.sendRedirect(loginURL); } } }</code>
此篩選器提供授權的細微控制,並確保正確處理標準要求和 AJAX 請求,並在必要時將使用者重新導向到登入頁面。
以上是為什麼我的 JSF 表單提交授權重定向失敗?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

在IDEA中連接Oracle數據庫時出現數字溢出錯誤的處理方法當我們在使用IntelliJ...

在研究MyBatis框架時,開發者們常常會遇到關於註解的各種問題,其中一個常見的問題是如何正確使用@ResultType注...

Springboot項目多數據源配置下的數據庫訪問性能問題排查本文針對一個Springboot項目中使用Atomikos進行多數據源配�...

Java項目打包成可執行JAR文件時遭遇NoClassDefFoundError難題很多Java開發者在將項目打包成可執行JAR文件時,可能會�...

關於IntelliJIDEA破解的分析方法在編程界,IntelliJ...

問題介紹:視頻質量提升是視頻處理中的一個重要環節,尤其是在處理低清晰度的視頻時,如何利用Java語言和�...

在處理SpringBoot應用中,我們經常會遇到如何正確接收請求參數的問題。特別是當參數格式不是常見的JSON時,更�...


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中