1

我正在尝试使用第三方库“Waffle”来实现 Windows 身份验证。我面临的挑战是如果我们知道用户 ID 和域,如何检索用户的邮件 ID。例如,我能够将用户 ID 设为 XYZ\phembr,并且我想从 SMTP 服务器获取邮件地址(在本例中为 phembrom@xyz.com)。以下是我正在使用的 jsp 代码和我得到的输出。

<%@page import="java.security.Principal" %>

<%@page import="waffle.windows.auth.WindowsAccount" %>

<%@page import="waffle.servlet.WindowsPrincipal" %>

<%@page import="com.sun.jna.platform.win32.Secur32" %>

<%@page import="com.sun.jna.platform.win32.Secur32Util" %>

<%

if (request.getParameter("logoff") != null) {

session.invalidate();

response.sendRedirect("index.jsp");

return;

}

%>

<html>

<head>

<title>Protected Page for Examples</title>

</head>

<body bgcolor="white">

Welcome <b><%= Secur32Util.getUserNameEx(Secur32.EXTENDED_NAME_FORMAT.NameDisplay)   %></b>    <br>

You are logged in as remote user <b><%= request.getRemoteUser() %></b> in session <b><%= session.getId() %></b>.<br>

You are impersonating user <b><%= Secur32Util.getUserNameEx(Secur32.EXTENDED_NAME_FORMAT.NameSamCompatible) %> </b>.

<br><br>

<%

if (request.getUserPrincipal() != null) {

%>

Your user principal name is <b><%= request.getUserPrincipal().getName() %></b>.<br>



Your email is <b><%= Secur32Util.getUserNameEx(Secur32.EXTENDED_NAME_FORMAT.NameUserPrincipal) %></b>.



<br><br>

<%

 } else {

%>

 No user principal could be identified.

 <br><br>

<%

}

%>

 </body>

我得到的输出是:(请注意,我应该得到 phembrom@xyz.com 而不是 phembr@xyz.com)

Welcome Prashant Kumar Hembrom

You are logged in as remote user XYZ\phembr in session DB5376CCEF5FA13F6059AC679F0B95BE.

You are impersonating user XYZ\phembr .



Your user principal name is XYZ\phembr.

Your email is phembr@xyz.com.
4

1 回答 1

1

常见问题解答中对此进行了回答:https ://github.com/dblock/waffle/blob/master/Docs/faq/AdditionalActiveDirectoryInfo.md

您不能直接使用 Waffle 执行此操作。在 Windows 上,这可以通过使用 ADSI 查询 Active Directory 来完成。这涉及通过从登录获得的 SID 定位用户的记录并获取任何附加信息。

两种实现:

于 2013-04-14T14:26:41.333 回答