0
点赞
收藏
分享

微信扫一扫

JAAS Authentication Example


例子程序来源于Java文档。

1.  配置Kerberos的Server端,配置KDC(kdc.conf)和Server(krb5.conf)。

2.  增加一个Principal,一个用于程序测试。

3.  将JassAcn.java和Jaas.conf文件拷贝到一个文件夹。

4.  Javac编译JassAcn.java文件

5.  用下面的命令执行class文件,替换成自己的配置

java -Djava.security.krb5.realm=HIGHGO.COM-Djava.security.krb5.kdc=hadooph.highgo.com-Djava.security.auth.login.config=jaas.conf JaasAcn

6.  运行此class文件,提示输入Kerberosusername和Kerberos password,验证成功,打印Authentication succeeded!,验证失败,打印Authenticationfailed和失败原因。

7.  也可将程序导入到Eclipse里运行,只要在运行时,在虚拟机参数里加入

-Djava.security.krb5.realm=HIGHGO.COM
-Djava.security.krb5.kdc=hadooph.highgo.com
-Djava.security.auth.login.config=jaas.conf

即可。调试什么的更方便。

Appendix

1.      JaasAcn.java

import javax.security.auth.*;
import javax.security.auth.callback.*;
import javax.security.auth.login.*;
importcom.sun.security.auth.callback.TextCallbackHandler;

/**
*This JaasAcn application attempts to authenticate a user and reports whether
* ornot the authentication was successful.
*/
public class JaasAcn {
public static void main(String[] args) {
// Obtain a LoginContext,needed for authentication. Tell it
// to use the LoginModuleimplementation specified by the
// entry named"JaasSample" in the JAAS login configuration
// file and to also use thespecified CallbackHandler.
LoginContext lc = null;
try {
lc = newLoginContext("JaasSample", new TextCallbackHandler());
} catch (LoginException le) {
System.err
.println("Cannot create LoginContext. " + le.getMessage());
System.exit(-1);
} catch (SecurityException se){
System.err
.println("Cannot create LoginContext. " + se.getMessage());
System.exit(-1);
}
try {
// attemptauthentication
lc.login();
} catch (LoginException le) {
System.err.println("Authentication failed:");
System.err.println(" "+ le.getMessage());
System.exit(-1);
}
System.out.println("Authentication succeeded!");
}

2.      Jaas.conf

JaasSample {
com.sun.security.auth.module.Krb5LoginModule required;
};

举报

相关推荐

0 条评论