动态网站开发课程设计——K.X的博客

写在前面

又是一个学期又是一个课程设计,上学期写了一个web前端课程设计——K.X的博客这学期老师给了一些SpringBoot的demo练习;明白了如何可以进行前后端分离开发。选择这个课程设计也是给自己上学期的前端课程设计写一个后端。

开发环境

  • idea
  • Visual Studio Code
  • mysql 8.0
  • jdk 10
    服务器用的是SpringBoot内置的服务器

说明

本课程设计的前端目前还是直接引用的,后续会转换成node.js环境下的前端项目

技术栈

  • Spring Boot
  • Mybatis
  • Spring Security
  • Vue
  • Bootstrap

功能模块图

在这里插入图片描述

效果展示

博主模块:
在这里插入图片描述在这里插入图片描述在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
访客模块
大部分页面效果和博主类似少了一些管理功能,添加了注册和评论发布功能。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
PS:固定的底部栏的向上箭头图片添加了页面回滚至顶的效果,我怕它太小大家看不到;哈哈哈哈哈

项目源码:

项目源码以及sql文件已托管至gitHub需要自取,可能是因为网络的原因,托管至github的图片显示错误;但clone或下载下来的图片显示是正常的。
由于经过了Spring Security安全框架的加密,数据库中看不到用户密码:在这里说一下,所有用户的密码都为:123456

K.X的博客开发过程种遇到问题及解决方法

问题一、

前端页面加载正常,但浏览器F12查看会有一个404错误

undefined:1 GET http://localhost:8080/blog/undefined 404

在这里插入图片描述

但是我的前端页面根本没有这个请求,查了这个问题也有一些其他的人遇到了这个问题;好像是和vue-router的使用有关,也没有找到具体的解决办法。

解决方法:

未解决。

问题二、

数据查询问题

由于想要实现在博客详情页面显示博客内容,以及所有评论和对应评论的用户和头像,就需要涉及到article(文章表)、comment(评论表)和user(表)连接查询问题。刚开始只是简单的写了三个表的连接查询,查出对应的字段。对于含有评论的文章这样查询是没有问题的,但当一个文章还没有评论时,comment(评论表)中无该文章相关数据,直接三个表连接查询查到为空

初始sql语句

select a.*,c.id c_id,c.content c_content,c.created c_created,u.nickname u_nickname,u.photo u_photo
     from article a,comment c,user u
     where a.id=c.articleid and c.userid=u.id and a.id=8 order by c_id desc;

解决方法:

查看了老师的博客例子发现老师使用的是左连接,两个进行左连接左连接会读取左边数据表的全部数据,即使右边数据表没有对应数据。(如果两个表中数据有相同部分,只显示一个) 没有写过sql的左连接,查了网上的都是两个表的左连接,自己试着照葫芦画瓢写三个表的左连接,要么语法错误要么找不到字段;后来想到了嵌套查询,先给user(用户表)和comment(评论表)连接查询,再与article(文章表)进行左连接查询,成功查到,解决当文章没有评论的不会报为空的查询。

sql语句

select a.*,c_id,c_content,c_created,u_nickname,u_photo 
from article a left join 
(select c.id c_id,c.articleid c_articleid,c.content c_content,c.created c_created,u.nickname u_nickname,u.photo u_photo from user u,comment c where c.userid=u.id) as b 
on a.id=c_articleid where a.id=1 order by c_id desc;

PS:我这种方法肯定影响效率,一定有更好的语句解决;有知道的大佬欢迎来留言,为小弟指点迷津。

由于每个文章有多个评论,而每个评论又对应一个用户,也就出现了一对多中含有多对一

ArticleMapper.xml中关于查询文章详情语句:

<!--根据id查询文章详情,包括所有评论-->
<select id="selectArticleByID" resultMap="articleWithComment">
    select a.*,c_id,c_content,c_created,u_nickname,u_photo
    from article a left join
    (select c.id c_id,c.articleid c_articleid,c.content c_content,c.created c_created,u.nickname u_nickname,u.photo u_photo
    from user u,comment c
    where c.userid=u.id) as b
    on a.id=c_articleid where a.id=#{id} order by c_id desc;
</select>
<resultMap id="articleWithComment" type="Article">
    <id property="id" column="id"/>
    <result property="title" column="title"/>
    <result property="content" column="content"/>
    <result property="created" column="created"/>
    <result property="hits" column="hits"/>
    <result property="zan" column="zan"/>
    <result property="comments" column="comments"/>
    <collection property="commentList" ofType="Comment">
        <id property="id" column="c_id"/>
        <result property="content" column="c_content"/>
        <result property="created" column="c_created"/>
        <association property="user" javaType="User">
            <result property="nickname" column="u_nickname"/>
            <result property="photo" column="u_photo"/>
        </association>
    </collection>
</resultMap>

评论管理时遇到类似问题,同样思路解决;不说是先进行的嵌套查询,再连接查询的;因为有些没有评论的博客就不需要再显示了。

问题三、

由于使用了Spring Security安全框架,User类实现了接口UserDetails;当通过Controller获取User时 新增了一些属性。

在这里插入图片描述

当更改用户信息时,报错无法构造实例

Cannot construct instance of `org.springframework.security.core.GrantedAuthority` (no Creators, like default construct, exist): abstract types either need to be mapped to concrete types, have custom deserializer, or contain additional type information
 at [Source: (PushbackInputStream); line: 1, column: 487] (through reference chain: com.kx.pojo.User["authorities"]->java.util.ArrayList[1])

解决方法:

查了一圈博客发现问题是由于Jackson反序列化时,authorities字段无法进行序列化;可通过@JsonIgnore注解在序列化或反序列化时忽略某属性;Jackson提供了@JsonIgnore这个注解,用于在(反)序列化时,忽略bean的某项属性;

参考博客:https://www.iteye.com/blog/wwwcomy-2397340

问题四、

由于获取登录用户的信息,是通过Spring Security中的SecurityContextHolder获取,在更改用户信息后但是session中缓存的用户信息未更新,所以当再次获取登录用户的信息依旧是上次登录session缓存中的信息。

获取登录用户信息代码:

@GetMapping("/getuser")
public User getuser(){
    return (User) SecurityContextHolder.getContext().getAuthentication().getPrincipal();
}

解决方法:

感谢江南一点雨大佬分享,无意间找到了大佬博客,有很多框架教学博客。具体解决文章:
https://mp.weixin.qq.com/s/jQZx4i4-vqjpBjpoJKJF4A

更新用户信息代码:

@PutMapping("/user")
public String updateUser(@RequestBody User user, Authentication authentication){
    userService.updateUser(user);
    SecurityContextHolder.getContext().setAuthentication(new UsernamePasswordAuthenticationToken(user,authentication.getCredentials(),authentication.getAuthorities()));
    return "success";
}

问题五、

加入Spring Security安全框架后,发现新加博客时插入本地图片显示错误。

在这里插入图片描述

解决方法:

查看login_page页面,提示未登录,估计vue-heml5-editor富文本编辑器的原因,为了使用方便在选择导入图片时,不用对用户进行认证。

查看file请求错误状态码为302;

在这里插入图片描述

并且请求的URL为:

http://localhost:8080/blog/file。

在后端设置/file服务任何用户都可以访问,可以不用登录。
在这里插入图片描述
选择本地图片显示成功。
在这里插入图片描述
后来在注册用户时也遇到了类似的问题,请求静态资源图片默认头像时显示错误类似方法解决,开启可不登录访问
在这里插入图片描述
欢迎大家运行测试,有问题随时滴滴我

  • 12
    点赞
  • 38
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
本书展示一个完整网站的设计和实现过程,详细地介绍动态网页设计和制作的技术和相关理论,全书共分为8章,主要内容包括:动态网站设计概述、动态网站编程环境、网站主页设计与PHP基础、网站计数器设计与PHP文件访问、会员注册和管理设计与数据获取、网上社区设计与PHP数据库访问、网上购书与PHP面向对象技术、网站优化与PHP的高级功能等,本书内容系统全面,案例典型实用,讲述直观详尽,非常适合动态网页设计与制作的初学者使用,还可作为高等院校教材和“实用型”人才培训教材。 目录 第1章 动态网站设计概述 1.1 动态网站的特点 1.2 动态网站的运行机制 1.2.1 域名 1.2.2 网页 1.2.3 浏览器 1.2.4 服务器 1.3 动态网站的规划 1.3.1 确定网站的类型 1.3.2 确定网站的主题 1.3.3 确定网站的整体风格 1.3.4 确定网站的内容 1.3.5 规划界面 1.3.6 规划站点的目录结构和链接结构 1.3.7 编写网站策划书 1.4 动态网站开发前的准备 1.4.1 申请域名 1.4.2 接入Internet 1.4.3 选择软硬件平台 1.4.4 选择网站建设服务商 第2章 动态网站编程环境 2.1 动态网页编程环境的构成要素 2.1.1 操作系统 2.1.2 服务器端程序 2.1.3 程序语言 2.1.4 数据库 2.1.5 基于PHP常见动态网站开发环境 2.2 安装和配置Apache 2.2.1 安装Apache前的准备 2.2.2 安装Apache 2.2 13测试Apache 2.2.4 配置Apache 2.2.5 在Windows上管理Apache 2.3 安装和配置PHP 2.3.1 安装PHP前的准备 2.3.2 安装PHP 2.3.3 配置PHP 2.3.4 测试PHP 2.4 安装和配置MySQL 2.4.1 安装MySQL,前的准备 2.4.2 安装MySQL 2.4.3 配置MySQL 2.4.4 在Windows上手动启动和停止MySQL 2.4.5 安装phpMyAdmin 2.5 AppServ组件安装 2.5.1 安装AppSery前的准备 2.5.2 安装。AppSery 2.5.3 测试AppSery 2.5.4 配置Apache 2.5.5 修改MySQL服务器的密码 2.6 PHP的集成开发环境 2.6.1 Dream weaver开发工具 2.6.2 Eclipse开发工具 2.6.3 其他开发工具 第3章 网站主页设计与PHP基础 3.1 网站主页的设计 3.1.1 主页的页面元素, 3.1.2 规划主页的结构 3.1.3 布局页面版式 3.1.4 用Fireworks创建网页模型 3.2 网站主页的实现 3.2.1 在Dream weaver创建网站 3.2.2 布局页面元素的样式 3.2.3 实现主页的结构 3.2.4 编辑主页的栏目内容 3.3 网站主页的链接策略 3.4 PHP语言基础 3.4.1 PHP的程序结构 3.4.2 PHP的句法结构 3.4.3 PHP的数据类型 3.4.4 PHP的控制语句 第4章 网站计数器设计与PHP文件访问 4.1 网站计数器的设计 4.1.1 系统架构 4.1.2 系统设计 4.2 网站计数器的实现 4.2.1 文本输出的网页计数器 4.2.2 图片输出的网页计数器 4.2.3 调试代码 4.3 PHP的函数 4.3.1 PHP函数概述 4.3.2 白定义函数 4.3.3 PHP内置函数 4.4 PHP访问文件 4.4.1 PHP支持的文件系统 4.4..2 PHP访问文件的方法 4.4.3.PHP访问目录 4.5 文件管理器 第5章 会员注册和管理设计与数据获取 5.1 会员注册和管理概述 5.2 会员注册和管理设计 5.2.1 系统架构 5.2.2 系统设计 5.3 注册模块的实现 5.3.1 页面样式表 5.3.2 网页的头部、尾部和数据库连接文件 5.3.3 注册的主页和处理程序 5.3.4 用户申请购书卡页和处理程序 5.3.5 注册用户资料页与处理程序 5.3.6 调试代码 5.4 会员管理模块的实现 5.4.1 页面样式表 5.4.2 网页的头部、尾部和连接数据库 5.4.3 会员管理的主页 5.4.4 用户分级登录页和处理程序 5.4.5 用户购书卡专区页和处理程序 5.4.6 会员修改资料页与处理程序 5.4.7 会员找回密码页与处理程序 5.4..8 购书卡管理页与处理程序 5.4.9 调试代码 5.5 表单数据处理 5.5.1 PHP与表单 5.5.2 表单数据的采集 5.5.3 表单数据处理描述 5.6 cookie与会话管理 5.6.1 数据传递概述 5.6.2 cookie 5.6.3 会话管理 第6章 网上社区设计与PHP数据库访问 6.1 网上社区概述 6.2 留言板的设计 6.2.1 留言板的架构 6.2.2 留言板的设计描述 6.3 留言板的实现 6.3.1 网页的头部、尾部和系统配置文件 6.3.2 留言板的主页——欢迎页 6.3.3 写留言页和回复留言 6.3.4 浏览留言主题页 6.3.5 浏览主题留言页 6.3.6 管理员登录页 6.3.7 屏蔽和删除留言页 6.3.8 调试代码 6.4 聊天室的设计 6.4.1 聊天室的架构 6.4.2 聊天室的设计描述 6.5 聊天室的实现 6.5.1 网页的头部、尾部和系统配置文件 6.5.2 聊天室的主页——登录页 6.5.3 聊天室页 6.5.4 浏览聊天信息页 6.5.5 离开页 6.5.6 注销页 6.5.7 调试代码 6.6 PHP访问数据库 6.6.1 PHP访问数据库的机制 6.6.2 连接数据库服务器 6.6.3 PHP数据库管理函数 6.6.4 PHP查询数据函数 6.6.5 其他数据管理工具 第7章 网上购书与PHP面向对象技术 7.1 网上购书系统分析 7.1.1 系统工作流程分析 7.1.2 系统功能模块分析 7.2 网上购书系统设计 7.2.1 模块的逻辑结构设计 7.2.2 数据库设计 7.2.3 数据操作类设计 7.2.4 界面设计 7.3 网上购书系统实现 7.3.1 数据操作类 7.3.2 图书查询 ’7.3.3 图书显示处理 7.3.4 购物车 7.3.5 订单处理 7.3.6 调试代码 7.4 PHP面向对象技术 7.4.1 基本概念 7.4.2 定义类 7.4.3 创建对象 7.4.4 使用对象的属性和方法 7.4..5 对象的操作 第8章 网站优化与PHP的高级功能 8.1 用户注册安全管理 8.1.1 用户注册安全管理的策略 8.1.2 优化用户注册页面 8.1.3 PHP的GD函数库 8.1.4 图片缩略图 8.2 图像文件上传处理 8.2.1 网站图像存储策略 8.2.2 上传图书封面图像 8.2.3 PHP文件上传处理 8.3 电子邮件处理 8.3.1 PHP电子邮件处理概述 8.3.2 向客户发送邮件 8.3.3 PHP发送电子邮件的方式 8.4 正则表达式 8.4.1 正则表达式简介 8.4.2 常用表单项验证 8.4.3 正则表达式的法则 参考文献

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值