我刚刚开始通过stackify使用Retrace监视我的应用程序,并且看到成千上万的错误,这些错误是:
System.FormatException: Guid should contain 32 digits with 4 dashes (xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx).
at System.Guid.TryParseGuidWithNoStyle
at System.Guid.TryParseGuid
at System.Guid..ctor
at System.DirectoryServices.AccountManagement.ADStoreCtx.IdentityClaimToFilter
这些错误每天要发生数千次,我为什么不知道呢?如果可以帮助您确定问题,我很乐意发布更多代码,但是现在我只发布我认为相关的内容,请不要拒绝投票,否则在有要求时我不会提供更多必要的信息。
首先,我的应用程序的工作方式如下:
MVC前端-使用Windows身份验证(使用RestSharp调用后端)
Web API后端,使用从RestSharp NTLM身份验证传递的Windows身份验证。
RestSharp包装器
public object WebRequest<T>(string controller, Dictionary<string, string> parameters, Method apiMethod, string action)
{
RestClient client = new RestClient(Url + controller + "/");
client.Authenticator = new NtlmAuthenticator();
RestRequest request = new RestRequest(action, apiMethod);
if (parameters != null && parameters.Count > 0)
{
foreach (var parameter in parameters)
{
request.AddParameter(parameter.Key, parameter.Value);
}
}
object result = JsonToObject<T>(client.Execute(request).Content);
return result;
}
辅助方法
@helper Username()
{
PrincipalContext ctx = new PrincipalContext(ContextType.Domain);
var username = System.Web.HttpContext.Current.User.Identity.Name.Replace(@"DOMAIN\", "");
@username
}
@helper UserFullName()
{
using (var context = new PrincipalContext(ContextType.Domain))
{
var principal = UserPrincipal.FindByIdentity(context, User.Identity.Name);
if (principal != null)
{
var fullName = string.Format("{0}", principal.DisplayName);
@fullName
}
}
}
关于此错误可能发生在哪里或如何缩小范围的任何建议?根据我在Stackify中所说的,它似乎发生在每个页面上。
答案 0 :(得分:1)
FindByIdentity
有一个重载,可让您指定identityValue
的实际含义,例如
Try UserPrincipal.FindByIdentity(context, IdentityType.SamAccountName, User.Identity.Name);
由于GUID是此调用的有效选项,因此当您使用非特定的重载时,似乎存在问题,并且它大概会尝试嗅探该值是什么。