zoukankan      html  css  js  c++  java
  • WebForm Response和Request以及Cookie

    内置对象:

    Response对象:响应请求
    Response.Write("<script>alert('添加成功!')</script>");
    Response.Redirect("Default.aspx");//重定向到Default.aspx

    Request对象:获取请求
    Request["key"]来获取传递过来的值

    QueryString:地址栏数据传递 ?key=value&key=value
    注意事项:不需要保密的东西可以传
    不要传过长东西,因为长度有限,过长会造成数据丢失
    增加:
    首先在数据连接类里面写一个增加方法
    public bool Insert(Users u)
    {
    bool isok = false;
    cmd.CommandText = "insert into Users values(@a,@b,@c,@d,@e,@f)";
    cmd.Parameters.Clear();
    cmd.Parameters.Add("@a", u.UserName);
    cmd.Parameters.Add("@b", u.PassWord);
    cmd.Parameters.Add("@c", u.NickName);
    cmd.Parameters.Add("@d", u.Sex);
    cmd.Parameters.Add("@e", u.Birthday);
    cmd.Parameters.Add("@f", u.Nation);

    conn.Open();
    try
    {
    cmd.ExecuteNonQuery();
    isok = true;
    }
    catch { }
    conn.Close();
    return isok;
    }
    然后,在web窗体中搭建一下窗体
    <form id="form1" runat="server">
    <h1>用户添加</h1>
    用户名:<asp:TextBox ID="TextBox1" runat="server"></asp:TextBox><br />
    <br />
    密码:<asp:TextBox ID="TextBox2" runat="server" TextMode="Password"></asp:TextBox><br />
    <br />
    重复密码:<asp:TextBox ID="TextBox3" runat="server" TextMode="Password"></asp:TextBox><asp:Label ID="Label1" runat="server" Text=""></asp:Label><br />
    <br />
    昵称:<asp:TextBox ID="TextBox4" runat="server"></asp:TextBox><br />
    <br />
    性别:<asp:RadioButtonList ID="RadioButtonList1" runat="server" RepeatDirection="Horizontal" RepeatLayout="Flow">
    <asp:ListItem Value="True" Selected="True">男</asp:ListItem>
    <asp:ListItem Value="False">女</asp:ListItem>
    </asp:RadioButtonList><br />
    <br />
    生日:<asp:DropDownList ID="DropDownList1" runat="server"></asp:DropDownList>年
    <asp:DropDownList ID="DropDownList2" runat="server"></asp:DropDownList>月
    <asp:DropDownList ID="DropDownList3" runat="server"></asp:DropDownList>日
    <br />
    <br />
    民族:<asp:DropDownList ID="DropDownList4" runat="server"></asp:DropDownList><br />
    <br />
    <asp:Button ID="Button1" runat="server" Text="添加" />
    </form>
    在form表单中把该有的控件都加上,然后我们来给DropDownList绑定数据,顺便把按钮的点击事件委托好
    if (!IsPostBack)
    {
    for (int i = DateTime.Now.Year; i >= 1900; i--)
    {
    ListItem li = new ListItem(i.ToString(), i.ToString());

    DropDownList1.Items.Add(li);
    }

    for (int i = 1; i <= 12; i++)
    {
    ListItem li = new ListItem(i.ToString(), i.ToString());

    DropDownList2.Items.Add(li);
    }

    for (int i = 1; i <= 31; i++)
    {
    ListItem li = new ListItem(i.ToString(), i.ToString());

    DropDownList3.Items.Add(li);
    }

    DropDownList4.DataSource = new NationData().Select();
    DropDownList4.DataTextField = "NationName";
    DropDownList4.DataValueField = "NationCode";
    DropDownList4.DataBind();
    }

    Button1.Click += Button1_Click;
    接下来我们再来就写点击事件了
    Users u = new Users();
    u.UserName = TextBox1.Text;
    u.PassWord = TextBox3.Text;
    u.NickName = TextBox4.Text;
    u.Sex = Convert.ToBoolean(RadioButtonList1.SelectedItem.Value);
    string date = DropDownList1.SelectedValue + "-" + DropDownList2.SelectedValue + "-" + DropDownList3.SelectedValue;
    u.Birthday = Convert.ToDateTime(date);
    u.Nation = DropDownList4.SelectedItem.Value;
    bool ok = new UsersData().Insert(u);
    if (ok)
    {
    Response.Write("<script>alert('添加成功!')</script>");
    Response.Write("<script>this.opener.location.href='Default.aspx';this.close();</script>");
    }
    else
    {
    Response.Write("<script>alert('添加失败!')</script>");
    }
    好,添加完成
    删除:
    首先还是写方法
    public void Delete(string Uname)
    {
    cmd.CommandText = "delete from Users where UserName=@a";
    cmd.Parameters.Clear();
    cmd.Parameters.Add("@a",Uname);
    conn.Open();
    cmd.ExecuteNonQuery();
    conn.Close();

    }
    新建一个页面delete,在主页面加一个超链接当按钮用
    <a href="Delete.aspx?un=<%#Eval("UserName") %>">删除</a>
    在delete页面里我们用request把Username给传过来,然后调方法
    //1、获得要删除的主键值,username
    string Uname = Request["un"].ToString();
    //2、删除
    new UsersData().Delete(Uname);
    //3、重定向回显示页面
    Response.Redirect("Default.aspx");

    修改:
    主界面和添加大致相同,主界面不想码了,好麻烦= =
    还是先写一个修改方法
    public bool Update(Users u)
    {
    bool isok = false;
    cmd.CommandText = "update Users set PassWord=@b,NickName=@c,Sex=@d,Birthday=@e,Nation=@f where UserName=@a";
    cmd.Parameters.Clear();
    cmd.Parameters.Add("@a", u.UserName);
    cmd.Parameters.Add("@b", u.PassWord);
    cmd.Parameters.Add("@c", u.NickName);
    cmd.Parameters.Add("@d", u.Sex);
    cmd.Parameters.Add("@e", u.Birthday);
    cmd.Parameters.Add("@f", u.Nation);

    conn.Open();
    try
    {
    cmd.ExecuteNonQuery();
    isok = true;
    }
    catch { }
    conn.Close();
    return isok;
    }
    这里我们用和删除一样的超链接当按钮,链接到修改页面
    <a href="Default6.aspx?un=<%#Eval("UserName") %>" target="_blank">修改</a>
    修改的界面和添加大致相同,不同的是修改需要从数据库里读出数据并绑定到控件上,在这里我也不写了


    登陆状态保持:
    Cookies

    在用户电脑的硬盘上保存的一段文本

    http协议包括浏览器,允许站点在用户电脑上以Cookies的形式来临时保存数据

    如果没有设置保存时间,会话cookies
    1、如果你20分钟内没有再次刷新页面,那么此cookies就会自动删除掉
    2、当当前访问连接中断,如关闭浏览器,那么cookies会自动删除

    作用:
    保持用户的登陆状态

  • 相关阅读:
    JDBC数据库访问操作的动态监测 之 p6spy
    ZeroC Ice启用SSL通讯的配置
    heartbeat在yum系发行版本的处理资料
    VisualStudio 调试Linux
    JVM之上的语言小集
    程序人生【一些经典的资料】
    读史知今、以史为鉴 【技术商业化】
    ipython notebook 浏览器中编写数学公式和现实
    大数据 云计算 等搜集的资料
    GO 1.5 代码编译安装 [centos7 64位]
  • 原文地址:https://www.cnblogs.com/blueteasama/p/5904806.html
Copyright © 2011-2022 走看看