我有两个共享会员提供商的网站.其中一个是ASP Playground站点,另一个是安装了ASP Playground站点集成包的站点.我们称他们为ASPPG网站和SIP网站.
我在SIP站点上运行Membership.GetAllUsers()时有时会出错.
SIP拒绝此方法,因此它不是标准的ASP.NET版本.
它有时只会发生.我注意到只有在其中一个成员发生某种变化时才会发生这种情况.然后它必须重新创建在调用Membership.GetAllUsers()时存储所有用户的哈希表,这就像这种娱乐在某种程度上出错了.
除了我粘贴在“administratoren”下面的例外,登录的用户名已经改变了一些信息.
通过更新web.config强制网站卸载没有帮助.
它无助于重新启动IIS或完全重新启动服务器.
异常出现后,每次调用Membership.GetAllUsers()时都会一直显示.突然之间,异常消失,并且再次可以登录并运行Membership.GetAllUsers(),没有任何异常.
它几乎看起来像错误在数据库中,并且修复错误的方法是加载ASPPG站点的任何页面.然后错误在SIP站点上得到修复.
导致异常的原因是什么?如何阻止它?
完整的例外是这样的:
Server Error in ‘/’ Application.
Item has already been added. Key in dictionary: ‘administratoren’ Key being added: ‘administratoren’
Description: An unhandled exception occurred during the execution of the current web request. Please review the stack trace for more information about the error and where it originated in the code.Exception Details: System.ArgumentException: Item has already been added. Key in dictionary: ‘administratoren’ Key being added: ‘administratoren’
Source Error:
Linje 116: MembershipUserCollection allUsers;
Linje 117: lock (objLock) {
Linje 118: allUsers = Membership.GetAllUsers();
Linje 119: }
Linje 120:Source File: [WebsiteLocation]\App_Code\MemberInfo.cs Line: 118
Stack Trace: (Please not that the line numbers of MemberInfo.cs in this stacktrace can be a bit off.
[ArgumentException: Item has already been added. Key in dictionary: ‘administratoren’ Key being added: ‘administratoren’]
System.Collections.Hashtable.Insert(Object key,Object nvalue,Boolean add) +7484392
System.Collections.Hashtable.Add(Object key,Object value) +11
System.Web.Security.MembershipUserCollection.Add(MembershipUser user) +129
ASPPG.MembershipProviders.ASPPGSqlMembershipProvider.CreateMembershipUserCollectionFromDataView(DataView dv) in H:\My Document\Visual Studio 2008\Projects\forumu\MembershipProviders\ASPPGSqlMembershipProvider.vb:656
ASPPG.MembershipProviders.ASPPGSqlMembershipProvider.GetAllUsers(Int32 pageIndex,Int32 pageSize,Int32& totalRecords) in H:\My Document\Visual Studio 2008\Projects\forumu\MembershipProviders\ASPPGSqlMembershipProvider.vb:360
System.Web.Security.Membership.GetAllUsers(Int32 pageIndex,Int32& totalRecords) +65
System.Web.Security.Membership.GetAllUsers() +26
MemberInfo.GetAllMembers() in d:\Faelles\SVN-exports\DFF-umbraco\App_Code\MemberInfo.cs:71
usercontrols_GetMemberTopList.LoadTopMembers() in d:\Faelles\SVN-exports\DFF-umbraco\usercontrols\GetMemberTopList.ascx.cs:16
usercontrols_GetMemberTopList.Page_Load(Object sender,EventArgs e) in d:\Faelles\SVN-exports\DFF-umbraco\usercontrols\GetMemberTopList.ascx.cs:11
System.Web.Util.CalliHelper.EventArgFunctionCaller(IntPtr fp,Object o,Object t,EventArgs e) +14
System.Web.Util.CalliEventHandlerDelegateProxy.Callback(Object sender,EventArgs e) +35
System.Web.UI.Control.OnLoad(EventArgs e) +99
System.Web.UI.Control.LoadRecursive() +50
System.Web.UI.Control.LoadRecursive() +141
System.Web.UI.Control.LoadRecursive() +141
System.Web.UI.Control.LoadRecursive() +141
System.Web.UI.Control.LoadRecursive() +141
System.Web.UI.Control.LoadRecursive() +141
System.Web.UI.Control.LoadRecursive() +141
System.Web.UI.Control.LoadRecursive() +141
System.Web.UI.Control.LoadRecursive() +141
System.Web.UI.Control.LoadRecursive() +141
System.Web.UI.Control.LoadRecursive() +141
System.Web.UI.Control.LoadRecursive() +141
System.Web.UI.Control.LoadRecursive() +141
System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint,Boolean includeStagesAfterAsyncPoint) +627Version Information: Microsoft .NET Framework Version:2.0.50727.3603; ASP.NET Version:2.0.50727.3618
MemberInfo.cs的内容如下:
public class MemberInfo { public string Username { get; set; } public string FirstName { get; set; } public string MiddleName { get; set; } public string LastName { get; set; } public string Fullname { get; set; } public string AddressPrimary { get; set; } public string AddressSecondary { get; set; } public string Zip { get; set; } public string Country { get; set; } public string HomepageUrl { get; set; } public string Id { get; set; } public string MemberNo { get; set; } public Boolean IsApproved { get; set; } public string Email { get; set; } public Boolean IsNotMember { get; set; } public Boolean IsUpdated { get; set; } public Boolean HasReceivedWelcomeMail { get; set; } public int RandomNumber { get; set; } public int MemberType { get; set; } public MemberInfo() { } public MemberInfo(string _username,string _id) { Username = _username; MembershipUser userRequested = Membership.GetUser(Username); ProfileBase profile = ProfileBase.Create(Username); IsApproved = userRequested.IsApproved; FirstName = profile.GetPropertyValue("Firstname").ToString(); MiddleName = profile.GetPropertyValue("Middlename").ToString(); LastName = profile.GetPropertyValue("Lastname").ToString(); AddressPrimary = profile.GetPropertyValue("AddressPrimary").ToString(); AddressSecondary = profile.GetPropertyValue("AddressSecondary").ToString(); Zip = profile.GetPropertyValue("Zip").ToString(); Country = profile.GetPropertyValue("Country").ToString(); HomepageUrl = profile.GetPropertyValue("HomepageUrl").ToString(); HasReceivedWelcomeMail = Boolean.Parse(profile.GetPropertyValue("WelcomeMailSent").ToString()); if (FirstName.Length > 2) { string strFullName = FirstName + " " + MiddleName + " " + LastName; Fullname = strFullName.Replace(" "," "); } else { Fullname = Username; } MemberNo = profile.GetPropertyValue("MemberNo").ToString(); IsNotMember = Boolean.Parse(profile.GetPropertyValue("NotMember").ToString()); Email = userRequested.Email; Id = _id; if (profile.GetPropertyValue("Description").ToString() != "") { IsUpdated = true; } else { if (umbraco.library.GetXmlNodeById("1352").Current.SelectSingleNode("node [@nodeName='" + Username + "']/node") == null) { IsUpdated = false; } else { IsUpdated = true; } } RandomNumber = ss.NumberStuff.GenerateRandomNumber(0,10000000); MemberType = 1; if (IsApproved == false && HasReceivedWelcomeMail == false) { // Not yet approved MemberType = 1; } if (IsApproved == false && HasReceivedWelcomeMail == true) { // Deleted MemberType = 2; } if (IsApproved == true && IsNotMember == false) { // Members MemberType = 3; } if (IsApproved == true && IsNotMember == true) { // Administrators MemberType = 4; } } private static object objLock = new object(); public List<MemberInfo> GetAllMembers() { return GetAllMembers(false); } public List<MemberInfo> GetAllMembers(Boolean bIncludeAdministrators) { MembershipUserCollection allUsers; lock (objLock) { allUsers = Membership.GetAllUsers(); } List<MemberInfo> memberInfoList = new List<MemberInfo>(); foreach (MembershipUser userCurrent in allUsers) { MemberInfo mInfo = new MemberInfo(userCurrent.UserName,userCurrent.ProviderUserKey.ToString()); if (mInfo.Id == "0") { continue; } if (mInfo.IsNotMember == true && bIncludeAdministrators == false) { continue; } memberInfoList.Add(mInfo); } return memberInfoList; } public static String GetMemberTypeName(int intMemberType) { switch (intMemberType) { case 1: { return "Endnu ikke godkendt"; } case 2: { return "Slettet"; } case 3: { return "Medlem"; } case 4: { return "Administrator"; } default: { return ""; } } } }
提前致谢 :)
编辑:添加了MemberInfo.cs的新来源并更新了我收到的错误消息.
请注意,堆栈跟踪仍然是旧的,因此它所指的行号可能有点偏差.