JAAS Tutorial 之 Authorization

如何将 Subject 关联 访问控制上下文
需要如下操作:
1、这个用户必须先完成认证。
2、Subject 对象的静态方法 doAs 被调用,传递一个被认证的 Subject 以及 一个 java.security.PrivilegedAction 或者 java.security.PrivilegedExceptionAction(此方法详细见API)。doAs 方法将 Subject 对象与当前访问控制上下文关联,并调用 action 的 run 方法。 run 方法实现代码作为特定 Subject 所执行。
策略文件

/** Java 2 Access Control Policy for the JAAS Sample Application **/


/* grant the sample LoginModule permissions */

grant codebase "file:./DemoLoginModule.jar" {

    permission javax.security.auth.AuthPermission "modifyPrincipals";

};


grant codebase "file:./DemoAzn.jar" {


   permission javax.security.auth.AuthPermission "createLoginContext.Sample";

   permission javax.security.auth.AuthPermission "doAsPrivileged";

};


/** User-Based Access Control Policy for the SampleAction class

 ** instantiated by SampleAzn 

 **/


grant codebase "file:./DemoAction.jar",

Principal jaas.DemoPrincipal "testUser" {


   permission java.util.PropertyPermission "java.home", "read";

   permission java.util.PropertyPermission "user.home", "read";

   permission java.io.FilePermission "foo.txt", "read";

};


运行授权代码

1、将以下文件放入一个文件夹:

      -- Demo.conf 登录配置文件

      -- DemoAzn.policy 策略文件

2、创建子文件夹 jaas ,放入以下文件

      -- DemoClient.java

      -- DemoAction.java

      -- DemoLoginModule.java

      -- DemoPrincipal.java

3、在顶层目录,编译源文件

4、创建命为DemoAzn.jar的JAR文件,包含DemoClient.class和DemoCallbackHandler.class

      jar -cvf  DemoAzn.jar  jaas/DemoClient.class  jaas/DemoCallbackHandler.class

5、创建命为DemoAction.jar的JAR文件,包含DemoAction.class

      jar -cvf  DemoAction.jar  jaas/DemoAction.class 

6、创建命为DemoLoginModule.jar的JAR文件,包含DemoLoginModule.class和DemoPrincipal.class

      jar -cvf  DemoLoginModule.jar  jaas/DemoLoginModule.class  jaas/DemoPrincipal.class

7、执行程序

      java -classpath DemoAzn.jar:DemoAction.jar:DemoLoginModule.jar 
        -Djava.security.manager 
        -Djava.security.policy==DemoAzn.policy 
        -Djava.security.auth.login.config==Demo.conf  jaas.DemoClient


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值