2

だからここに私の問題があります。ログインと新しいログインアカウントの作成に使用される Login というクラスがあります。

引数を取らない Login コンストラクタを作成しました

public Login()
{
    _gloID = 0;
    _Username = null;
    _Password = null;
    _Note = null;
    _Active = false;
    _Status = null;
    _gvoID = 0;
    _DateModified = new DateTime(1901, 1, 1);
    _ModifiedBy = 0;
}

また、2 つの引数を取る Login コンストラクターも作成しました。このコンストラクターは、ユーザー名とパスワードを受け取り、データベースから残りの情報を収集します。

public Login(string username, string password)
{
    // Declarations
    uint gloid = 0, gvoid = 0, modifiedby = 0;
    string note = null, status = null;
    bool active = false;
    DateTime datemodified = new DateTime(1901, 1, 1);
    // Command
    string query = string.Format("SELECT glo_id, glo_note, glo_active, glo_status, gvo_id, date_modified, modified_by FROM gfrc_login" +
                                    " WHERE glo_username = '{0}' AND glo_password = '{1}'", username, password);

    try
    {
        using (conn)
        {
            conn.Open();
            cmd = new OleDbCommand(query, conn);
            rdr = cmd.ExecuteReader();
            while (rdr.Read())
            {
                gloid = Convert.ToUInt32(rdr.GetString(0));
                note = rdr.GetString(1).ToString();
                active = Convert.ToBoolean(rdr.GetString(2));
                status = rdr.GetString(3).ToString();
                gvoid = Convert.ToUInt32(rdr.GetString(4));
                datemodified = Convert.ToDateTime(rdr.GetString(5));
                modifiedby = Convert.ToUInt32(rdr.GetString(6));
            }
        }
    }
    finally
    {
        if (rdr != null)
            rdr.Close();
    }
    if (conn != null)
    {
        conn.Close();
    }

    _gloID = gloid;
    _Username = username;
    _Password = password;
    _Note = note;
    _Active = active;
    _Status = status;
    _gvoID = gvoid;
    _DateModified = datemodified;
    _ModifiedBy = modifiedby;
}

すべてのデータベース接続変数がクラスの先頭で宣言されていることに注意してください。

次を実行しようとすると、次のエラーが表示されます。「ログイン」には、2 つの引数を取るコンストラクターが含まれていません。

protected void Login_Authenticate(object sender, EventArgs e)
{
    string username = txtUsername.Text;
    string password = CalculateMD5(txtPassword.Text);
    Login login = new Login(username, password);
}

編集: 参考までに、コードの残りの部分で SQL インジェクションを防止する対策を講じています。

4

2 に答える 2

3

あなたはおそらく2つの異なるLoginクラスを参照しています。完全な名前 (名前空間を含む) を指定してみて、何が起こるかを確認してください。

于 2013-06-07T09:31:57.903 に答える
2

呼び出し元のクラスも呼び出さLoginれます。生成されたイベント ハンドラーからわかります。

型の完全な名前空間を使用するか、クラスの名前を別のものに変更する必要があります。

例えば:

protected void Login_Authenticate(object sender, EventArgs e)
{
    string username = txtUsername.Text;
    string password = CalculateMD5(txtPassword.Text);
    My.Namespace.Login login = new My.Namespace.Login(username, password);
}
于 2013-06-07T09:32:07.247 に答える