当前位置: 首页 > news >正文

JavaEE-博客系统3(功能设计)

本部分内容为:实现登录功能;强制要求用户登录;实现显示用户信息;退出登录;发布博客




在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
该部分的后端代码如下:

   @Overrideprotected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {//1.从请求中获取用户名和密码//    给请求对象设置字符集, 保证说请求中的 username 或者 password 是中文, 也能正确处理.req.setCharacterEncoding("utf8");String username=req.getParameter("username");String password=req.getParameter("password");if(username==null || password==null || "".equals(username) || "".equals(password)){//这是用户名和密码有误resp.setContentType("text/html;charset=utf8");resp.getWriter().write("username or password is empty");return;}//2.从数据库的数据进行验证,看用户名和密码是否匹配//通过用户名查询信息UserDao userDao=new UserDao();User user=userDao.getUserByName(username);if(user==null){//当前提交的用户名密码错误resp.setContentType("text/html;charset=utf8");resp.getWriter().write("username or password is wrong");return;}if(!password.equals(user.getPassword())){//当前提交的用户名密码错误resp.setContentType("text/html;charset=utf8");resp.getWriter().write("username or password is wrong");return;}//3创建会话HttpSession session= req.getSession(true);// 把当前登录的用户信息保存到 session 中, 方便后续进行获取.session.setAttribute("user",user);//4跳转到博客列表页resp.sendRedirect("blog_list.html");

在这里插入图片描述

在这里插入图片描述




在这里插入图片描述在这里插入图片描述
该部分的后端代码如下:

@Overrideprotected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {//根据上面,我们建立了会话为依据HttpSession session= req.getSession(false);if(session==null){//未登录,返回前端resp.setStatus(403);return;}//不仅仅要看session是否存在,还要看上述中存储的用户信息是否存在User user= (User) session.getAttribute("user");if(user==null){//未登录,返回前端resp.setStatus(403);return;}//表示已经登陆resp.setStatus(200);}



在这里插入图片描述

在这里插入图片描述在这里插入图片描述
该部分的后端代码如下:

private ObjectMapper objectMapper=new ObjectMapper();@Overrideprotected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {//通过判断请求是否带有blogId这个参数,来判断是列表页发来的请求还是详情页发来的请求String blogId=req.getParameter("blogId");if(blogId==null){//表明是列表页//列表页可以从保存下来的session中拿到用户信息HttpSession session=req.getSession(false);//拿到的这个session可能为空if(session==null){//session为空,那么用户信息也必然为空,这里需要创建一个卡用户出来User user=new User();//Jackson ObjectMapper类(com.fasterxml.jackson.databind.ObjectMapper)解析JSON工具////序列化:      Java对象生成Json////反序列化:  Json解析为Java对象String respJson=objectMapper.writeValueAsString(user);resp.setContentType("application/json;charset=utf8");resp.getWriter().write(respJson);return;}User user= (User) session.getAttribute("user");if(user==null){user=new User();String respJson=objectMapper.writeValueAsString(user);resp.setContentType("application/json;charset=utf8");resp.getWriter().write(respJson);return;}String respJson=objectMapper.writeValueAsString(user);resp.setContentType("applicaion/json;charset=utf8");resp.getWriter().write(respJson);}else{//表明是详情页//需要查询数据库,通过blogId关联找到blog,再通过getuserid找到userid,通过userid找到userBlogDao blogDao=new BlogDao();Blog blog=blogDao.getBlog(Integer.parseInt(blogId));if(blog==null){User user=new User();String respJson=objectMapper.writeValueAsString(user);resp.setContentType("application/json;charset=utf8");resp.getWriter().write(respJson);return;}UserDao userDao=new UserDao();User user=userDao.getUserById(blog.getBlogId());if(user==null){user=new User();String respJson=objectMapper.writeValueAsString(user);resp.setContentType("application/json;charset=utf8");resp.getWriter().write(respJson);return;}String respJson=objectMapper.writeValueAsString(user);resp.setContentType("application/json;charset=utf8");resp.getWriter().write(respJson);}}

在这里插入图片描述




在这里插入图片描述在这里插入图片描述上述过程的后端代码如下:

protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {HttpSession session=req.getSession(false);if(session==null){//当前状态未登录,不做处理,跳转到登录resp.sendRedirect("login.html");return;}//在登录成功之后,session中会有user这个属性,// 把他删除之后,状态就成了为登录session.removeAttribute("user");resp.sendRedirect("login.html");

在这里插入图片描述




在这里插入图片描述
在这里插入图片描述
上述过程的后端代码如下:

//1.获取登录的用户//虽然编写内容的时候,一定会有用户登录,但是为了防止其它情况,我们还是要做检查HttpSession session=req.getSession(false);if(session==null){resp.setContentType("text/html;charset=utf8");resp.getWriter().write("user don`t register,please register");return;}User user= (User) session.getAttribute("user");if(user==null){resp.setContentType("text/html;charset=utf8");resp.getWriter().write("user don`t register,please register");return;}//2.从请求中获取用户传递过来的信息req.setCharacterEncoding("utf8");String title=req.getParameter("title");String content=req.getParameter("content");if(title==null || content==null || "".equals(title) || "".equals(content)){resp.setContentType("text/html;charset=utf8");resp.getWriter().write("title or content is empty");return;}//3.构造对象,将其插入倒数据库中Blog blog=new Blog();blog.setTitle(title);blog.setContent(content);blog.setUserId(user.getUserId());//此处的时间是sql通过自带的now获取,不需要手动获取BlogDao blogDao=new BlogDao();blogDao.insert(blog);//4.跳转到列表页resp.sendRedirect("blog_list.html");

在这里插入图片描述




http://www.lryc.cn/news/219761.html

相关文章:

  • 椭圆滤波器
  • Mac 下安装golang环境
  • 前端面试大纲
  • CAN(Controller Area Network)是一种用于在汽车和工业领域中进行通信的串行总线系统(附加案例)
  • 代码随想录day53|1143.最长公共子序列、 1035.不相交的线、 53. 最大子序和
  • xilinx fpga ddr mig axi
  • 《golang设计模式》第三部分·行为型模式-04-迭代器模式(Iterator)
  • python加上ffmpeg实现音频分割
  • LLM之Prompt(一):5个Prompt高效方法在文心一言3.5的测试对比
  • TreeBERT:基于树的编程语言预训练模型。
  • 生成小程序的二维码的base64码(中间logo可以自定义)
  • 【音视频 | Ogg】Ogg封装格式详解——包含Ogg封装过程、数据包(packet)、页(page)、段(segment)等
  • ubuntu 22.04 安装ros2 iron
  • PHP语言、B/S手术麻醉临床信息管理系统源码
  • Win11安装网络打印机
  • 逆向学习记录(3)工具介绍jadx、gda和jeb
  • C#,数值计算——偏微分方程,Mglin的计算方法与源程序
  • 一机服务万人,拓世法宝AI智能商业数字人一体机,解锁文旅新表达
  • 【源码解析】聊聊SpringBean是如何初始化和创建
  • 【0基础学Java第六课】-- 数组的定义与使用
  • 后台项目Gradle打包jar,不包含依赖jar并放到外部路径
  • NSSCTF web刷题记录4
  • 什么是大模型?一文读懂大模型的基本概念
  • 数据结构之队的实现
  • 【实战Flask API项目指南】之三 路由和视图函数
  • mediasoup udp端口分配策略
  • 山西电力市场日前价格预测【2023-11-07】
  • Microsoft Dynamics 365 CE 扩展定制 - 5. 外部集成
  • 手机升级STM32单片机,pad下载程序,手机固件升级单片机,局域网程序下载,STM32单片机远程下载升级
  • 【漏洞复现】weblogic-SSRF漏洞