`

JAAS(一)

阅读更多
Java Authentication Authorization Service(JAAS,Java验证和授权API)提供了灵活和可伸缩的机制来保证客户端或服务器端的Java程序。Java早期的安全框架强调的是通过验证代码的来源和作者,保护用户避免受到下载下来的代码的攻击。JAAS强调的是通过验证谁在运行代码以及他/她的权限来保护系统面受用户的攻击。它让你能够将一些标准的安全机制,例如Solaris NIS(网络信息服务)、Windows NT、LDAP(轻量目录存取协议),Kerberos等通过一种通用的,可配置的方式集成到系统中。
Java Authentication Authorization Service(JAAS,Java验证和授权API)提供了灵活和可伸缩的机制来保证客户端或服务器端的Java程序。Java早期的安全框架强调的是通过验证代码的来源和作者,保护用户避免受到下载下来的代码的攻击。JAAS强调的是通过验证谁在运行代码以及他/她的权限来保护系统面受用户的攻击。它让你能够将一些标准的安全机制,例如Solaris NIS(网络信息服务)、Windows NT、LDAP(轻量目录存取协议),Kerberos等通过一种通用的,可配置的方式集成到系统中。
JAAS简介  
Java安全框架最初集中在保护用户运行潜在的不可信任代码,是基于代码的来源(URL)和谁创建的代码(certificate)来给移动代码进行授权。Java 2 SDK 1.3引入了JAAS( Java Authentication and Authorization Service),增加了基于用户的访问控制能力,即根据谁在运行代码来进行授权。JAAS已经整合进了Java 2 SDK 1.4,作为标准的用户认证与授权模型。编辑本段JAAS用户认证框架  JAAS认证被实现为可插入的方式,允许应用程序同底层的具体认证技术保持独立,新增或者更新认证方法并不需要更改应用程序本身。应用程序通过实例化LoginContext对象开始认证过程,引用配置文件中的具体认证方法,即LoginModule对象,来执行认证。
JAAS:可插入式认证  一旦执行代码的用户通过了认证,JAAS授权组件将和核心Java访问控制模型一起工作,来保护对敏感资源的访问。从J2SDK 1.4开始,访问控制不仅基于代码的来源和签名者(CodeSource),而且还要检查谁在运行代码。执行代码的用户被表现为Subject对象,如果LoginModule认证成功,Subject对象被更新为相应的Principals和credentials。
1.1. 一个简单的例子   本节通过一个简单的例子介绍JAAS开发的基本步骤。本节中的范例位于Apusic应用服务器安装目录中的docs/samples/jaas/simple目录。有关范例的内容、编译、部署与运行,可参考docs/samples/jaas/simple目录下的readme.txt文件。   
范例程序的代码分为两部分,一部分为主程序,执行用户认证过程,源程序如下:   package samples;  
 import javax.security.auth.Subject;  
 import javax.security.auth.login.LoginContext;  
 import javax.security.auth.login.LoginException;  
 import com.sun.security.auth.callback.TextCallbackHandler;   public class CountFiles {   static LoginContext lc = null;   public static void main(String[] args) {   //使用配置文件中名字为“CountFiles”的条目   
try {   lc = new LoginContext("CountFiles",   new TextCallbackHandler());  
 } catch (LoginException le) {  
 le.printStackTrace();   
System.exit(-1);   }   
try {   lc.login();   //如果没有异常抛出,则表示认证成功  
 } catch (Exception e) {   
System.out.println("Login failed: " + e);   System.exit(-1);   }   //以认证用户的身份执行代码  
 Object o = Subject.doAs(lc.getSubject(), new CountFilesAction());   System.out.println("User " + lc.getSubject( ) + " found " + o + " files.");  
 System.exit(0);   }   }   
可以看出,主程序包含了三个重要的步骤:首先构造一个LoginContext对象,然后使用这个对象进行登录,最后,把用户作为doAs方法一个参数。  
 另一部分表示用户想要执行的具体操作,源程序如下:  
 package samples;   
  import java.io.File;   
  import java.security.PrivilegedAction;  
 class CountFilesAction implements PrivilegedAction {  
 public Object run() {   
File f = new File(".");   
File[] files = f.listFiles();   
return new Integer(files.length);   }   }
1.2. JAAS核心类和接口
  JAAS相关的核心类和接口分为三类,公共、认证和授权。  
 公共类:Subject,,Principal,Credential  
 认证类和接口:LoginContext,LoginModule,CallbackHandler,Callback   授权类 :Policy,AuthPermission,PrivateCredentialPermission  
 详细的描述请参考《JAAS Reference Guide》。   
1.3. 配置LoginModules   
JAAS认证被实现为一种可插入的方式,系统管理员可以通过配置文件为每一个应用程序配置LoginModuls来决定应用程序使用的认证技术。配置信息可以保存在文件或数据库中,通过javax.security.auth.login.Configuration对象进行读取。javax.security.auth.login.Configuration为抽象类,JDK提供了可实例化的子类com.sun.security.auth.login.ConfigFile,从文件中读取配置信息。配置文件中包含一个或多个条目,每一个条目指明了特定应用程序使用的认证方法。条目的结构如下:   <name used by application to refer to this entry> {   <LoginModule> <flag> <LoginModule options>;   <optional additional LoginModules, flags and options>;   };   可以看出,每一个条目由名字和一个或多个LoginModule组成。范例程序使用的配置文件login.conf内容如下:   CountFiles {   com.apusic.security.auth.login.ClientPasswordLoginModule required;   };   详细的描述信息可以参考Configuration。
1.4. 编写Policy文件
  JAAS授权扩展了现有的Java安全体系结构,在给代码授权时可以包括一个多个Principal域,指出Principal代表的用户执行特定的代码时,具有分配的权限。因此,授权声明的基本形式为:  
 grant <signer(s) field>, <codeBase URL>   <Principal field(s)> {   permission perm_class_name "target_name", "action";   ....   permission perm_class_name "target_name", "action";   };   缺省的策略文件实现和策略文件语法请参考《Default Policy Implementation and Policy File Syntax》。
范例程序使用的策略文件policy.jaas内容如下:   
grant codeBase "file:./build" {  
 permission java.security.AllPermission;   };  
 grant codeBase "file:/${apusic.home}/lib/apusic.jar" {   permission java.security.AllPermission;   };  
 grant codeBase "file:./build/actions" Principal com.apusic.security.PrincipalImpl "admin" {   
permission java.io.FilePermission "<<ALL FILES>>", "read";   };   可以看出,给主程序和apusic.jar授予了所有权限;当执行具体操作的用户为“admin”时,授予了读取所有文件的权限。
25.1.5. 运行范例程序
  范例程序提供了ant的build.xml脚本,请用户自己下载并安装ant。运行范例程序的步骤为:   首先启动Apusic应用服务器, 范例程序将登录服务器。   编译、运行程序。在simple目录下执行ant命令,会编译源程序CountFiles.java到build目录下,编译源程序CountFilesAction.java到build/actions目录下。然后会自动运行程序,相当于在命令行敲入下面的java命令:   java -classpath %APUSIC_HOME%/lib/apusic.jar;./build;./build/actions   -Djava.security.manager   -Djava.security.policy==policy.jaas   -Djava.security.auth.login.config==login.conf   -Dapusic.home=%APUSIC_HOME% samples.CountFiles   根据提示输入服务器,用户名和口令。 如果用“admin”登录,程序将正常运行结束,若使用其他用户名登录,将抛出访问控制异常。
分享到:
评论

相关推荐

    JAAS简介及实例

    Java Authentication and Authorization Service (JAAS) 是Java平台提供的一种安全框架,用于实现用户身份验证和权限管理。这个框架使得开发者可以轻松地在Java应用程序中集成安全性,而不必深入理解底层的复杂安全...

    java JAAS登陆验证

    JAAS提供了一种标准的方式来实现这一目标,允许开发者在不深入了解底层安全机制的情况下,构建安全的应用程序。 **JAAS 登录验证机制** JAAS的核心概念是登录模块(LoginModule),它是处理用户身份验证逻辑的组件...

    jaas规范实现代码

    Java Authentication and Authorization Service (JAAS) 是 Java 平台中用于安全管理的重要组件,它提供了一种框架,使得应用程序可以进行用户身份验证和权限控制。在本文中,我们将深入探讨 JAAS 的核心概念、工作...

    JAAS简介及示例代码

    Java Authentication and Authorization Service (JAAS) 是Java平台中用于安全性的核心组件,它为开发者提供了一种机制来处理用户身份验证和权限控制。这个服务允许应用程序执行基于角色的安全性,这意味着用户的...

    JAAS认证与授权教程

    Java Authentication and Authorization Service (JAAS) 是Java平台中用于安全性的关键组件,它提供了一种框架,使得应用程序能够实现用户身份验证和权限管理。在这个教程中,我们将深入探讨JAAS的核心概念、工作...

    JAAS in Web Applications

    Java Authentication and Authorization Service (JAAS) 是Java平台中用于安全性的关键组件,它提供了一种标准框架来实现用户身份验证和授权。在Web应用程序中,JAAS被用来控制对资源的访问,确保只有经过验证的用户...

    JAAS登录验证文档

    #### 一、JAAS概述 Java Authentication and Authorization Service(JAAS)是Java平台提供的一种安全框架,它允许开发者为应用程序添加认证和授权功能。与传统的基于容器的身份验证不同,JAAS提供了更为灵活和强大...

    JAAS Demo

    #### 一、JAAS概述 JAAS(Java Authentication and Authorization Service)作为Java平台标准版(JSE)的一部分,为Java应用程序提供了灵活且强大的身份验证和授权服务。相比于早期版本的Java安全模型,JAAS显著...

    websphere 6 JAAS登陆例子

    标题 "websphere 6 JAAS登陆例子" 描述了一个在Websphere 6版本中集成LDAP用户和实现Single Sign-On (SSO)的实践案例。这个主题涉及到Java Authentication and Authorization Service (JAAS)的安全框架,以及它如何...

    JAAS基础教程

    #### 一、JAAS概述与背景 Java Authentication and Authorization Service (JAAS) 是Java平台提供的一种灵活且可扩展的安全机制,用于确保Java应用程序的安全性。JAAS的设计理念在于通过验证谁在运行代码以及该用户...

    JAAS样例

    Java 认证和授权服务(Java Authentication and Authorization Service,简称 JAAS)是 Java 平台的一个组件,用于在应用程序中实现安全性的用户身份验证和权限控制。这篇博客文章将通过一个实际的样例,帮助我们...

    基于JAAS的Java安全编程

    随着互联网安全问题的日益凸显,JAAS作为一种强大的安全机制,在Java EE 1.3标准中扮演了重要的角色,并在许多Java EE应用服务器中得到了广泛应用,例如WebLogic Server等。JAAS主要包括认证和授权两个核心功能: -...

    JAAS In Action download

    JAAS,全称为Java Authentication and Authorization Service,是Java平台中的一个核心组件,用于处理应用系统的用户身份验证和权限授权。这个框架允许开发者构建安全的应用程序,确保只有经过验证的用户才能访问受...

    java软件包文件 jaas.jar

    Java Authentication and Authorization Service (JAAS) 是Java平台中用于安全性的关键组件,它提供了一种框架,用于在Java应用程序中实现认证(Authentication)和授权(Authorization)。`jaas.jar` 文件是这个...

    在JAAS基础上的Java安全编程

    JAAS不仅为Java应用程序提供了一种基于用户身份验证和授权的机制,而且还支持多种不同的认证方式,使得开发者能够灵活地选择最适合其应用场景的安全策略。 #### 二、JAAS的核心概念与特点 ##### 1. 认证与授权 ...

    JAAS.rar_jaas

    描述中提到“可以参考参考,很不错的解决方案”,意味着这个压缩包可能包含了一个实用的JAAS SSO实现,或者是一系列关于如何利用JAAS构建SSO的教程和指南。"sample"这个文件名可能表示有示例代码或配置文件,这对于...

    JAAS简介及实例.

    总结来说,JAAS是Java平台上的一个强大工具,它提供了灵活的用户认证和授权机制,帮助开发者构建更安全的应用程序。通过理解和掌握JAAS的工作原理,开发者可以更好地控制应用程序的访问控制,提高系统的安全性。

    jaas详细配置精讲

    它为开发者提供了一种标准的方式来管理用户的身份验证和访问控制,从而确保应用程序的安全性。在本精讲中,我们将深入探讨JAAS的配置及其在Tomcat服务器中的应用。 首先,我们来看J2EE的安全认证机制。在J2EE环境中...

Global site tag (gtag.js) - Google Analytics