牛腩新闻发布系统之系统分析、后台设计

2024-08-26 01:48

本文主要是介绍牛腩新闻发布系统之系统分析、后台设计,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

牛腩新闻发布系统前17讲主要是针对系统分析及后台的设计和编码。主要包括以下几部分的工作:
1.系统设计说明书编写
首先应该明确自己要做的是什么,明确分析用户的需求,接下来就是要计划自己怎么去做这件事,最后还要考虑一下,如何才能更好的去完成这件事。文档编写主要包括以下几个方面:
(1)系统介绍(明确自己要做的是什么)
(2)系统功能图、数据库设计图
(3)数据库文档编写
这个主要是针对数据库的介绍,其中包含那几张表、表中包含哪些字段、字段的属性及说明等。
2.界面原型图设计(前台)
3.数据表操作代码编写
(1)用SQL语句建立数据库、表、字段
以前只是听说过可以在数据库里面写SQL语句进行建立数据库等的操作,看了牛腩老师的视频自己也学会了,真的很方便的,而且操作也非常的简单,以后就用这个办法建表啦。
(2)编写SQLHelper类
机房重构的时候就用到了SQLHelper类,真个重构下来这个数据库小助手确实给我们省了不少事哈。无非还是那些功能:数据库的连接与关闭、有参数的增删改和无参数的增删改方法、带参查询和不带参查询。将公用的东西放到一起,封装成一个类到时候用到哪个就直接调用一下就好啦。重构的时候虽然说是用到了这个类,但是是站在巨人的肩膀上,可以说更多是引用。看了牛腩视频之后,老师对SQLHelper类的编写是不断优化的,从繁琐到精简,我也是一步步的跟着操作,真正体会到了代码优化的过程。
(3)编写数据表操作类
牛腩新闻发布系统一共涉及到了三张表:新闻表、类别表、评论表。关系如下:


首先先把三者的关系理清了,明确各自需要实现的功能,接下来再说代码的事。举个最简单的例子:评论类DAL层代码设计
CommentDAO类包含的方法:
(1)根据新闻ID取出该新闻所有评论
(2)插入评论
(3)删除评论
这样将需要实现的方法先明确了,接下来是对数据库的一些操作了:查询、增加、删除。这个就是要调用SQLHelper类的相关增删改查的方法了。和七层的重构没有什么区别。

为了给DAL层减负,还用到了多个存储过程。既方便有减少了出错率。

期间如果我们想删除某一个新闻类别,因为设置了外键关联。其下面关联的还有相应的评论,关系到评论表,所以总是会提示出现错误,无法删除新闻类别。这个时候我们需要用到触发器。先看一段代码:

看了这个之后相信大家都明白触发器是做什么的了吧,哈哈,没错它可以实现级联删除功能:先删除某ID下的评论,再删除该ID的新闻,最后删除该类别、这样的话就大功告成了。

还需要注意的是使用该软件的人可能是丝毫没有软件编程基础的人,这样的话,还需要防止SQL的注入,如果使用者一不小心乱输了一串字符恰好执行了数据的某些操作,歪打正着,无意间破坏了软件。作为程序员,我们一定要对自己设计的软件考虑周全。之前只是听说过,也见到过别人对这放慢的总结,自己之前在设计软件的时候可能并没有进行破坏性试验,所以知道现在才真正认识它。举个例子:比方说,你想要搜索新闻,然后你不小心在输入框中输入了:
娱乐新闻c')delete category where id=4--
你在实现搜索新闻功能的时候,需要实现的是通过文本框中用户输入的信息,然后对应到数据库中,一旦写的不严谨,就有可能把文本框的这句话当成一个SQL语句执行了。


所以我们需要对自己的这段代码进行优化,避免SQL注入:不使用拼接的形式,用更为严谨的方式:使用带参数的SQL语句(在SQLHelper类中编写带参数的增删改方法)


4.编写BLL层代码
根据DAL层的方法编写BLL层代码,从而实现用户需求。很简单,就不多说了。

关于代码规范:
1、类头的注释
2、类中方法的注释

总结,至此为止算是基本上完成了牛腩新闻发布系统的系统分析、后台实现,接下来就该进行前台界面等的设计了。

这篇关于牛腩新闻发布系统之系统分析、后台设计的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1107203

相关文章

定价129元!支持双频 Wi-Fi 5的华为AX1路由器发布

《定价129元!支持双频Wi-Fi5的华为AX1路由器发布》华为上周推出了其最新的入门级Wi-Fi5路由器——华为路由AX1,建议零售价129元,这款路由器配置如何?详细请看下文介... 华为 Wi-Fi 5 路由 AX1 已正式开售,新品支持双频 1200 兆、配有四个千兆网口、提供可视化智能诊断功能,建

在不同系统间迁移Python程序的方法与教程

《在不同系统间迁移Python程序的方法与教程》本文介绍了几种将Windows上编写的Python程序迁移到Linux服务器上的方法,包括使用虚拟环境和依赖冻结、容器化技术(如Docker)、使用An... 目录使用虚拟环境和依赖冻结1. 创建虚拟环境2. 冻结依赖使用容器化技术(如 docker)1. 创

CentOS系统Maven安装教程分享

《CentOS系统Maven安装教程分享》本文介绍了如何在CentOS系统中安装Maven,并提供了一个简单的实际应用案例,安装Maven需要先安装Java和设置环境变量,Maven可以自动管理项目的... 目录准备工作下载并安装Maven常见问题及解决方法实际应用案例总结Maven是一个流行的项目管理工具

C#实现系统信息监控与获取功能

《C#实现系统信息监控与获取功能》在C#开发的众多应用场景中,获取系统信息以及监控用户操作有着广泛的用途,比如在系统性能优化工具中,需要实时读取CPU、GPU资源信息,本文将详细介绍如何使用C#来实现... 目录前言一、C# 监控键盘1. 原理与实现思路2. 代码实现二、读取 CPU、GPU 资源信息1.

在C#中获取端口号与系统信息的高效实践

《在C#中获取端口号与系统信息的高效实践》在现代软件开发中,尤其是系统管理、运维、监控和性能优化等场景中,了解计算机硬件和网络的状态至关重要,C#作为一种广泛应用的编程语言,提供了丰富的API来帮助开... 目录引言1. 获取端口号信息1.1 获取活动的 TCP 和 UDP 连接说明:应用场景:2. 获取硬

JAVA系统中Spring Boot应用程序的配置文件application.yml使用详解

《JAVA系统中SpringBoot应用程序的配置文件application.yml使用详解》:本文主要介绍JAVA系统中SpringBoot应用程序的配置文件application.yml的... 目录文件路径文件内容解释1. Server 配置2. Spring 配置3. Logging 配置4. Ma

2.1/5.1和7.1声道系统有什么区别? 音频声道的专业知识科普

《2.1/5.1和7.1声道系统有什么区别?音频声道的专业知识科普》当设置环绕声系统时,会遇到2.1、5.1、7.1、7.1.2、9.1等数字,当一遍又一遍地看到它们时,可能想知道它们是什... 想要把智能电视自带的音响升级成专业级的家庭影院系统吗?那么你将面临一个重要的选择——使用 2.1、5.1 还是

高效管理你的Linux系统: Debian操作系统常用命令指南

《高效管理你的Linux系统:Debian操作系统常用命令指南》在Debian操作系统中,了解和掌握常用命令对于提高工作效率和系统管理至关重要,本文将详细介绍Debian的常用命令,帮助读者更好地使... Debian是一个流行的linux发行版,它以其稳定性、强大的软件包管理和丰富的社区资源而闻名。在使用

Ubuntu系统怎么安装Warp? 新一代AI 终端神器安装使用方法

《Ubuntu系统怎么安装Warp?新一代AI终端神器安装使用方法》Warp是一款使用Rust开发的现代化AI终端工具,该怎么再Ubuntu系统中安装使用呢?下面我们就来看看详细教程... Warp Terminal 是一款使用 Rust 开发的现代化「AI 终端」工具。最初它只支持 MACOS,但在 20

windows系统下shutdown重启关机命令超详细教程

《windows系统下shutdown重启关机命令超详细教程》shutdown命令是一个强大的工具,允许你通过命令行快速完成关机、重启或注销操作,本文将为你详细解析shutdown命令的使用方法,并提... 目录一、shutdown 命令简介二、shutdown 命令的基本用法三、远程关机与重启四、实际应用