ASP.net 练习(评论模块)

一.说明

此文是小白在学习张晨光老师的视频教学<<Asp.Net WEB服务器编程技术>>中做的学习笔记,一些知识点也是跟着教程走的,大家也可以去老师的主页去学习,谢谢大家.

这一篇要练习的是,如下课程的代码:
在这里插入图片描述

二.登录页面(login.aspx)

//我们在登录按钮点击事件(btn_sub_Click)里增加如下代码
.....
//将用户id绑定到session里
if (resilc > 0)
{
	Session["userid"]= dt.Rows[0]["id"].ToString();
.....

三.歌曲界面(Musci_Main.aspx)

在前端增加如下代码:

<asp:ScriptManager ID="ScriptManager1" runat="server">
</asp:ScriptManager>
<asp:UpdatePanel ID="UpdatePanel1" runat="server">
	<ContentTemplate>
		<div class="container my-md-2">
			<h4>评论:</h4>
			<hr />
			<asp:TextBox ID="comment_txt" runat="server" Height="55px" TextMode="MultiLine" Width="100%"></asp:TextBox><br />
			<asp:Button ID="m_comment" runat="server" Text="评论" CssClass="btn btn-primary" OnClick="m_comment_Click" style="margin-bottom: 0" />
		</div>
	
	</ContentTemplate>
</asp:UpdatePanel>

后端增加(全代码):

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data;
using System.Collections;

namespace MyMusci
{
    public partial class Musci_Main : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {
            string id = Request["id"].ToString();
            string sql = string.Format(@"SELECT t1.*,t2.m_type mu_type FROM music t1 INNER JOIN music_type t2 ON t1.`m_type`=t2.`m_number` AND t1.m_id={0}", id);

            DataTable dt = ToolMysqlDate.executTable(sql);

            //将查询的值赋值给页面
            if (dt.Rows.Count > 0) {
                lblname.Text = dt.Rows[0]["m_name"].ToString();
                lblsinger.Text = dt.Rows[0]["m_singer"].ToString();
                lbltype.Text = dt.Rows[0]["mu_type"].ToString();

                m_photo.Src = dt.Rows[0]["m_photo"].ToString();
                audio.Src = dt.Rows[0]["m_mediafile"].ToString();
                lbldescrip.Text = dt.Rows[0]["m_description"].ToString();
				
				//***本节新加
                //将歌曲编号存放到ViewState,将用户id,放到某个地方,ViewState在页面page间共享
                ViewState["m_id"]= dt.Rows[0]["m_id"].ToString();
            }

        }

        /// <summary>
        /// 评论按钮点击事件
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        protected void m_comment_Click(object sender, EventArgs e)
        {
            //如果用户未登录,则提示用户,并不给予他评论功能
            if (Session["userid"] == null || Session["userid"].ToString() == "") {
                ScriptManager.RegisterStartupScript(this, this.GetType(), "no_user", "alert('您还未登录!')", true);
                return;
            }

            string sql = string.Format(@"insert into comment values(?m_id,?m_comment,?u_id,?sysdate)");
            Hashtable ht = new Hashtable();
            ht.Add("m_id", ViewState["m_id"].ToString());
            ht.Add("m_comment", comment_txt.Text);
            ht.Add("u_id", Session["userid"].ToString());
            ht.Add("sysdate", DateTime.Now);

            int result = ToolMysqlDate.executeSql(sql, ht);
            if (result > 0) {
                ScriptManager.RegisterStartupScript(UpdatePanel1, typeof(UpdatePanel), "ok", "alert('评论成功!')", true);
            }
        }
    }
}

四.效果

未登录时:
在这里插入图片描述
登录后:
在这里插入图片描述
数据库:
在这里插入图片描述

  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值