配置web.xml和glassfish容器实现javaEE表单验证

web.xml配置:

<!-- 声明用于安全约束的角色 --> 
   <security-role>
        <role-name>ReimUser</role-name>
    </security-role>
    <security-role>
        <role-name>ReimAdmin</role-name>
    </security-role>

    <security-constraint>
        <web-resource-collection>
            <web-resource-name>root</web-resource-name>
            <url-pattern>/service/*</url-pattern>
            <url-pattern>/rest/*</url-pattern>
            <http-method>POST</http-method>
            <http-method>GET</http-method>
        </web-resource-collection>
        <auth-constraint>
            <role-name>ReimUser</role-name>
        </auth-constraint>
    </security-constraint>

   <!--  配置表单验证 -->
    <login-config>
        <auth-method>FORM</auth-method>
        <!--  指定HTTP Basic验证中使用的领域名  -->
        <realm-name>ReimApp</realm-name>
        <form-login-config>
            <form-login-page>/login.jsp</form-login-page>
            <form-error-page>/login.jsp</form-error-page>
        </form-login-config>
    </login-config>

 表单的action地址j_security_check  j_username j_password不可更改

 

新建用户表、组表并在glassfish的领域中配置对应的用户表、组表,用于校验用户是否合法。合法时从组表中读取用户对应的组设置到 container 中。

 

其实这就是容器实现的sam模块,他会从配置的 组表 里面查当前登录的用户有哪些组,然后设置  GroupPrincipal 和 sam中 从 token 解析 scope 出来去设置一样。

默认获取 UserPrincipal 对应的类,从里面解析出来的用户信息只有一个账号信息。如果需要获取完成的用户信息,可以自己实现ServerAuthModule模块来实现。

 

这里配置的参数就是ServerAuthModule类所用到的参数。

要支持这种,在 ServerAuthModule 的 validateRequest 里面加上对应的代码就可以了:

if(request.getServletPath().startsWith('/j_security_check')) {
String username = request.getParameter('j_username');
String password = request.getParameter('j_password');
//TODO: check username and password
//TODO: set user's groups
}

这样action 和 对应的参数名称就都可以自己定义了,。 

转载于:https://my.oschina.net/u/2618302/blog/892988

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值