我正在通过这样的web应用程序创建db用户:
try
{
SetConnection(server);
string sql =
"USE [master]" +
" CREATE LOGIN" + " [TP1\\" + user + "] FROM WINDOWS WITH DEFAULT_DATABASE=[master], " +
"DEFAULT_LANGUAGE=[us_english] " +
"EXEC sys.sp_addsrvrolemember @loginame = N'TP1\\" + user + "', @rolename = N'sysadmin'";
_tableContext.Database.ExecuteSqlCommand(TransactionalBehavior.DoNotEnsureTransaction, sql);
}
catch (Exception e)
{
// log error
throw e;
}而且效果很好。
我正在测试应用程序,并输入了一个在WINDOWS-NT中不存在的名称,并得到了以下错误:
未找到Windows用户或组'TP1\MyName‘。再次检查名称。\r\n‘to 1\MyName’不是有效的登录名,或者您没有权限。\r\n更改数据库上下文到“主”
经过一段时间的研究后,我发现我可以使用SELECT * FROM sysusers,但这只显示用户已经在该服务器上注册了。
我想知道是否有一种方法可以检查用户名是否是有效的NT-user?。
发布于 2018-11-26 15:15:18
这个问题将被标记为重复,但为了明确起见,我只想分享一下我的具体情况:
由于@SteveDrake,我找到了here的答案。
我的实施:
using (PrincipalContext pc = new PrincipalContext(ContextType.Domain))
{
user = "MyName";
UserPrincipal up = UserPrincipal.FindByIdentity(
pc,
IdentityType.SamAccountName,
user);
bool UserExists = (up != null);
}注意:我将ContextType更改为Domain
https://stackoverflow.com/questions/53483574
复制相似问题