0

我有一个用户登录并可以编辑他/其他人的数据的应用程序。但是,如果用户是管理员,他将获得一个网格视图,其中包含他可以编辑的所有用户记录。如果用户不是管理员,他只会得到一个列表视图,他可以在其中编辑自己的数据。

当用户登录页面时,他的用户 ID 本身也存储在 db 中,作为会话变量存储在 Session["ID"] 中。现在我需要用用户的数据填充列表视图。我认为只根据 Session["ID"] 参数查询数据会很好。但我不知道该怎么做。

编辑:

好的,我对此几乎没有代码,因为我不知道该怎么做,但我会发布我所拥有的。首先是我设置用户标识的会话变量的方法:

            objda = new SqlDataAdapter("[GetIDOfUser]", objcon);
            objda.SelectCommand.CommandType = CommandType.StoredProcedure;
            objda.SelectCommand.Parameters.Add("@Username", SqlDbType.VarChar).Value = tbUsername.Text;
            objda.SelectCommand.Parameters.Add("@UserPassword", SqlDbType.VarChar).Value = tbPassword.Text;
            String id = (string)objda.SelectCommand.ExecuteScalar();
            Session["ID"] = id;

这是我的标记:

 <asp:ListView ID="ListView1" Visible="False" runat="server" DataSourceID="SqlDataSource2"></asp:ListView>

这是我启用列表视图的代码:

protected void Page_Load(object sender, EventArgs e)
        {
            if (Session["UserAuthentication"] == null)
            {
                Response.Redirect("Login.aspx");
            }

            if (Session["Benutzerart"].ToString() == Enums.Enumerations.Benutzer.Administrator.ToString())
            {
                GridView1.Visible = true;  

                //Set controls for admin
            }

            if (Session["Benutzerart"].ToString() != Enums.Enumerations.Benutzer.Administrator.ToString())
            {
                ListView1.Visible = true;
                //Set controls for other users
            }
        }

好吧,伙计们,我想通了:

我只是像上面的代码一样制作普通的列表视图。只有数据源在标记中没有 selectcommand 属性。此属性在代码中设置:

if (Session["Benutzerart"].ToString() != Enums.Enumerations.Benutzer.Administrator.ToString())
            {
                ListView1.Visible = true;
                SqlDataSource2.SelectCommand = "SELECT [Titel], [Bezeichnung], [Vorname], [Nachname], [Geburtsdatum], [Geburtsort], [Straße], [Nationalität], [Hausnummer], [PLZ], [Ort], [Land], [Mobil], [UrlaubstageGenommen], [UrlaubstageInsgesamt], [Status], [Benutzerart], [Homepage], [Email], [Festnetz], [Fax], [UrlaubstageRest], [Username], [UserPassword] FROM [Benutzer] WHERE [BenutzerID] = '" + Session["ID"] + "'";
            }

数据源标记:

<asp:SqlDataSource ID="SqlDataSource2" runat="server" ConnectionString="<%$ ConnectionStrings:ConnectionString %>" ></asp:SqlDataSource>
4

2 回答 2

2

您正在将列表视图与 SqlDataSource 绑定,使用 sqldatasource SelectParameter

<asp:SqlDataSource ID="SqlDataSource2" runat="server" 
                                ConnectionString="<%$ ConnectionStrings:yourConnection %>" 
                                SelectCommand="SELECT * FROM yourTable WHERE userid = @userid">
                                <SelectParameters>
                                    <asp:SessionParameter Name="userid" SessionField="ID" Type="String" />
                                </SelectParameters>
                            </asp:SqlDataSource>
于 2013-03-13T15:09:49.920 回答
1

要从 DB 中选择数据,您可以创建 sql 数据源并将其绑定到 ListView:

    SqlDataSource ds = new SqlDataSource();

    ds.ConnectionString = yourDBconnectionString;

    ds.SelectCommand = "SELECT * FROM records_table WHERE user_id=@user_id";
    ds.SelectParameters.Add("user_id", Convert.ToInt32(Session["id"]));

    ListView1.DataSource = ds;
    ListView1.DataBind();

然后将记录字段绑定到 aspx 页面上的 ListView 使用(只是一个示例):

<%# Eval("recort_title") %>
于 2013-03-13T14:56:46.143 回答