草庐IT

三更Blog项目总结(p1~p40)

塔塔开!!! 2023-04-10 原文

文章目录


视频地址:SpringBoot项目实战-前后端分离博客项目-Java项目_哔哩哔哩_bilibili

项目创建——多模块开发

整个系统分为前台模块(blog)和后台模块(admin),前端已给好,我们只需好些两套后端系统即可。

多模块开发:

我们并不是直接在Blog模块(父模块)下直接开发,还是根据需求分为了前台模块后台模块

但是两个模块很多代码和功能都是有重复的,就比如一些pom依赖,逻辑代码接口,统一的工具类,响应类等等,要是两个模块都这样写,那就造成了代码的大量重复冗余!

为此我们给父模块再创建一个模块,这个模块作为工作模块(framework公共子模块),让blogadmin模块享有它的资源,公共的代码、类、pom依赖等放在framework模块下,blogadmin模块到时自己特定的功能代码或者依赖等等,在自己放在自己的模块下即可,这样很多公共的代码就可以复用了!,那么我们主项目Blog下的src目录就可以删除去了。

一个父模块三个子模块,通过maven的多模块管理建立关系,子模块共享(继承)父模块的pom(公共pom)依赖,子模块开发特定功能在特定添加pom依赖即可

主模块pom依赖:

    <groupId>com.lwt</groupId>
    <artifactId>lwtBlog</artifactId>
    <packaging>pom</packaging>
    <version>0.0.1-SNAPSHOT</version>
    <!--    管理子模块-->
    <modules>
        <module>lwt-framework</module>
        <module>lwt-admin</module>
        <module>lwt-blog</module>
    </modules>

其他三个子模块继承父模块:

    <parent>
        <artifactId>lwtBlog</artifactId>
        <groupId>com.lwt</groupId>
        <version>0.0.1-SNAPSHOT</version>
    </parent>

功能业务逻辑总结

热门文章列表

进入首页后,热门文章一栏展示热门文章:

要求:

  • 文章必须是正常状态的,不能为草稿
  • 不能是已经删除的文章
  • 展示浏览量前10的文章
  • 用户点击后可以跳转到相应的文章进行浏览

功能逻辑总结(service层):

  • 调用mapper层查询数据库,条件如下:

    • 文章正常状态
    • 文章未删除
    • 我们要浏览量前10——根据浏览量进行降序排序
  • 自此我们就得到了满足条件的所有文章,但我们只要前十条——分页查询拿到前十条数据

  • 封装成VO对象响应给前端(Bean拷贝、用于操作集合的stream流等)

分类列表

需求:

用户查看分类信息时,展示存在的分类

注意分类的名称有文章信息确定,必须先通过文章表拿到对应的分类id才能通过这些id去分表表查询获取对应的分类名称!

功能逻辑总结(service层):

  • 先去查询文章表,获取到所有文章的分类id

    • 分类id必须是正常状态文章对应的分类id
    • 拿到分类id集合后对其进行去重(stream流操作)
  • 然后拿着这些分类ids去查询分类表,拿到对应的分类集合

    • 要求必须是正常状态的分类信息(stream流filter操作)
  • 封装为VO对象响应给前端

分页文章查询

需求:在首页或者点击相关的分类后,展示文章(相当于后台管理系统的数据显示)

由于都是文章查询然后显示,因此我们可以统一写在一个功能接口下!

文章会有很多不可能完全展示,因此分页查询是必须的,又因为我们统一写的一个接口,当你点击分类名称后要展示该分类下的文章,为此函数参数可以带有个分类id,在分页查询时有则加入条件,无则不加即可。

要求:

  • 只能展示正式发布的文章
  • 置顶的文章优先展示

功能逻辑总结(service层):

  • 调用mapper查询数据库
    • 根据前端请求的参数,有分类id则加入条件
    • 文章为正常状态的文章
    • 对应isTop字段进行降序排序(优先展示置顶文章)
  • 分页查询,拿到文章信息集合
  • 由于展示要有该文章对应的分类名称,而这个文章集合中只有分类id
    • 在文章实体类加上分类名称字段,由于数据库表中没有该字段因此注解做标记
    • 对文字集合进行操作,通过分类id查询到对应的分类名称,将其注入文章对象的成员属性
  • 封装成VO对象响应给前端

文章详情

需求:

要求在文章列表点击阅读全文时能够跳转到文章详情页面,可以让用户阅读文章正文。

前端的请求会带有文章id过来,通过文章id查询数据库,拿到信息即可

功能逻辑总结(service层):

  • 调用mapper通过id查询文章表,拿到该文章
  • 文章详情也要展示分类名称,因此还要通过分类id去拿到分类名称
  • 封装成VO对象响应给前端

注意:

由于是get请求,且请求的URL中带有参数,因此在controller中,通过@PathVariable 是从一个url中拿到文章id给后台

 @GetMapping("/{id}")
    public ResponseResult getArticleDetail(@PathVariable("id") Long id){
    
    }

友链查询

需求:友链展示,在友链页面要查询出所有的审核通过的友链。

功能逻辑总结(service层):

  • 调用mapper去友链表查询友链
    • 必须为审核通过的
  • 封装成VO对象返回给前端

登录功能

SpringSecurity登录认证流程的实现!

登录流程:

功能逻辑总结(service层):

一、登录

1、自定义登录接口(LoginImpl)

  • 调用ProviderManager的方法进行认证
    • 将我们传入的(初始带有用户名和密码)的Authentication对象与security自行去UserDetailsService 的实现类由load..ByName方法通过用户名从数据库查询数据封装得到一个UserDetails对象(包含用户的信息和相关权限等),UserDetails对象通过PasswordEncoder(加密后比对)对比UserDetailsAuthentication中的密码是否正确,最终返回一个完整的Authentication对象
  • 自定义UserDetailsService
    • 在这个实现类中去查询数据库
  • 认证通过后,从完整的Authentication对象中拿到userId生成token
  • 将用户信息存入redis
  • 封装成VO对象响应给前端

二、校验

所有请求都先经过jwt认证过滤器!

定义Jwt认证过滤器链

​ 获取(请求头)token

​ 解析token获取userId

​ 从redis中获取用户信息

​ 存入上下文SecurityContextHolder(loginUser、权限集合等)

​ 修改SecurityConfig,将这个过滤器加到security过滤器链的最前面!

核心:

  • 自定义登录接口
  • 实现UserDetail接口,用于从数据库查询用户信息,返回UserDetail接口的实现类——LoginUser
  • 生成token
  • 存入redis

退出登录

既然你要退出登录,说明你现在是一个登录的状态,我们通过token获取相关信息即可,然后从redis中删除即可

由于函数并没有携带HttpRequest...除了从request对象获取token外,我们可以从上下文中获取(因为我们之前是先经过Jwt认证过滤器的了)

  • 从上下文获取token解析拿到userId
  • redis中删除对应信息
  • 响应前端

有关三更Blog项目总结(p1~p40)的更多相关文章

  1. ruby - 如何在 buildr 项目中使用 Ruby 代码? - 2

    如何在buildr项目中使用Ruby?我在很多不同的项目中使用过Ruby、JRuby、Java和Clojure。我目前正在使用我的标准Ruby开发一个模拟应用程序,我想尝试使用Clojure后端(我确实喜欢功能代码)以及JRubygui和测试套件。我还可以看到在未来的不同项目中使用Scala作为后端。我想我要为我的项目尝试一下buildr(http://buildr.apache.org/),但我注意到buildr似乎没有设置为在项目中使用JRuby代码本身!这看起来有点傻,因为该工具旨在统一通用的JVM语言并且是在ruby中构建的。除了将输出的jar包含在一个独特的、仅限ruby​​

  2. ruby-on-rails - 项目升级后 Pow 不会更改 ruby​​ 版本 - 2

    我在我的Rails项目中使用Pow和powifygem。现在我尝试升级我的ruby​​版本(从1.9.3到2.0.0,我使用RVM)当我切换ruby​​版本、安装所有gem依赖项时,我通过运行railss并访问localhost:3000确保该应用程序正常运行以前,我通过使用pow访问http://my_app.dev来浏览我的应用程序。升级后,由于错误Bundler::RubyVersionMismatch:YourRubyversionis1.9.3,butyourGemfilespecified2.0.0,此url不起作用我尝试过的:重新创建pow应用程序重启pow服务器更新战俘

  3. ruby-on-rails - 新 Rails 项目 : 'bundle install' can't install rails in gemfile - 2

    我已经像这样安装了一个新的Rails项目:$railsnewsite它执行并到达:bundleinstall但是当它似乎尝试安装依赖项时我得到了这个错误Gem::Ext::BuildError:ERROR:Failedtobuildgemnativeextension./System/Library/Frameworks/Ruby.framework/Versions/2.0/usr/bin/rubyextconf.rbcheckingforlibkern/OSAtomic.h...yescreatingMakefilemake"DESTDIR="cleanmake"DESTDIR="

  4. Ruby 从大范围中获取第 n 个项目 - 2

    假设我有这个范围:("aaaaa".."zzzzz")如何在不事先/每次生成整个项目的情况下从范围中获取第N个项目? 最佳答案 一种快速简便的方法:("aaaaa".."zzzzz").first(42).last#==>"aaabp"如果出于某种原因你不得不一遍又一遍地这样做,或者如果你需要避免为前N个元素构建中间数组,你可以这样写:moduleEnumerabledefskip(n)returnto_enum:skip,nunlessblock_given?each_with_indexdo|item,index|yieldit

  5. SPI接收数据异常问题总结 - 2

    SPI接收数据左移一位问题目录SPI接收数据左移一位问题一、问题描述二、问题分析三、探究原理四、经验总结最近在工作在学习调试SPI的过程中遇到一个问题——接收数据整体向左移了一位(1bit)。SPI数据收发是数据交换,因此接收数据时从第二个字节开始才是有效数据,也就是数据整体向右移一个字节(1byte)。请教前辈之后也没有得到解决,通过在网上查阅前人经验终于解决问题,所以写一个避坑经验总结。实际背景:MCU与一款芯片使用spi通信,MCU作为主机,芯片作为从机。这款芯片采用的是它规定的六线SPI,多了两根线:RDY和INT,这样从机就可以主动请求主机给主机发送数据了。一、问题描述根据从机芯片手

  6. ruby - 如何在 Ruby 字符串中插入项目符号字符? - 2

    我正在尝试创建一个带有项目符号字符的Ruby1.9.3字符串。str="•"+"helloworld"但是,当我输入它时,我收到有关非ASCII字符的语法错误。我该怎么做? 最佳答案 你可以把Unicode字符放在那里。str="\u2022"+"helloworld" 关于ruby-如何在Ruby字符串中插入项目符号字符?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/1195

  7. ruby - 在 Rails 项目中测试本地版本的 gem - 2

    我的Rails站点使用了一个确实不是很好的gem。每次我需要做一些新的事情时,我最终不得不花费与向实际Rails项目添加代码一样多的时间来为gem添加功能。但我不介意,我将我的Gemfile设置为指向我的gem的GitHub分支(我尝试提交PR,但维护者似乎已经下台)。问题是我真的没有找到一种合理的方法来测试我添加到gem的新东西。在railsc中测试它会特别好,但我能想到的唯一方法是a)更改~/.rvm/gems/.../foo。rb,这看起来不对或者b)升级版本,推送到Github,然后运行​​bundleup,这除了耗时之外显然是一场灾难,因为我不确定我所做的promise是否正

  8. ruby - 合并 nanoc 中的项目 - 2

    我一直在尝试使用nanoc用于生成静态网站。我需要组织一个复杂的排列页面,我想让我的内容保持干燥。包含或合并的概念在nanoc系统中如何运作?我已阅读文档,但似乎找不到我想要的内容。例如:我如何获取两个部分内容项并将它们合并到一个新的内容项中。在staticmatic您可以在您的页面中执行以下操作。=partial('partials/shared/navigation')类似的约定在nanoc中如何运作? 最佳答案 这里是nanoc的作者。在nanoc中,部分是布局。因此,您可以拥有layouts/partials/shared/

  9. Ruby 和指南针路径与 yeoman 项目 - 2

    我安装了ruby​​、yeoman,当我运行我的项目时,出现了这个错误:Warning:Running"compass:dist"(compass)taskWarning:YouneedtohaveRubyandCompassinstalledthistasktowork.Moreinfo:https://github.com/gruUse--forcetocontinue.Use--forcetocontinue.我有进入可变session目标的路径,但它不起作用。谁能帮帮我? 最佳答案 我必须运行这个:geminstallcom

  10. node.js - 如何在 Travis CI 上的一个项目中运行 Node.js 和 Ruby 测试 - 2

    我有一个包含多个组件的存储库,其中大部分是用JavaScript(Node.js)编写的,一个是用Ruby(RubyonRails)编写的。我想要一个.travis.yml文件来触发一个运行每个组件的所有测试的构建。根据thisTravisCIGoogleGroupthread,目前还没有官方支持。我的目录结构是这样的:.├──构建服务器├──核心├──扩展├──网络应用├──流浪文件├──package.json├──.travis.yml└──生成文件我希望能够运行特定版本的Ruby(2.2.2)和Node.js(0.12.2)。我已经有了一个make目标,所以maketest在每

随机推荐