0

MasterPage に Container(ContentPlaceHolder) を設定し、必要に応じて非表示にすることはできますか?

たとえば、ユーザーがログインするための2つのテキストボックスとボタンを配置したいのですが、セッションがまだ実行中の場合(つまり、ユーザーがすでにログインしている場合)、これら2つのテキストボックスとボタンをウェルカムメッセージに変更したい(例: 「ようこそ、ユーザー名」)。

ここに画像の説明を入力

MasterPage (注: すべてがコード化されているわけではありません)

<%@ Import Namespace="System.Data.SqlClient" %>
<!DOCTYPE html>

<html xmlns="http://www.w3.org/1999/xhtml">
<script runat="server">

    Protected Sub Button1_Click(sender As Object, e As EventArgs)

        Dim loginSQL As New SqlCommand
        Dim loginComm As String

        Dim CommonFunctions As New CommonFunctions()
        Dim dec_pass As String = CommonFunctions.EncryptPassword(txtLoginPass.Text.Trim)

        Dim conn As New SqlConnection("Data Source=BRIAN-PC\SQLEXPRESS;Initial Catalog=master_db;Integrated Security=True")


        loginComm = "SELECT userid FROM users WHERE username=@username and password=@password"

        conn.Open()


        loginSQL = New SqlCommand(loginComm, conn)
        loginSQL.Parameters.AddWithValue("@username", txtLoginUser.Text.ToString)
        loginSQL.Parameters.AddWithValue("@password", dec_pass)
        Dim dr As SqlDataReader = loginSQL.ExecuteReader()

        If dr.HasRows Then
            Session("userid") = dr("userid")
        ElseIf dr.HasRows = False Then
            lblRegister.ForeColor = Drawing.Color.Red
            lblRegister.Text = "Incorrect Username/Password."
        End If

    End Sub

    Protected Sub Page_Load(sender As Object, e As EventArgs)

        If Session("userid") <> "" Then
            txtLoginUser.Visible = False
            txtLoginPass.Visible = False
        Else

            Dim conn As New SqlConnection("Data Source=BRIAN-PC\SQLEXPRESS;Initial Catalog=master_db;Integrated Security=True")

            Dim useridComm As String = "SELECT name, surname FROM users WHERE userid=@userid"
            Dim sqlUserID As New SqlCommand

            conn.Open()

            Dim userid As String = Session("userid")

            sqlUserID = New SqlCommand(useridComm, conn)
            sqlUserID.Parameters.AddWithValue("@userid", userid)
            Dim datareader As SqlDataReader = sqlUserID.ExecuteReader()

            lblLoggedIn.Text = "Welcome," + txtLoginUser.Text
        End If
    End Sub

</script>



<head>
    <meta charset="utf-8" />
    <script src="http://html5shiv.googlecode.com/svn/trunk/html5.js"></script>
    <title></title>
    <meta name="keywords" content="" />
    <meta name="description" content="" />
    <link rel="stylesheet" href="style.css" type="text/css" media="screen, projection" />
</head>

<body>

    <form id="form1" runat="server">

<div id="wrapper">

    <header id="header">
        <strong>Header:</strong> Mobile CMS

        </header>


<section id="login">

    <div id="login-form">



            <asp:ContentPlaceHolder id="ContentPlaceHolder2" runat="server">

                <p>

                    <asp:Label ID="lblUsername" runat="server" Font-Bold="True" Text="U:"></asp:Label>
&nbsp;<asp:TextBox ID="txtLoginUser" runat="server" BorderStyle="None" BorderWidth="0px" Wrap="False"></asp:TextBox>
&nbsp;
                    <asp:Label ID="lblUsername0" runat="server" Font-Bold="True" Text="P:"></asp:Label>
                    <asp:TextBox ID="txtLoginPass" runat="server" BorderStyle="None" BorderWidth="0px" TextMode="Password" Wrap="False"></asp:TextBox>
&nbsp;
                    <asp:Button ID="btnLogin" runat="server" BorderStyle="None" OnClick="Button1_Click" Text="Login" />

                </p>

                <p>

                    <asp:Label ID="lblRegister" runat="server" Font-Bold="True" Font-Underline="True" ForeColor="#0000CC" Text="Register"></asp:Label>

                    <asp:ContentPlaceHolder ID="ContentPlaceHolder3" runat="server">
                        <asp:Label ID="lblLoggedIn" runat="server" Text=""></asp:Label>
                    </asp:ContentPlaceHolder>

                </p>


                </asp:ContentPlaceHolder>



    </div>

</section>

<div class="navigation-bar">
       <ul class="navigation-menu">

            <li><a href="#" class="home">Home</a></li>
            <li><a href="#" class="mainsettings">Settings</a></li>
            <li><a href="#" class="profile">Profile</a>

                <ul>
                    <li><a href="#" class="messages">Messages</a></li>
                    <li><a href="#" class="settings">Profile Settings</a></li>
                </ul>

            </li>
            <li><a href="#" class="uploads">Uploads</a></li>
            <li><a href="#" class="documents">Media</a>


                <ul>
                    <li><a href="#" class="docs">Documents</a></li>
                    <li><a href="#" class="others">Others</a></li>
                </ul>

            </li>

            <li><a href="#" class="projects">Projects</a>


                <ul>
                    <li><a href="#" class="yprojects">Your Projects</a></li>
                    <li><a href="#" class="otherprojects">Other Projects</a></li>
                </ul>

            </li>

        </ul>

    </div>


    <section id="middle">

        <div id="container">
            <div id="content">
                <div>
                    <asp:ContentPlaceHolder id="ContentPlaceHolder1" runat="server">

                    </asp:ContentPlaceHolder>
                </div>
        </div>
        </div>



    </section>

    <footer id="footer">
        <strong>Footer:</strong> adsfdsgfds
    </footer>

</div>

    </form>

</body>
</html>
4

2 に答える 2

1

理想的には、ASP.NetLoginViewLoginStatusコントロールを使用する必要があります。

ページは 1 つしかないためPanels、ユーザーが認証されているかどうかに基づいて表示と非表示を 2 つだけ使用します。

ContentPlaceHolder注:この場合には使用しないでください。

アップデート:

LoginView試してみたい場合のサンプルコードは次のとおりです。それはそれを行うための好ましい方法です。

%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm6.aspx.cs" 
    Inherits="WebApplication2010.WebForm6" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
</head>
<body>
    <form id="form1" runat="server">
    <asp:LoginView ID="LoginView1" runat="server">
        <AnonymousTemplate>
            <asp:Label ID="lblUsername" runat="server" Font-Bold="True" Text="U:"></asp:Label>
            &nbsp;<asp:TextBox ID="txtLoginUser" runat="server" BorderStyle="None" BorderWidth="0px"
                TextMode="Password" Wrap="False"></asp:TextBox>
            &nbsp;
            <asp:Label ID="lblUsername0" runat="server" Font-Bold="True" Text="P:"></asp:Label>
            <asp:TextBox ID="txtLoginPass" runat="server" BorderStyle="None" BorderWidth="0px"
                TextMode="Password" Wrap="False"></asp:TextBox>
            &nbsp;
            <asp:Button ID="btnLogin" runat="server" BorderStyle="None" OnClick="Button1_Click"
                Text="Login" />
        </AnonymousTemplate>
        <LoggedInTemplate>
            Welcome!
        </LoggedInTemplate>
    </asp:LoginView>
    </form>
</body>
</html>

protected void Button1_Click(object sender, EventArgs e)
{
    var txtLoginUser = LoginView1.FindControl("txtLoginUser") as TextBox;
    var txtLoginPass = LoginView1.FindControl("txtLoginPass") as TextBox;

    // Your authentication

    // If validation is successful, create Authentication ticket
    FormsAuthentication.SetAuthCookie(txtLoginUser.Text, false);
}
于 2013-04-02T19:11:03.957 に答える
0

まず、あなたはContentPlaceHolder別の内部を持っていますが、ContentPlaceHolderこれには理由がありません。

<asp:ContentPlaceHolder ID="ContentPlaceHolder3" runat="server">
   <asp:ContentPlaceHolder id="ContentPlaceHolder2" runat="server">

ContentPlaceHolder目下のところ、プレースホルダーを非表示にするのではなく、ユーザーがログインしているかどうかに応じて、に含まれるコントロールを非表示にしますが、これはあなた次第です。useridまた、列を SQL クエリに追加します。

これは私の頭の上でテストされていないことに注意してください。

SELECT userid, username, password FROM users ....

If dr.HasRows Then
  Session("userid") = dr("userid")
ElseIf dr.HasRows = False Then
   lblRegister.ForeColor = Drawing.Color.Red
   lblRegister.Text = "Incorrect Username/Password."
End If

これで、セッション変数をチェックしてPage_Load、ユーザーがログインしているかどうかを確認できます。

Protected Sub Page_Load(sender As Object, e As EventArgs)
  If Session("userid") <> "" Then
    txtLoginUser.Visible = False
    txtLoginPass.Visible = False
  Else
    'Set your label text here, query the database to get the First and Second name of the user using the `userid`
  End If
End Sub

編集 読み終わったら、リーダーを閉じる必要があります。

dr.Close()datareader.Close()

また、この行lblLoggedIn.Text = "Welcome," + txtLoginUser.Textは次のようにする必要があります。

lblLoggedIn.Text = datareader("name").ToString() & " " &
datareader("surname").ToString()
于 2013-04-02T19:11:03.113 に答える