<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    weidagang2046的專欄

    物格而后知致
    隨筆 - 8, 文章 - 409, 評論 - 101, 引用 - 0
    數據加載中……

    為tomcat頁面設置訪問權限(j_security_check)

    web應用中,對頁面的訪問控制通常通過程序來控制,流程為:
    登錄 -> 設置session -> 訪問受限頁面時檢查session是否存在,如果不存在,禁止訪問

    對于較小型的web應用,可以通過tomcat內置的訪問控制機制來實現權限控制。采用這種機制的好處是,程序中無需進行權限控制,完全通過對tomcat的配置即可完成訪問控制。

    為了在tomcat頁面設置訪問權限控制,在項目的WEB-INFO/web.xml文件中,進行如下設置:

    <web-app>

    <!--servlet等其他配置-->

    <security-constraint>
      <web-resource-collection>
          <display-name>Example Security Constraint</display-name>
          <web-resource-name>My Test</web-resource-name>
      
          <url-pattern>/ddly/admin/*</url-pattern>
      </web-resource-collection>
     
    <auth-constraint>
        <role-name>role1</role-name>
        <role-name>tomcat</role-name>
    </auth-constraint>

    </security-constraint>

    <login-config>
        <auth-method>BASIC</auth-method>
        <realm-name>My Test</realm-name>
    </login-config>

    </web-app>

    其中,<url-pattern>中指定受限的url,可以使用通配符*,通常對整個目錄進行訪問權限控制。
    <auth-constraint>
    中指定哪些角色可以訪問<url-pattern>指定的url,在<role-name>中可以設置一個或多個角色名。

    使用的角色名來自tomcat的配置文件${CATALINA_HOME}/conf/tomcat-users.xml

    <login-config>中設置登錄方式,<auth-method>的取值為BASICFORM。如果為BASIC,瀏覽器在需要登錄時彈出一個登錄窗口。如果為FORM方式,需要指定登錄頁面和登錄失敗時的提示信息顯示頁面。

    使用FORM方式的配置樣例如下:

    <login-config>
       <auth-method>FORM</auth-method>
       <realm-name>Example Form-Based Authentication Area</realm-name>
       <form-login-config>
          <form-login-page>/login.jsp</form-login-page>
          <form-error-page>/error.jsp</form-error-page>
       </form-login-config>
    </login-config>

    其中的<form-login-page>指定登錄頁面url<form-error-page>指定登錄失敗時的提示頁面url
    登錄頁面中,formaction,以及其中的用戶名和密碼兩個參數的名稱,都應取固定的值。登錄的后臺處理程序為j_security_check;用戶名和密碼的參數名稱分別為:j_usernamej_password
    如下是登錄頁面(如:login.jsp)的一段示例代碼:

    <form method="POST" action='<%= response.encodeURL("j_security_check") %>' >
      <table border="0" cellspacing="5">
        <tr>
          <th align="right">Username:</th>
          <td align="left"><input type="text" name="j_username"></td>
        </tr>
        <tr>
          <th align="right">Password:</th>
          <td align="left"><input type="password" name="j_password"></td>
        </tr>
        <tr>
          <td align="right"><input type="submit" value="Log In"></td>
          <td align="left"><input type="reset"></td>
        </tr>
      </table>
    </form>

    posted on 2005-07-28 12:42 weidagang2046 閱讀(5015) 評論(1)  編輯  收藏 所屬分類: Java

    評論

    # re: 為tomcat頁面設置訪問權限(j_security_check)   回復  更多評論   

    注意這里的url-pattern <url-pattern>/ddly/admin/*</url-pattern>其實是以本web app為根的相對路徑。
    2005-09-03 20:45 | weidagang2046

    # re: 為tomcat頁面設置訪問權限(j_security_check)   回復  更多評論   

    自己測試了一下,下面是我的web.xml配置文件:

    <?xml version="1.0" encoding="ISO-8859-1"?>

    <web-app xmlns="http://java.sun.com/xml/ns/j2ee"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"
    version="2.4">

    <security-constraint>
    <web-resource-collection>
    <display-name>Example Security Constraint</display-name>
    <web-resource-name>welcome_info</web-resource-name>
    <url-pattern>/*</url-pattern>
    </web-resource-collection>
    <auth-constraint>
    <role-name>role1</role-name>
    <role-name>tomcat</role-name>
    </auth-constraint>
    </security-constraint>
    <login-config>
    <auth-method>BASIC</auth-method>
    <realm-name>welcome_info</realm-name>
    </login-config>
    </web-app>

    2005-09-03 20:47 | weidagang2046
    主站蜘蛛池模板: 久久国产精品萌白酱免费| 黄 色一级 成 人网站免费| 1a级毛片免费观看| 亚洲视频精品在线| 亚洲免费在线视频观看| 亚洲综合男人的天堂色婷婷| 亚洲美女免费视频| 亚洲乱码日产精品BD在线观看| 国产精品怡红院永久免费| 亚洲手机中文字幕| 成人性生交大片免费看无遮挡 | 成人免费看黄20分钟| 亚洲中文字幕久久久一区| 日本一道在线日本一道高清不卡免费| 亚洲色最新高清av网站| 国产精品色午夜视频免费看| 无遮挡免费一区二区三区 | 亚洲国产高清精品线久久| 国产福利在线观看永久免费| 亚洲av无码不卡一区二区三区| 久久午夜伦鲁片免费无码| 亚洲剧情在线观看| 在线观看亚洲免费| 国产精品美女久久久免费| 亚洲综合一区二区精品导航| 免费99精品国产自在现线| 草久免费在线观看网站| 亚洲av永久无码制服河南实里| 一色屋成人免费精品网站| 国产亚洲福利精品一区二区| 国产日韩亚洲大尺度高清| 国产乱码免费卡1卡二卡3卡| 免费激情网站国产高清第一页| 亚洲AV无码国产精品色午友在线 | 美女被免费视频网站a国产| 一级黄色片免费观看| 亚洲理论片在线中文字幕| 四虎影视永久免费观看| 91成人在线免费视频| 无人视频免费观看免费视频 | 最近免费中文字幕中文高清 |