下面的代码在编译期间没有任何错误,但当我打开页面时,Guid currentUserId = (Guid)currentUser.ProviderUserKey;
处出现错误,说明Object引用未设置为对象的实例。
foreach(DataRowView ProfileInfo in UserProfileDataSource.Select(DataSourceSelectArguments.Empty))
{
//Some codes where I display data from database
}
protected void UserProfileDataSource_Selecting(object sender, SqlDataSourceSelectingEventArgs e)
{
MembershipUser currentUser = Membership.GetUser();
Guid currentUserId = (Guid)currentUser.ProviderUserKey;
e.Command.Parameters["USERID"].Value = currentUserId;
}
这是我的SQLDataSource
<asp:SqlDataSource ID="UserProfileDataSource" runat="server"
ConnectionString="<%$ ConnectionStrings:ConnectionString %>"
onselecting="UserProfileDataSource_Selecting"
ProviderName="<%$ ConnectionStrings:ConnectionString.ProviderName %>"
SelectCommand="SELECT "TITLE", "FAMILYNAME", "GIVENNAME", "MIDDLENAME", "POSITION", "INSTITUTIONNAME", "USERID", "REGISTEREDDATE" FROM "MEMBERINFO" WHERE ("USERID" = ?)">
<SelectParameters>
<asp:Parameter Name="USERID" Type="Object" />
</SelectParameters>
</asp:SqlDataSource>
Ernie
在尝试访问currentUser之前,您应该检查以确保它不是null:
if ( currentUser != null )
{
/* do stuff here */
}
else
{
/* do something else, like show an error message perhaps */
}
试试这个代码:
string username = HttpContext.Current.User.Identity.Name;
if(!string.IsNullOrEmpty(username))
{
MembershipUser currentUser = Membership.GetUser(username);
Guid currentUserId = new Guid(currentUser.ProviderUserKey.ToString());
}
您似乎允许匿名用户访问需要登录用户的页面。如果用户尚未登录,则无法获取该用户。
安全由授权和身份验证两部分组成。身份验证是登录,但授权是拒绝未经授权的用户(例如尚未登录或没有为其分配正确角色的用户)访问页面。
如果您的页面依赖于经过身份验证的用户,则应拒绝匿名用户访问。如果页面不依赖于经过身份验证的用户,而仅在成员信息经过身份验证时使用成员信息,那么如果用户未经过身份验证,则需要防止调用成员函数(或任何使用成员数据的内容)。
问题是错误代码。请尝试以下步骤:-在您的网站中,将"开始页面"设置为正确的"登录"页面。一旦您正确登录并登录页面,您就应该能够访问此属性。如果您单击注销按钮,登录页面可能会引用此会员信息,您可能会遇到同样的错误。
因此,解决方法很简单。1.正确设置起始页。2.处理两种情况:-用户已登录,用户未有效登录。一个例子如下:-
protected void Page_Load(对象发送方,EventArgs e){
if (Membership.GetUser() == null)
{ Label1.Text = "";
Label_TotalCoxxxxxxxxx.Text = "";
Label_TotalSuxxxxxxxxx.Text ="";
}
else {
string loggedinuser = Membership.GetUser().ToString();
Label1.Text = loggedinuser;
Label_TotalCoxxxxxxxxx.Text = "Total of xxxxxxxxxx Added in the current Month:-";
Label_TotalSuxxxxxxxxx.Text = "Total of yyyyyyyyyy done in the current Month:-";
}
}