asp.net结课作业中遇到的问题解决2

news2024/11/18 1:45:27

目录

1、如何实现评论交流的界面

2、如果想要将文字添加到数据库中,而不是乱码,该怎么修改

3、如果想要添加的数据已经存在于数据库,就不允许添加了,该如何实现

4、想要实现某个模块下有好几个小的功能该如何实现

5、想要实现鼠标扫过书籍的名字就可以显示它的封面,该如何实现

6、显示封面时在某个区域,而不是最顶端,该如何实现

待解决问题


1、如何实现评论交流的界面

 就设置一个留言的界面,然后再设置一个显示留言的界面,在显示的界面中,用户还可以进行修改评论。

2、如果想要将文字添加到数据库中,而不是乱码,该怎么修改

        要确保在将文本插入数据库时不会出现乱码,可以使用参数化查询。这样做可以防止 SQL 注入,并且可以正确处理文本中的特殊字符,避免乱码问题。

例如:


    string adduser = TextBox1.Text;
    string bookid = TextBox2.Text;
    string addtime = TextBox3.Text;
    string comment = TextBox4.Text;

    // 使用参数化查询
    string sqlcmd = "insert into pinglun(adduser,addtime,bookid,commentcontent) values (@AddUser, @AddTime, @BookID, @Comment)";
    SqlCommand mycommand = new SqlCommand(sqlcmd, myconnection);

    // 添加参数并设置值
    mycommand.Parameters.AddWithValue("@AddUser", adduser);
    mycommand.Parameters.AddWithValue("@AddTime", addtime);
    mycommand.Parameters.AddWithValue("@BookID", bookid);
    mycommand.Parameters.AddWithValue("@Comment", comment);

    // 执行 SQL 查询
    mycommand.ExecuteNonQuery();

在使用的过程中,出现了下面的这个错误。 

出现的原因:在初始化的时候没有检查登录的状态,所以这里并没有登录,即Session["UserID"]是个空值,所以就会出现上述错误。

解决办法:首先判断登录状态,如果未登录,就跳转到登陆界面进行登录,如果登录了,就进行下面的操作。 

3、如果想要添加的数据已经存在于数据库,就不允许添加了,该如何实现

先检查是否存在,如果不存在就添加,如果存在就不能添加。

例如:

protected void Button1_Click(object sender, EventArgs e)
{
    myconnection.ConnectionString = sqlconn;
    myconnection.Open();
    
    string name = TextBox1.Text;
    string pwd = TextBox2.Text;
    string sex = DropDownList1.Text;
    string email = TextBox3.Text;
    string number = TextBox4.Text;
    
    // 在插入之前检查是否已存在相同数据
    if (!IsDataExists(name, pwd, sex, email, number))
    {
        // 数据库中不存在相同数据,执行插入操作
        string sqlcmd = "insert into GRmessage(用户名,密码,性别,邮箱,电话) values (@Name, @Pwd, @Sex, @Email, @Number)";
        SqlCommand mycommand = new SqlCommand(sqlcmd, myconnection);
        mycommand.Parameters.AddWithValue("@Name", name);
        mycommand.Parameters.AddWithValue("@Pwd", pwd);
        mycommand.Parameters.AddWithValue("@Sex", sex);
        mycommand.Parameters.AddWithValue("@Email", email);
        mycommand.Parameters.AddWithValue("@Number", number);
        mycommand.ExecuteNonQuery();
        Response.Write("<script>alert('添加成功');window.location.href = 'read.aspx';</script>");
    }
    else
    {
        // 数据库中已存在相同数据,给出提示或执行其他操作
        Response.Write("<script>alert('数据已存在,无法添加');</script>");
    }
    
    myconnection.Close();
}

// 检查数据库中是否已存在相同数据
protected bool IsDataExists(string name, string pwd, string sex, string email, string number)
{
    string sqlcmd = "SELECT COUNT(*) FROM GRmessage WHERE 用户名 = @Name AND 密码 = @Pwd AND 性别 = @Sex AND 邮箱 = @Email AND 电话 = @Number";
    SqlCommand command = new SqlCommand(sqlcmd, myconnection);
    command.Parameters.AddWithValue("@Name", name);
    command.Parameters.AddWithValue("@Pwd", pwd);
    command.Parameters.AddWithValue("@Sex", sex);
    command.Parameters.AddWithValue("@Email", email);
    command.Parameters.AddWithValue("@Number", number);
    
    int count = (int)command.ExecuteScalar();
    return count > 0;
}

4、想要实现某个模块下有好几个小的功能该如何实现

使用控件:treeview

5、想要实现鼠标扫过书籍的名字就可以显示它的封面,该如何实现

可以通过在 HTML 中使用 JavaScript 来实现鼠标悬停在字母上时显示对应的图片。这里是你可以尝试的修改:

  1. 首先,在 <head> 标签中添加一个 <script> 标签来定义 JavaScript 函数。
     <script>
            // 定义显示图片的函数
            function showImage(bookTitle) {
                // 获取对应书籍的图片路径
                var imagePath = '';
    
                switch (bookTitle) {
                    case '活着':
                        imagePath = '/bookimages/huozhe.png'; // 替换为对应图片的路径
                        break;
                    case '疯人说':
                        imagePath = '/bookimages/fengrenshuo.png'; // 替换为对应图片的路径
                        break;
                    // 添加更多书籍的图片路径
                    // case '书籍名称':
                    //     imagePath = '对应的图片路径';
                    //     break;
                    default:
                        // 如果没有对应的图片路径,则不显示图片
                        imagePath = '/bookimages/manhua1.jpg';
                        return;
                }
    
                // 获取图片元素并设置图片路径
                var imgElement = document.getElementById('hoverImage');
                imgElement.src = imagePath;
    
                // 显示图片
                imgElement.style.display = 'block';
            }
    
            // 定义隐藏图片的函数
            function hideImage() {
                // 获取图片元素并隐藏
                document.getElementById('hoverImage').style.display = 'none';
            }
        </script>
  2. 接下来,在书籍列表中的每个书名周围添加 <span> 标签,并为每个 <span> 标签添加 onmouseover 和 onmouseout 事件来调用 JavaScript 函数。
    <div id="btopleft">
        <br />
        <span onmouseover="showImage('活着')" onmouseout="hideImage()">活着</span>
        <span onmouseover="showImage('疯人说')" onmouseout="hideImage()">疯人说</span>
        <!-- 添加更多书籍名称 -->
    </div>
    
  3. 最后,在 HTML 页面的适当位置添加一个 <img> 标签,用于显示悬停在书名上时显示的图片。
<img id="hoverImage" src="" style="display: none; width: 100px; height: 150px;" />

这样,当鼠标悬停在书名上时,对应的图片就会显示出来。记得替换书籍名称和图片路径为实际使用的值。

6、显示封面时在某个区域,而不是最顶端,该如何实现

只需要将第5个问题中的下面这句话放到想要显示图片的位置即可。

<img id="hoverImage" src="" style="display: none; width: 100px; height: 150px;" />

 今天就先这样吧,明天实现书籍的阅读,书籍的管理操作。

待解决问题

?想实现不止鼠标滑过就显示图片,初始化状态下也可以显示图片,且每个图片还会自动变化,该如何实现

?我想要实现跳转的是一个界面,只是编号不同,该怎么实现呢?(几种不同的书籍,好像可以通过UserControl实现。)

?不支持MasterPageFile="~/MasterPage.master"吗?为什么

 ?2登录界面加个会话,不然运行的时候可以直接在地址栏输入跳转到阅读界面

?3如果已经登陆了账号,如何在个人信息管理的时候将用户名和密码显示在上面,而不是自己随机输入呢?post和get方法可以实现吗。

 ?4如何使得DropDownList中的某个选择还能继续向下选

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1642724.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Unity 性能优化之数据面板(Statistics)(一)

提示&#xff1a;仅供参考&#xff0c;有误之处&#xff0c;麻烦大佬指出&#xff0c;不胜感激&#xff01; 文章目录 前言一、unity 统计数据面板&#xff08;Statistics&#xff09;1.Audio属性2.Graphics属性 二、什么是Draw Call&#xff1f;三、Unity3D stats也可以通过代…

大型语言模型的新挑战:AMR语义表示的神秘力量

DeepVisionary 每日深度学习前沿科技推送&顶会论文&数学建模与科技信息前沿资讯分享&#xff0c;与你一起了解前沿科技知识&#xff01; 引言&#xff1a;AMR在大型语言模型中的作用 在自然语言处理&#xff08;NLP&#xff09;的领域中&#xff0c;抽象意义表示&…

【Android学习】自定义文本框和输入监听

实现功能 以上代码可实现功能&#xff1a; 1 自定义文本框样式 2. 文本框触发形式转变 3. 文本框输入长度监听&#xff0c;达到最大长度关闭软键盘 4. password框触发检测phone框内容 1. drawable自定义形状 我创建了editor_focus.xml 和 editor_unfocus.xml&#xff0c;两者仅…

性能优化(一):ArrayList还是LinkedList?

引言 集合作为一种存储数据的容器&#xff0c;是我们日常开发中使用最频繁的对象类型之一。JDK为开发者提供了一系列的集合类型&#xff0c;这些集合类型使用不同的数据结构来实现。因此&#xff0c;不同的集合类型&#xff0c;使用场景也不同。 很多同学在面试的时候&#x…

3.2Java全栈开发前端+后端(全栈工程师进阶之路)-前端框架VUE3框架-企业级应用- Vuex

Vuex简介 Vuex概述 Vuex是一个专门为Vue.js应用程序开发的状态管理模式, 它采用集中式存储管理所有组件的公共状态, 并以相应的规 则保证状态以一种可预测的方式发生变化. 试想这样的场景, 比如一个Vue的根实例下面有一个根组件名为App.vue, 它下面有两个子组件A.vue和B.vu…

巧记英语单词

页面 在输入框中填写英语单词的谐音 这样的话就进行了一次英语单词的记忆练习。 页面代码 <% layout(/layouts/default.html, {title: 英语单词管理, libs: [dataGrid]}){ %> <div class"main-content"><div class"box box-main">&l…

如何为 Nestjs 编写单元测试和 E2E 测试

前言 最近在给一个 nestjs 项目写单元测试&#xff08;Unit Testing&#xff09;和 e2e 测试&#xff08;End-to-End Testing&#xff0c;端到端测试&#xff0c;简称 e2e 测试&#xff09;&#xff0c;这是我第一次给后端项目写测试&#xff0c;发现和之前给前端项目写测试还…

练习题(2024/5/4)

1 二叉树的所有路径 给你一个二叉树的根节点 root &#xff0c;按 任意顺序 &#xff0c;返回所有从根节点到叶子节点的路径。 叶子节点 是指没有子节点的节点。 示例 1&#xff1a; 输入&#xff1a;root [1,2,3,null,5] 输出&#xff1a;["1->2->5","…

学习Rust的第26天:Rust中的cp

在本文中复刻了 cp 实用程序的功能&#xff0c;我想默认使其递归&#xff0c;因为每次我想复制时都输入 -R 文件夹都会觉得有点重复&#xff0c;本文代码将与前文代码保持相似&#xff0c;我们只会更改程序的核心功能和一些变量名称以匹配用例 Pseudo Code 伪代码 function cop…

STM32G474 CMAKE VSCODE 开发环境搭建

本篇博文尝试搭建 stm32g474 的开发环境 一. 工具安装 1. 关于 MinGW、OpenOCD、Zadig 这些工具的下载和安装见 JlinkOpenOCDSTM32 Vscode 下载和调试环境搭建_vscode openocd stm32 jlink-CSDN博客 2. 导出一个 STM32 的 CMAKE 工程&#xff0c;这里略过。 3. 安装 ninja …

C++:继承-继承权限

在C中&#xff0c;类的权限分为公有、私有和保护三种。这些权限控制了类的成员&#xff08;数据成员和成员函数&#xff09;对外部代码的可见性和访问性。 公有&#xff08;public&#xff09;权限&#xff1a; 在公有权限下声明的成员可以被类的外部代码直接访问&#xff1b;公…

小程序引入 Vant Weapp 极简教程

一切以 Vant Weapp 官方文档 为准 Vant Weapp 官方文档 - 快速入手 1. 安装nodejs 前往官网下载安装即可 nodejs官网 安装好后 在命令行&#xff08;winr&#xff0c;输入cmd&#xff09;输入 node -v若显示版本信息&#xff0c;即为安装成功 2. 在 小程序根目录 命令行/终端…

langchain+qwen1.5-7b-chat搭建本地RAG系统

已开源&#xff1a;https://github.com/stay-leave/enhance_llm 概念 检索增强生成&#xff08;Retrieval Augmented Generation, RAG&#xff09;是一种结合语言模型和信息检索的技术&#xff0c;用于生成更准确且与上下文相关的输出。 通用模型遇到的问题&#xff0c;也是…

头歌实践教学平台:三维图形观察OpenGL1.0

一.任务描述 根据提示&#xff0c;在右侧修改代码&#xff0c;并自己绘制出图形。平台会对你编写的代码进行测试。 1.本关任务 学习了解三维图形几何变换原理。 理解掌握OpenGL三维图形几何变换的方法。 理解掌握OpenGL程序的模型视图变换。 掌握OpenGL三维图形显示与观察的…

怎么用CAPL与Python交互

怎么用CAPL与其他应用程序交互 怎么用CAPL与Python交互 怎么用CAPL与Python交互 怎么用CAPL与其他应用程序交互前言1、CAPL怎么调Python&#xff1f;1.1CAPL调Python的命令1.2CAPL调用Python实例 2、怎么把python运行的结果返回给CAPL2.1通过环境变量 3、CAPL调Python的输入参…

OCC笔记:选择TopoDS_Shape顶点、边、面等等

1、通过AIS_InteractiveContext的函数访问当前选择的图形 hAISContext->InitSelected(); hAISContext->MoreSelected(); hAISContext->NextSelected()&#xff1b; hAISContext->SelectedShape()&#xff1b; 其中hAISContext->SelectedShape()通过StdSelect_…

C语言——rand函数

一、rand函数 这是一个在 C 标准库 <stdlib.h> 中定义的函数&#xff0c;用于生成伪随机数&#xff0c;默认情况下&#xff0c;它生成从 0 到 RAND_MAX 的伪随机数&#xff0c;其中 RAND_MAX 是一个常数&#xff0c;通常是 32767。 1、函数原型&#xff1a; 2、函数返回…

MongoDB的分片集群

MongoDB分片技术 介绍 ​ 分片&#xff08;sharding&#xff09;是MongoDB用来将大型集合分割到不同服务器上采用的方法。分片这种说法起源于关系型数据库。但是实际上非关系型数据库在分片方面相比于传统的关系型数据库更有优势。 ​ 与MySQL分库方案对比&#xff0c;MongoDB…

my-room-in-3d中的电脑,电视,桌面光带发光原理

1. my-room-in-3d中的电脑&#xff0c;电视&#xff0c;桌面光带发光原理 最近在github中&#xff0c;看到了这样的一个项目&#xff1b; 项目地址 我看到的时候&#xff0c;蛮好奇他这个光带时怎么做的。 最后发现&#xff0c;他是通过&#xff0c;加载一个 lightMap.jpg这个…

分布式与一致性协议之一致哈希算法(二)

一致哈希算法 使用哈希算法有什么问题 通过哈希算法&#xff0c;每个key都可以寻址到对应的服务器&#xff0c;比如&#xff0c;查询key是key-01,计算公式为hash(key-01)%3,警告过计算寻址到了编号为1的服务器节点A&#xff0c;如图所示。 但如果服务器数量发生变化&#x…