java连接Active Directory进行用户认证

本是古典 何须时尚 2022-04-16 06:52 363阅读 0赞

将Windows2003 升级为域控制器:

在运行对话框里输入dcpromo,进入AD安装向导。一步步执行即可。

执行完后可通过管理工具在AD中添加用户。使用新建的用户登录系统时会出现问题:

1)点击管理工具,域安全策略或域控制器安全策略时,提示错误:“未能打开组策略对象 企图在不存在的网络连接上操作

gpedit.msc是可以打开本地组策略的。

原因是服务中的Computer Browser服务没有启动。启动后解决。

2)此系统的本地策略,不允许您采用交互式登录

原因:域控制器缺省状态下不允许新创建的用户登录。
解决办法:
在 这台域控制器中的“Active Directory用户和计算机”中创建一个组,假设组名为“NC Group”,然后打开[开始]→程序→管理工具→域控制器安全策略,在出现的窗口打开“安全设置”→“本地策略”→“用户权利指派”,把“在本地登录” 的权限赋给组“NC Group”,同时把所有要在这台域控制器上登录的终端服务用户添加到组“NC Group”中。
注意:
从设置该策略到策略生效需要一段时间,如果要使策略立即生效,可重启计算机或是运行一次 gpupdate /force 的cmd命令刷新。

创建好用户后可以使用java程序访问AD进行身份认证,方法同访问LDAP相同:

  1. public class AuthenticationTest {
  2. public static void main(String[] args) {
  3. String userName = "zhangsan"; // 用户名称
  4. String password = "123456"; // 密码
  5. String host = "192.168.131.111"; // AD服务器
  6. String port = "389"; // 端口
  7. String domain = "@example.com"; // 邮箱的后缀名
  8. String url = new String("ldap://" + host + ":" + port);
  9. String user = userName.indexOf(domain) > 0 ? userName : userName + domain;
  10. Hashtable<String, String> env = new Hashtable<String, String>();
  11. DirContext ctx;
  12. env.put(Context.SECURITY_AUTHENTICATION, "simple");
  13. env.put(Context.SECURITY_PRINCIPAL, user);
  14. env.put(Context.SECURITY_CREDENTIALS, password);
  15. env.put(Context.INITIAL_CONTEXT_FACTORY, "com.sun.jndi.ldap.LdapCtxFactory");
  16. env.put(Context.PROVIDER_URL, url);
  17. try {
  18. ctx = new InitialDirContext(env);
  19. ctx.close();
  20. System.out.println("验证成功!");
  21. } catch (NamingException e) {
  22. e.printStackTrace();
  23. System.out.println("验证失败!");
  24. }
  25. }
  26. }

发表评论

表情:
评论列表 (有 0 条评论,363人围观)

还没有评论,来说两句吧...

相关阅读

    相关 Active Directory自动安装

    各位大虾: 我们这里用Active Directory 部署一个应用程序。 在服务器端进行AD的设置后,想让加入域的成员机器都自动安装部署的应用程序。但是 发现并没有像想