基于Java+MySQL+Tomcat+Servlet+Maven+JQuery+jackson+开源Markdown编辑器实现前后端分离个人博客系统

这篇具有很好参考价值的文章主要介绍了基于Java+MySQL+Tomcat+Servlet+Maven+JQuery+jackson+开源Markdown编辑器实现前后端分离个人博客系统。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

项目简介

模块实现

设计实现数据库相关代码

博客列表页

博客详情页

注册页

登录页

检测登录状态

显示用户信息

退出登录

发布博客

删除博客

统计博客数量

效果展示

部分代码展示

小结:


项目简介

    项目中使用了Java ,MySQL ,Tomcat ,Servlet ,Maven ,JQuery ,jackson,开源MarkDown编辑器这些技术。共有五个页面:注册用户页,登录页,博客列表页,博客详情页,博客编辑页。

    所实现的功能有:设计实现数据库相关代码,实现博客列表页,实现博客详情页(按照md渲染),实现注册页,实现登录页,实现检测登录状态。显示用户信息,退出登录,发布博客,删除博客,统计博客数量。

由于源码较多,我放在github上,大家可以查看。
diwei00/JavaEE_Study (github.com)https://github.com/diwei00/JavaEE_Study

模块实现

设计实现数据库相关代码

    设计表,这里涉及两个实体(用户,博客)。一个用户可以拥有多篇博客,一篇博客只能有一个用户与之对应,即用户和博客之间是一对多的关系。

    封装数据库相关代码(数据源,连接,释放资源)。封装所有对于博客和用户操作的数据库代码。当我们具体实现各种处理请求计算响应时,就直接使用我们封装的这些方法。

博客列表页

    首先我们需要约定前后端交互接口。前端怎样发起请求,后端处理数据怎样将响应返回给前端。然会代码就需要根据我们所约定的前后端交互接口去实现。

    前端发起get请求,后端查询数据库中所有博客返回给前端。前端使用js构造相应标签,显示具体内容。

   请求:get/blog

   响应:HTTP/1.1 200 OK。使用jso格式组织数据。

博客详情页

    当我们从博客列表页跳转到博客详情页时,url中添加blogId。在博客详情页我们就可以通过blogId让后端查找到具体博客。由于这里使用的时Makrdown编辑器,数据库存储的也是未经md渲染的数据,当前端获取到后端数据时,需要使用md进行渲染展现给用户。

    请求:get/blog

    响应:HTTP/1.1 200 OK。使用json格式组织数据。

注册页

    通过用户在注册页面上输入的数据,将数据发送到后端。后端将数据构造成user对象,存储在数据库中。注册成功后端重定向到登录页面。

    请求:post/enroll

    响应:HTTP/1.1 302 重定向。

登录页

    通过用户在登录页面输入数据,发送到后端。后端查找数据库,判断用户名和密码,如果匹配失败则提示用户,否则登录成功重定向到博客列表页。

    请求:post/login

    响应:HTTP/1.1 302 重定向。

检测登录状态

    无论在哪一个页面操作都需要先登录,当进入博客列表页,博客详情页,博客编辑页首先会检测是否登录,如果没有登录直接重定向到登录页面。

    当用户注册账户且登录成功时,首先会为当前用户创建会话,通过key-val的方式将用户对象存储在HttpSessioon中。创建会话的过程中就会生成当前用户的SessionId通过set-cookie字段设置到客户端,后续操作每个页面都会请求中通过cookie字段都会带上这个SessionId。服务器这边就可以查找会话,看是否存在这个用户对象,来判断用户是否登录。

    请求:get/login

    响应:HTTP/1.1 200 OK。使用json组织user对象。

显示用户信息

    博客列表页显示当前登录的用户,点击博客详情页显示当前这篇文章的作者信息。

    当用户登录成功,服务器查找当前用户的会话,进一步查找会话中的user对象。约定如果没查找到返回空的user对象,否则返回当前查找到的用户。前端得到数据后,判断user对象。如果不为空,通过js将username设置到页面中。

    请求:get/login

    响应:HTTP/1.1 200 OK。使用json组织user对象。

    博客详情页中QueryString中是带有当前博客的blogId字段的。前端请求中也带上当前页面的QueryString,后端就可以获取到blogId字段。后端通过blogId就可以查找到具体博客,然后通过博客中的userId属性借助会话就可以查找到具体的user对象。前端得到数据后,就可将username设置到页面中。

    请求:get/author

    响应:HTTP/1.1 200 OK。使用json组织user对象。

退出登录

    退出登录有两种方法,可以直接删除当前用户的会话,也可以删除会话中的user对象。直接删除当前会话没有相应的api,所以我们采用第二种方式。

    前端发起请求,后端获取到当前用户的会话。然后删除当前会话中的user对象,重定向到登录页面。当前端再发请求时,后端就会检测登录状态,此时就是未登录状态。

    请求:get/logout

    响应:HTTP/1.1 302 重定向。

发布博客

    前端博客编写完成后,将标题和博客正文通过post请求中的body发送到后端。后端获取到数据后,同时通过会话获取到当前用户对象。然后构造blog对象,将blog对象存入数据库,重定向到博客列表页。

    请求:post/blog

    响应:HTTP/1.1 302 重定向。

删除博客

    在博客详情页进行删除博客操作。前端发起请求带上当前页面中的QueryString,后端就可以得到当前要删除的blogId。

    当前登录用户只能删除自己的博客,没有权限删除别人的博客。通过会话获取到当前用户,通过blogId获取到当前博客。判断这篇博客是否属于当前用户,使用blog中的userId属性和user中的userId属性进行判断。如果不属于提示用户,否则删除数据库中对应的博客,重定向到博客列表页。

    请求:get/delete

    响应:HTTP/1.1 302 重定向。

统计博客数量

    博客列表页统计当前列表所有博客数量。前端发起get请求,后端查询数据库统计所有博客数量。将数据返回到前端,前端使用js将数据显示到页面上。

    请求:get/count

    响应:HTTP/1.1 200 OK。json组织数据。

    博客详情页显示的是当前博客的作者,这里只统计当前作者博客数量。前端发起请求带上当前页面中的QueryString,后端就可以得到blogId。通过blogId就可以查找到具体博客,然后通过博客中的userId属性就可以确定这篇博客属于哪个作者。然后查询数据库,统计这个作者有多少篇博客,将数据返回到前端。前端使用js将数据构造到页面中。        

    请求:post/count

    响应:HTTP/1.1 200 OK。json组织数据。

效果展示

基于Java+MySQL+Tomcat+Servlet+Maven+JQuery+jackson+开源Markdown编辑器实现前后端分离个人博客系统

基于Java+MySQL+Tomcat+Servlet+Maven+JQuery+jackson+开源Markdown编辑器实现前后端分离个人博客系统

基于Java+MySQL+Tomcat+Servlet+Maven+JQuery+jackson+开源Markdown编辑器实现前后端分离个人博客系统

基于Java+MySQL+Tomcat+Servlet+Maven+JQuery+jackson+开源Markdown编辑器实现前后端分离个人博客系统

基于Java+MySQL+Tomcat+Servlet+Maven+JQuery+jackson+开源Markdown编辑器实现前后端分离个人博客系统

部分代码展示

package api;

import com.fasterxml.jackson.databind.ObjectMapper;
import model.User;
import model.UserDao;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.io.IOException;

@WebServlet("/login")
public class LoginServlet extends HttpServlet {
    private ObjectMapper objectMapper = new ObjectMapper();
    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //实现登录功能
        //设置请求编码,告诉servlet按照怎样的格式解析
        req.setCharacterEncoding("utf8");
        //设置响应类型,告诉客户端按照怎样格式解析
        resp.setContentType("application/json;charset=utf8");
        //获取到username 和  password
        String username = req.getParameter("username");
        String password = req.getParameter("password");

        //判断
        if(username == null || "".equals(username) || password == null || "".equals(password)) {
            //登录失败
            String respJson = "{\"message\":\"登录失败!缺少username 或 password字段\"}";
            resp.getWriter().write(respJson);
            return;
        }
        //查看数据库,判断密码和用户名是否匹配
        UserDao userDao = new UserDao();
        User user = userDao.selectByUsername(username);
        if(user == null) {
            //用户名错误
            String respJson = "{\"message\":\"登录失败! 用户名或密码错误\"}";
            resp.getWriter().write(respJson);
            return;
        }
        if(!user.getPassword().equals(password)) {
            //密码错误
            String respJson = "{\"message\":\"登录失败! 用户名或密码错误\"}";
            resp.getWriter().write(respJson);
            return;
        }
        //用户验证成功,创建会话,保存当前用户信息
        HttpSession session = req.getSession(true);
        session.setAttribute("user", user);
        //重定向到博客列表页
        resp.sendRedirect("blog_list.html");
    }

    //用户判断用户是否登录
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        resp.setContentType("application/json;charset=utf8");
        HttpSession session = req.getSession(false);
        if(session == null) {
            //用户未登录。返回空的user对象
            User user = new User();
            String respJson = objectMapper.writeValueAsString(user);
            resp.getWriter().write(respJson);
            return;
        }
        User user = (User) session.getAttribute("user");
        if(user == null) {
            user = new User();
            String respJson = objectMapper.writeValueAsString(user);
            resp.getWriter().write(respJson);
            return;
        }
        //获取到user对象,直接返回
        String respJson = objectMapper.writeValueAsString(user);
        resp.getWriter().write(respJson);
    }
}

小结:

    当我们把后端代码编写完成后,可以使用Postman工具发请求进行验证。当前端代码编写完成后,运行前端和和后端代码。如果出现bug,使用抓包工具Fiddler进行抓包,看请求和响应中的一些数据和body。来判断是前端bug还是后端bug,定位好之后就可以修改了。文章来源地址https://www.toymoban.com/news/detail-432318.html

到了这里,关于基于Java+MySQL+Tomcat+Servlet+Maven+JQuery+jackson+开源Markdown编辑器实现前后端分离个人博客系统的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • SpringBoot学习——追根溯源servlet是啥,tomcat是啥,maven是啥 & springBoot项目初步,maven构建,打包 & 测试

    1.追根溯源,servlet是啥,tomcat是啥,maven是啥; 2.前后端开发模式,mvc,mvvc,service层的事务; 3.maven对项目全生命周期的管理,打包jar包和运行; 4.springBoot项目的搭建,pom文件,项目结构,项目环境; 5.Druid连接数据库,管理连接,springBootApplication的exclude; 6.banner.text的使用

    2024年02月13日
    浏览(35)
  • IDEA2023 Maven3.9.1+Tomcat10.1.8配置并搭建Servlet5.0的基本框架

    文章目录 一、Maven3.9.1下载并配置 二、Tomcat10.1.8下载并配置 三、搭建Servlet 一、Maven3.9.1下载并配置 (1)Maven下载 Maven官网:https://maven.apache.org/download.cgi?. Maven3.9.1下载:https://dlcdn.apache.org/maven/maven-3/3.9.1/binaries/apache-maven-3.9.1-bin.zip   (2)Maven配置环境变量并修改settings.xml文件

    2024年02月09日
    浏览(40)
  • 基于JAVA+Servlet+JSP+MYSQL的党员信息管理系统

    项目功能: ###用户角色: 超级管理员: 整个系统的信息维护,相当于学校党务负责人 测试账号admin 密码:123456 系管理员: 各院系党务办公室负责人,负责管理自己院系党员信息 测试账号zhangsan 密码:123456 实现功能:(超级管理员与系管理员权限不同) 用户个人信息管理

    2023年04月09日
    浏览(26)
  • 基于javaweb+mysql的jsp+servlet图书图书馆管理系统(java+jsp+layui+bootstrap+servlet+mysql)

    基于javaweb+mysql的jsp+servlet图书图书馆管理系统(java+jsp+layui+bootstrap+servlet+mysql) 运行环境 Java≥8、MySQL≥5.7、Tomcat≥8 开发工具 eclipse/idea/myeclipse/sts等均可配置运行 适用 课程设计,大作业,毕业设计,项目练习,学习演示等 功能说明 基于javaweb+mysql的JSP+Servlet图书图书馆管理系统

    2024年02月04日
    浏览(41)
  • Eclipse+servlet+Tomcat+MySQL实现登入注册页面

    目录 1. 效果展示 2. 环境搭建 3. 前端代码 4. 后端代码  5.创作不易,点个赞吧 表   登入界面 注册界面 注册一个账号   登入该账号 1.尝试输入错误密码 2.输入正确密码 再次注册该账号   MySQL下载安装网上都有可以参考http://t.csdn.cn/czWMN Eclipse搭载MySQLhttp://t.csdn.cn/NKXAh 这边说一

    2023年04月26日
    浏览(32)
  • 基于javaweb+mysql的jsp+servlet幼儿园管理系统(java+jsp+easyui+h-ui+servlet+mysql)

    基于javaweb+mysql的jsp+servlet幼儿园管理系统(java+jsp+easyui+h-ui+servlet+mysql) 私信 源码获取及调试交流 运行环境 Java≥8、MySQL≥5.7、Tomcat≥8 开发工具 eclipse/idea/myeclipse/sts等均可配置运行 适用 课程设计,大作业,毕业设计,项目练习,学习演示等 功能说明 基于javaweb的JSP+Servlet幼儿

    2024年01月16日
    浏览(61)
  • 一个简单的前后端交互——登录注册页面(升级版)idea代码篇(2:Maven:Javaweb项目)使用MyBatis:Mapper,servlet+Tomcat

    前言:本篇前后端交互实现代码 。详细项目搭建见上篇 先贴一张登录界面和包结构:   1.Mapper 2.pojo 3.util 4.web 5.Login.html 6.CSS 我的企业版过期了,不能演示跳转页面了。但测过没问题。

    2024年02月11日
    浏览(37)
  • java-初识Servlet,Tomcat,JDBC

    java入门须知的重要概念/名词/技术 等 Servlet是Java Web开发中的一个核心组件,它是 基于Java语言编写的服务器端程序,可以接收Web容器(如Tomcat)发送过来的HTTP请求 ,并向客户端发送HTTP响应。Servlet通常用来处理动态Web页面、Web表单数据、管理会话(session)等任务。 实际上,

    2024年02月11日
    浏览(26)
  • 基于Java+Servlet+Mysql的人才招聘网站的设计与实现(附源码 调试 文档)

    摘要 本文介绍了一种基于Servlet人才招聘网站的设计与实现。该系统分为管理员、注册用户和企业用户三种角色,分别具有不同的功能。管理员主要负责用户管理、企业管理、新闻管理、职位管理和简历投递管理等;注册用户和企业在系统中的功能各不相同,注册用户可以查

    2024年02月05日
    浏览(38)
  • Java+Servlet+MySql后台的基于微信小程序的汽车租赁管理系统的设计与实现(附源码 论文 配置 讲解)

    随着科技的快速发展和互联网的广泛应用,传统行业正在经历着前所未有的变革。汽车租赁行业是一种需要大量人力和物力投入的行业,而随着移动互联网的发展,利用微信小程序开发一个汽车租赁管理系统成为可能。本论文将介绍一种基于微信小程序的汽车租赁管理系统的

    2024年02月06日
    浏览(48)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包