0

我正在尝试通过网络方法将用户的帖子存储到访问数据库中。我想存储登录用户的用户名、用户的帖子和发布日期时间。

到目前为止,我可以通过硬编码存储现有的用户帖子。但我想存储任何登录用户的帖子。我被告知我需要获取用户名的用户 ID。

因此,我找到并尝试添加以下代码:

//GetUser() returns current user information
MembershipUser user = Membership.GetUser();

//Returns the UserID and converts to a string
string UserID = user.ProviderUserKey.ToString();

当我尝试使用断点进行调试时,第一个还可以。但对于第二个,VS 2010 表示“对象引用未设置为对象的实例”。我如何解决它?

VS 建议添加“新”,但这不起作用。它还建议捕获 NullReferenceException,但我不知道如何使用他们提供的代码:

public class EHClass
{
    void ReadFile(int index)
    {
        // To run this code, substitute a valid path from your local machine
        string path = @"UsersDB_in_App_Data";
        System.IO.StreamReader file = new System.IO.StreamReader(path);
        char[] buffer = new char[10];
        try
        {
            file.ReadBlock(buffer, index, buffer.Length);
        }
        catch (System.IO.IOException e)
        {
            Console.WriteLine("Error reading from {0}. Message = {1}", path, e.Message);
        }

        finally
        {
            if (file != null)
            {
                file.Close();
            }
        }
        // Do something with buffer...
    }

}

你能给我建议我需要做什么,或者另一种方法来获取用户名的用户ID吗?

4

3 回答 3

2

您没有说明您拥有的 MembershipUser 类型,但ProviderUserKey完全依赖于底层数据存储。

例如,sql 成员资格提供程序将此值存储为 GUID。

如果此属性可能不包含任何有用的数据,那么您需要在访问它之前测试它是否存在:

//Returns the UserID and converts to a string
string UserID;
if ((myObject != null) && (myObject.ProviderUserKey != null)) {
    UserId = myObject.ProviderUserKey.ToString();
} else {
    UserId = String.Empty;
}

此外,除非您在直接的 asmx Web 服务中使用 WSE,否则我认为成员资格提供者不会有任何有效数据可操作。

如果是这种情况,您可能需要切换到 WCF 或实施 WSE(不推荐)。

于 2011-12-16T02:21:44.970 回答
1

您得到的异常意味着 myObject (当前用户)为空或 myObject.ProviderUserKey 为空。我建议当你在设置 myObject 之后到达断点时,你应该检查 myObject 的值并查看它是否为空。

取决于实际为 null 的内容会影响您查找问题的位置。如果 myObject 为空,那么您需要查看代码以获取当前用户,并检查是否有人实际登录等。如果 ProviderUserKey 为空,请考虑您是否需要此 ID,或者最好只使用直接使用用户名,检查成员资格提供者是否真的以任何有意义的方式提供该属性。

于 2011-12-16T02:21:36.817 回答
0

相反,您可以直接使用此代码....

string UserID = MembershipUser.ProviderUserKey.ToString();
于 2011-12-16T02:55:17.100 回答