HTML+CSS+JS+Servlet+MSQL搭建个人博客

article/2025/9/14 4:50:54

 

 

3.应用技术:HTML+CSS+JS+JSP+Servlet+MSQL 前端+后台管理。

4.开发环境:eclipse+jdk1.8+tomcat8.5+ mysql5.7+前端Layui

二、前端

1.博客首页

博主和用户可以访问到博客系统的首页,首页内容主要包括导航条,文章推荐和登录注册管理模块。在首页中还引入了动态时间显示,天气插件和日历插件。

图1-2

文章阅读:点击新文章下面的箭头,弹出浮动窗口,可放大缩小或关闭。

2.微语模块

博主与用户可在此模块发表日记,支持上传图片、视频,用户还可以在日记底下点赞加评论。

 

3.留言模块

用户可在此模块给博主留言、查看留言。留言按时间先后倒序排列,系统自动标记留言发布日期,如图3-1至3-3所示。

 

 

 

大量的博文以及文章,不能在一个页面中展现给用户 进行浏览,本博客系统使用数据库分页技术,实现了文章和日记的分页功能。

4.关于模块

博主可以在后台中设置自己的个人信息,用户可以在该页面看到关于博主的信息,主要是博主的个人介绍,最后还附加了博主的联系方式。

 

5.登录与注册模块

用户可进行登录或注册,详细说明图下附说明。

 

说明:

1,登录用户分为3种,1 管理员,2 普通用户,3 冻结用户(管理员在管理界面设置用户权限,冻结用户不能评论)。

管理员可进入管理界面,对整个博客进行管理(后面详细说明)

普通用户可以浏览,点赞,评论,留言。

用户权限通过数据库gg_user表中的 user_rights设置,通过过滤器filter进行拦截。

2,验证码通过后台动态生成,不区分大小写,验证码,用户名,密码同时正确,才能完成登录。点击验证码,可以动态切换验证码。

 

说明:

注册采用邮箱验证激活的方式,主要实现是 验证gg_user表中的user_rights。当递交注册表单的时,服务器会发送一封邮件到用户填写的指定邮箱,当用户点击激活链接的时候user_rights的值设置为1 才能完成注册,否则注册的用户无效。

6.后台管理模块

管理员使用管理员账号登录后可发表文章,管理日记、评论、留言,修改用户权限等

 

说明:微语管理分写微语,微语管理,评论管理。
写微语,图片和文章内容在同一个form表单同时提交,在后台先做识别处理,识别出的图片存到服务器,图片地址存到数据库,识别出文字,直接存到数据库。支持一张图片上传。点击上传,上传。

 

 

 主要是博主对留言板的设置,例如删除留言,设置黑名单,设置审核功能等。对于有不良记录的访客,可以进行设置权限,或者拒绝该用户访问。

 

说明:

1.页面内容 是查询数据库内容然后循环输出的

2.点击展开 查询数据库此条微语的评论并且循环显示,评论后点击确定,提交评论并写入数据库。

3.有统计 此条微语 总被评论数和点赞数。

4.没有登陆的用户无法评论,被冻结用户无法评论(主要是检测session中的user_name和user_right)

5.微语的图片是可以在后台上传的,图片存在服务器,地址存在数据库。

功能描述:

        该模块作为整个博客系统的后台管理中心,将该博客的所有功能集成展现在此,只有博主通过账号和密码才能访问到此页面,可以实现该博客系统的所有功能,并进行相应的操作

详细说明:

AboutDao.java :对用户信息的操作(有三个内置方法)

1,public GgUser getUserInfo(String userName)  //用于关于界面的用户数据查询显示

2,public GgUser updateUserInfo(GgUser user)  //管理员界面修改用户数据

3,public ArrayList<GgUser> getUsers()  //管理员界面显示全部用户信息

ActiveDao  :管理用户权限

1,public boolean addUser(GgUser user)  //邮箱激活时 修改user_rights==2

2,public boolean forbiden(int userid)  //管理员界面 冻结用户时调用

LeacotDao  :留言管理

1,public boolean addLeacot(Ggcom com)  //添加留言

2,public boolean delete(int id)  //管理员删除留言

LeaShowDao  :数据库查询留言

public ArrayList<Ggcom> getcomInfo()

LoginDao  :登录检测

public int check(String userName,String userPassword)

WisComShowDao  :微语评论  查询展示

public ArrayList<GgNoteCom> getcomInfo(int noteId)

WisDelDao  :管理员界面  微语删除   微语评论删除

public boolean delCom(int id)

public boolean del(int id)

wisShowDao  :微语查询展示

public ArrayList<GgNote> getcomInfo()

WisUploadDao:添加微语,添加微语评论

public boolean addwis(GgNote note)

public boolean addcom(GgNoteCom com)

 

AboutUpServlet  :管理员界面 更新用户信息

ActiveServlet  :处理邮箱点击的激活码get请求,激活用户

LeacotsServlet  :留言post

LeaDelServlet  :管理员界面 删除留言

LoginFilter  :用户权限管理

LoginServlet  :登录

PicUpServlet  :管理员界面 上传微语,接受post表单包含文字和图片

RegServlet  :注册时接受post表单并发送邮件

UserForbidenServlet  :管理员界面 冻结用户

ValidationCodeServlet  :登录验证码生成

WhiComServlet  :微语评论

WhiDelComServlet  :管理员界面 删除微语评论

WhiDelServlet  :管理员界面 删除微语

Auth  :发送邮件的工具

DbUtil  :与数据库建立连接的代码,在Dao层调用

SendMail  :发送邮件的工具

Upload  :在微语上传时使用,微语上传时是图片和文字一起上传,不能直接使用getParameter方法,所以 先调用此方法  分离出图片和文字递交 Dao层处理

images :保存微语中上传的图片。

Page  :管理员界面的  jsp页面。

Layer,res :引用的前端框架。

2.数据库说明

新建数据库:ggdb,并为其创建如下4个表

gg_user:用户信息管理表

gg_note:微语管理表

gg_note_com:微语评论管理表

gg_comment:留言管理表

 

1.系统亮点与不足
   该系统整体采用HTML+CSS+JS+Jsp+Servlet+JavaBean+Filter模式分层开发,在这种模式下,servlet负责处理用户请求并进行相应的逻辑操作,jsp负责数据的显示,javabean负责封装数据,filter负责过滤数据,数据库采用mysql数据库。方便了以后的修改与功能的扩充。
   技术上系统使用了Html5搭建前台页面,使用CSS3进行样式的美化,用了JavaScript和jQuery等技术加入了特效和前台的交互功能,给系统增加了更多的便捷性。
   由于个人能力的不足,jQuery只是会一些简单的,而非精通,以至于在后台开发模块遇到很大的障碍。系统开发中后期,由于想实现功能的模块化开发,结果需要使用Ajax技术,自己了解学习后,并没有成功解决掉该问题。系统数据库的设计未进行优化,至于能否在大数据的用户访问博客时出现问题未知。
   关于安全性,是该系统的关键所在,如何能在网络的冲击下,保护博主和用户的信息以及博客数据信息的安全,在将来的的再次设计中,需要注意。

2.未来功能设想
   博客系统虽然已不陌生,但是千篇一律的博客不能给用户带来新鲜感,后期的相册功能,是否可以用java爬虫技术,爬取网易云最热门的歌曲,采用音乐与图片的结合实现音乐相册。

需要源码评论区留邮箱,感谢点赞收藏


http://chatgpt.dhexx.cn/article/ZNA8s2h3.shtml

相关文章

用 Dev-C++ 编写简单的走迷宫小游戏

用 Dev-C 编写简单的走迷宫小游戏 前言基础版优化版 前言 以下是显示效果 B站视频讲解&#xff1a;【小游戏】用 Dev-C 编写简单的控制台走迷宫小游戏 【小游戏】用 Dev-C 编写简单的控制台走迷宫小游戏 基础版 用 # 代表墙 用 空格 代表空地 用 O 代表玩家 地图存储&#…

简单的迷宫问题(DFS/BFS分别求解)

简单的迷宫问题 题目描述输入样例输出样例 dfs解题思路(深搜)路线规划DFS特点C源码(DFS) bfs解题思路(广搜)路线规划测试代码段BFS特点C源码&#xff08;BFS&#xff09; 题目描述 现在需要你来规划一条路线&#xff0c;从起点到终点的最短路线。 给你一个nm的地图&#xff08;…

基于JAVA的简单迷宫游戏

一、实验要求 1. 迷宫游戏是非常经典的游戏&#xff0c;在该题中要求随机生成一个迷宫&#xff0c;并求解迷宫。 2. 要求游戏支持玩家走迷宫&#xff0c;和系统走迷宫路径两种模式。玩家走迷宫&#xff0c;通过键盘方向键控制&#xff0c;并在行走路径上留下痕迹&#xff1b;系…

C++实现简单的走迷宫

c实现简单走迷宫 用n*n个小方格代表迷宫&#xff0c;每个方格上有一个字符0或1&#xff0c;0代表这个格子不能走&#xff0c;1代表这个格子可以走。只能一个格子一个走&#xff0c;而且只能从一个格子向它的上、下、左、右四个方向走&#xff0c;且不能重复。迷宫的入口和出口分…

迷宫问题(简单模拟)

目录导航 图解体会领悟&#xff1a;代码实现&#xff08;Java&#xff09;&#xff1a;C语言版C版 为了复习递归&#xff0c;而模拟学习的。所以迷宫不大&#xff0c;总体是8行7列。 图解 A为起点&#xff0c;B为终点。 如下图在A和B之间设置挡板被隔绝之后&#xff0c;结果如…

超级简单的迷宫代码 初学者程序

迷宫 走迷宫一种比较有趣&#xff0c;操作简单的小游戏。 #include<stdio.h> #include<getch.h> #include<stdlib.h> #include<time.h> int main(int argc,const char*argv[]) {//构造迷宫地图char maze[10][10]{{#,#,#,#,#,#,#,#,#,#},{#,,#,#,#,#…

最简单的迷宫求解

在计算机中&#xff0c;我们可以把迷宫当做一个二维数组。其中0表示通路&#xff0c;1表示墙。 我们以下图为例&#xff0c;对于只有一条通路的简单迷宫进行求解 该迷宫存储在“Map.txt”文档中。 对于该迷宫&#xff0c;我们首先将入口点压入栈中&#xff0c;然后通过对该点…

JAVA 中实现的简单的迷宫小游戏

多的不说&#xff0c;直接上代码&#xff0c;就是一个简单的迷宫小游戏。 import java.awt.Color; import java.awt.Graphics; import java.awt.event.KeyAdapter; import java.awt.event.KeyEvent; import java.util.Random; import java.util.Stack; import javax.swing.JFr…

Python实现迷宫游戏

项目&#xff1a;迷宫游戏 摘要1.引言1.1研究的背景及意义1.2研究的内容 2.系统结构2.1系统的结构2.2基本思路 3.实现代码3.1Maze类3.2Player类3.3Controller类3.4主函数 4.实验5.总结和展望参考文献 摘要 本次实验设计了一款迷宫小游戏&#xff0c;采用用Python开发技术实现。…

C语言实现简单迷宫

C语言实现迷宫程序 前言 大家小时候一定都玩过迷宫这个游戏&#xff0c;很吸引人吧&#xff0c;有那种走不出来就不罢休的执着&#xff0c;然后走出来了觉得自己很强&#xff0c;自己可以了&#xff0c;接着激动的开始下一个关卡&#xff0c;慢慢的沉溺在迷宫的世界里了。 然…

如何使用C语言实现简单迷宫(递归和非递归实现 含图例)

1.非递归实现 简单迷宫&#xff1a;只有一条通路的迷宫 思路&#xff1a;在找迷宫通路的时候&#xff0c;我们往往是在给定入口(入口合法且为通路)的情况下&#xff0c;沿着入口的某个方向走&#xff08;此方向是通路&#xff09;。现给定走迷宫的方向&#xff1a;上、左、右…

简单迷宫(递归)

代码思路 1.创建二位数组作为迷宫 2.数字1为墙壁&#xff0c;2为经过的位置&#xff0c;3为死路&#xff0c;0为未探寻的位置 3,定义一个起点和终点&#xff0c;运用递归的方法&#xff0c;按照自己设计的寻找方向的优先级运行&#xff0c;直到让终点值为2则返回true&#x…

简单迷宫问题

简单迷宫问题 一、问题描述二、数据组织三、算法说明附录&#xff1a;完整代码 #简单迷宫问题 一、问题描述 给定一个MN得迷宫&#xff0c;求一条从指定入口到出口得迷宫路径。假设一个迷宫如图1所示&#xff0c;&#xff08;这里MN8)&#xff0c;其中每个方块用空白表示通道…

maven生命周期lifecycle和plugins介绍

一、Maven的生命周期 生命周期的定义&#xff1a;Maven的生命周期就是为了对所有的构建过程进行抽象和统一。在大量项目的构建过程中&#xff0c;Maven总结出了一套高度完善的&#xff0c;易于扩展的生命周期&#xff0c;包括项目的清理&#xff0c;初始化&#xff0c;编译&am…

【Maven】IDEA中Maven生命周期

Maven生命周期&#xff08;lifecycle&#xff09;由各个阶段组成&#xff0c;每个阶段由Maven的插件plugin来执行完成。 生命周期&#xff08;lifecycle&#xff09;主要包括clean、resources、complie、install、pacakge、testResources、testCompile、deploy等&#xff0c;其…

Maven生命周期与插件

竟无语凝噎 文章目录 前言一、生命周期二、插件总结 前言 maven原来有这么多道道 一、生命周期 Maven对项目构建的生命周期划分为三套 clean&#xff1a;清理工作 default&#xff1a;核心工作&#xff0c;例如编译&#xff0c;测试&#xff0c;打包&#xff0c;部署等 si…

Maven 生命周期详解

思考&#xff1a;我们常使用的maven命令&#xff0c;比如 mvn clean install&#xff0c;mvn clean package 这些命令到底最后是如何工作的&#xff1f; 在这里我们还是先一步步来&#xff0c;其实它们运行的是生命周期中对应的phase阶段。 Maven 拥有三套独立的生命周期&…

关于maven生命周期的理解

晚上有点无聊&#xff0c;看到了一些东西引发了自己的思路&#xff0c;就想将maven的一些东西总结总结&#xff0c;有从网上抄的&#xff0c;也有自己的思路。 一、生命周期是指什么&#xff08;lifecycle&#xff09; Maven的生命周期就是对所有的构建过程进行抽象和统一。包…

Maven的生命周期

一、生命周期简介&#xff1a; Maven强大的一个重要的原因是它有一个十分完善的生命周期模型&#xff0c;这个生命周期可以从两方面来理解&#xff1a; 运行Maven的每个步骤都由它来定义的&#xff0c;这种预定义的默认行为使得我们使用Maven变得简单。 这个模型是一种标准&am…