经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » Java相关 » Spring Boot » 查看文章
SpringBoot采用AJAX实现异步发布帖子详解
来源:jb51  时间:2022/8/23 16:19:21  对本文有异议

1. AJAX

  • Asynchronous JavaScript and XML
  • 异步的 JavaScript 与 XML 不是一门新技术,而是一个新术语
  • 使用 AJAX,网页能够将增量更新呈现在页面上,而不需要刷新整个页面
  • 虽然 X 代表 XML,但是目前 JSON 的使用比 XML 更加普遍

2. 功能描述

  • 使用 jQuery 发送AJAX请求
  • 采用AJAX请求,实现发布帖子的功能

用户点击【发布帖子】按钮后,页面出现一个弹窗,此时后面的页面并没有刷新。

点击【发布帖子】按钮后,publishBtn 按钮会执行 index.js 中的 publish() 方法,跳转到:CONTEXT_PATH + “/discuss/add”;会执行控制器类 DiscussPostControlleraddDiscussPost()方法。里面调用Service: discussPostService,该service又调用了 discussPostMapper,通过其对应的 SQL 语句将帖子内容插进 discuss_post 表中。

3. 开发流程

  • 工具类:编写多个(重载)JSONString 相关的方法
  • 数据库交互:在 xxxmapper.xml 文件中编写对应的 SQL 语句,并在 Dao 层的接口中声明 CRUD 方法
  • 核心业务逻辑:在 Service 层中编写,由该层调用 Dao 层的方法实现对数据层的操作
  • 视图层:控制器 + 页面

4. 引入AJAX依赖

  1. <dependency>
  2. <groupId>com.alibaba</groupId>
  3. <artifactId>fastjson</artifactId>
  4. <version>1.2.58</version>
  5. </dependency>

5. Util

util/CommunityUtil.java

在用户登录之前,不显示【发布帖子】按钮;

在用户登录之后,才显示【发布帖子】按钮,可以进行相关操作。

  1. //得到JSON格式的字符串
  2. //输入为:编号、提示、业务数据
  3. public static String getJSONString(int code, String msg, Map<String, Object> map){
  4. JSONObject json = new JSONObject();
  5. json.put("code",code);
  6. json.put("msg",msg);
  7. if (map!=null){
  8. for (String key: map.keySet()) {
  9. json.put(key, map.get(key));
  10. }
  11. }
  12. return json.toJSONString();
  13. }
  14. //得到JSON格式的字符串(重载1:无业务数据)
  15. public static String getJSONString(int code, String msg){
  16. return getJSONString(code, msg, null);
  17. }
  18. //得到JSON格式的字符串(重载2:无提示、业务数据)
  19. public static String getJSONString(int code){
  20. return getJSONString(code, null, null);
  21. }

6. Mapper

dao/DiscussPostMapper.java

添加了 insertDiscussPost() 方法,功能为插入帖子

  1. package com.nowcoder.community.dao;
  2. import com.nowcoder.community.entity.DiscussPost;
  3. import org.apache.ibatis.annotations.Mapper;
  4. import org.apache.ibatis.annotations.Param;
  5. import java.util.List;
  6. @Mapper
  7. public interface DiscussPostMapper {
  8. List<DiscussPost> selectDiscussPosts(int userId, int offset, int limit);
  9. // @Param注解用于给参数取别名
  10. // 如果只有一个参数,并且在<if>里使用,则必须加别名
  11. int selectDiscussPostRows(@Param("userId") int userId);
  12. int insertDiscussPost(DiscussPost discussPost);
  13. }

mapper/discusspost-mapper.xml

编写对应的 SQL 语句

  1. <insert id="insertDiscussPost" parameterType="DiscussPost">
  2. insert into discuss_post(<include refid="insertFields"></include>)
  3. values (#{userId},#{title},#{content},#{type},#{status},#{createTime},#{commentCount},#{score})
  4. </insert>

7. Service

service/DiscussPostService.java

编写 addDiscussPost(),同时注入过滤器

  1. package com.nowcoder.community.service;
  2. import com.nowcoder.community.dao.DiscussPostMapper;
  3. import com.nowcoder.community.entity.DiscussPost;
  4. import com.nowcoder.community.util.SensitiveFilter;
  5. import org.springframework.beans.factory.annotation.Autowired;
  6. import org.springframework.stereotype.Service;
  7. import org.springframework.web.util.HtmlUtils;
  8. import java.util.List;
  9. @Service
  10. public class DiscussPostService {
  11. @Autowired
  12. private DiscussPostMapper discussPostMapper;
  13. @Autowired
  14. private SensitiveFilter sensitiveFilter;
  15. public List<DiscussPost> findDiscussPosts(int userId, int offset, int limit) {
  16. return discussPostMapper.selectDiscussPosts(userId, offset, limit);
  17. }
  18. public int findDiscussPostRows(int userId) {
  19. return discussPostMapper.selectDiscussPostRows(userId);
  20. }
  21. public int addDiscussPost(DiscussPost post) {
  22. if (post == null) {
  23. throw new IllegalArgumentException("参数不能为空!");
  24. }
  25. // 转义HTML标记
  26. post.setTitle(HtmlUtils.htmlEscape(post.getTitle()));
  27. post.setContent(HtmlUtils.htmlEscape(post.getContent()));
  28. // 过滤敏感词
  29. post.setTitle(sensitiveFilter.filter(post.getTitle()));
  30. post.setContent(sensitiveFilter.filter(post.getContent()));
  31. return discussPostMapper.insertDiscussPost(post);
  32. }
  33. }

8. Controller

  1. package com.nowcoder.mycommunity.controller;
  2. import com.nowcoder.mycommunity.entity.DiscussPost;
  3. import com.nowcoder.mycommunity.entity.User;
  4. import com.nowcoder.mycommunity.service.DiscussPostService;
  5. import com.nowcoder.mycommunity.util.CommunityUtil;
  6. import com.nowcoder.mycommunity.util.HostHolder;
  7. import org.springframework.beans.factory.annotation.Autowired;
  8. import org.springframework.stereotype.Controller;
  9. import org.springframework.web.bind.annotation.RequestMapping;
  10. import org.springframework.web.bind.annotation.RequestMethod;
  11. import org.springframework.web.bind.annotation.ResponseBody;
  12. import java.util.Date;
  13. //处理所有与发帖相关的请求
  14. @Controller
  15. @RequestMapping("/discuss")
  16. public class DiscussPostController {
  17. @Autowired
  18. private DiscussPostService discussPostService;
  19. @Autowired //获取当前用户
  20. private HostHolder hostHolder;
  21. @RequestMapping(path = "/add", method = RequestMethod.POST)
  22. @ResponseBody
  23. public String addDiscussPost(String title, String content) {
  24. User user = hostHolder.getUser();
  25. if (user == null){
  26. // 403表示没有权限
  27. return CommunityUtil.getJSONString(403, "你还没有登录哦!");
  28. }
  29. DiscussPost post = new DiscussPost();
  30. post.setUserId(user.getId());
  31. post.setTitle(title);
  32. post.setContent(content);
  33. post.setCreateTime(new Date());
  34. discussPostService.addDiscussPost(post);
  35. return CommunityUtil.getJSONString(0, "发布成功");
  36. }
  37. }

9. JavaScript

index.js

在 js 文件中编写【发布按钮】对应的函数 publish()

  1. $(function(){
  2. $("#publishBtn").click(publish);
  3. });
  4. function publish() {
  5. $("#publishModal").modal("hide");
  6. // 获取标题和内容
  7. var title = $("#recipient-name").val();
  8. var content = $("#message-text").val();
  9. // 发送异步请求(POST)
  10. $.post(
  11. CONTEXT_PATH + "/discuss/add",
  12. {"title":title,"content":content},
  13. function(data) {
  14. data = $.parseJSON(data);
  15. // 在提示框中显示返回消息
  16. $("#hintBody").text(data.msg);
  17. // 显示提示框
  18. $("#hintModal").modal("show");
  19. // 2秒后,自动隐藏提示框
  20. setTimeout(function(){
  21. $("#hintModal").modal("hide");
  22. // 刷新页面
  23. if(data.code == 0) {
  24. window.location.reload();
  25. }
  26. }, 2000);
  27. }
  28. );
  29. }

到此这篇关于SpringBoot采用AJAX实现异步发布帖子详解的文章就介绍到这了,更多相关SpringBoot AJAX内容请搜索w3xue以前的文章或继续浏览下面的相关文章希望大家以后多多支持w3xue!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号