4.发布帖子,评论帖子

本文介绍了如何使用AJAX实现论坛的发布帖子、查看帖子详情和评论功能。涉及数据层、服务层和视图层的开发,包括DiscussPostMapper、DiscussPostService和DiscussPostController的交互,以及CommentMapper和CommentService的评论功能实现,同时强调了事务管理和页面的异步更新。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

一:发布帖子

二:帖子详情

三:查看评论

四:评论帖子


一:发布帖子

用到的表:DiscussPost

方法:用到AJAX,网页能将增量更新呈现在页面上,而不需要刷新整个页面 

异步通信技术,虽然X代表XML,但目前JSON使用的比XML更加普遍

思路 

  1. 在首页点击 “我要发布”,填写标题和正文,点击发布,会执行index.js中的publish()方法,触发ajax异步发送帖子请求,映射到DiscussPostController(/discuss)层的 /add 路径。执行控制器类 DiscussPostController 的 addDiscussPost()方法。里面调用 discussPostService.addDiscussPost 方法,将post 中的 title,content 转义HTML标记,,然后调用 discussPostMapper.insertDiscussPost(post) 存入数据。通过其对应的SQL语句将帖子内容插进 discuss_post表中。
  2. 简单来说就是 用post方式提交接json格式数据给目标URL,controller层接收到请求后,处理/add请求,前端根据返回的状态码以及提示信息判断是否添加成功。
     

 开发流程

1.我们从最简单的工具类开始,在里面写上了我们需要的一些工具方法;

在util.CommunityUtil类中添加新的工具方法,用于转换json字符串:返回状态码,在贴子发布后,显示发布成功。

    //得到JSON格式的字符串
    //输入为:编号、提示、业务数据
    public static String getJSONString(int code, String msg, Map<String, Object> map){
        JSONObject json = new JSONObject();
        json.put("code",code);
        json.put("msg",msg);
        if (map!=null){
            for (String key: map.keySet()) {
                json.put(key, map.get(key));
            }
        }
        return json.toJSONString();
    }
 
    //得到JSON格式的字符串(重载1:无业务数据)
    public static String getJSONString(int code, String msg){
        return getJSONString(code, msg, null);
    }
 
    //得到JSON格式的字符串(重载2:无提示、业务数据)
    public static String getJSONString(int code){
        return getJSONString(code, null, null);
    }

2. 在数据层dao中的DiscussPostMapper接口新添加方法,并在对应的discusspost-mapper添加对应的SQL语句

//添加帖子
int insertDiscussPost(DiscussPost discussPost);

//SQL语句
    <insert id="insertDiscussPost" parameterType="DiscussPost">
        insert into discuss_post(<include refid="insertFields"></include>)
        values (#{userId},#{title},#{content},#{type},#{status},#{createTime},#{commentCount},#{score})
    </insert>

3. 业务的核心逻辑都在Service层,在service类中编写了一些需要的业务逻辑,业务层需要定义一个对帖子进行保存的方法,最后调用dao里的方法,实现对数据层的更新。

在service.DiscussPostService类下新建方法:addDiscussPost()。

    @Autowired
    private SensitiveFilter sensitiveFilter;
 
    public int addDiscussPost(DiscussPost post){
        if(post==null){
            throw new IllegalArgumentException("参数不能为空!");
        }
        //转义HTML标记:防止人家发布的内容中包含html的标签,导致破坏页面
        //只用对主题、评论进行转义、过滤操作
        post.setTitle(HtmlUtils.htmlEscape(post.getTitle()));
        post.setContent(HtmlUtils.htmlEscape(post.getContent()));
        //过滤敏感词
        post.setTitle(sensitiveFilter.filter(post.getTitle()));
        post.setContent(sensitiveFilter.filter(post.getContent()));
        return discussPostMapper.insertDiscussPost(post);
    }


4. Service之后,最后就是视图层的编写,分为两个部分:控制器 + 页面。

在controller目录下新建:DiscussPostController,实现增加帖子的功能,以后所有与发帖相关的请求都在这里处理。

package com.nowcoder.mycommunity.controller;
 
//处理所有与发帖相关的请求
@Controller
@RequestMapping("/discuss")
public class DiscussPostController {
    @Autowired
    private DiscussPostService discussPostService;
    @Autowired    //获取当前用户
    private HostHolder hostHolder;
 
    @RequestMapping(path = "/add", method = RequestMethod.POST)
    @ResponseBody
    public String addDiscussPost(String title, String content) {
        User user = hostHolder.getUser();
        if (user == null){
            // 403表示没有权限
            return CommunityUtil.getJSONString(403, "你还没有登录哦!");
        }
        DiscussPost post = new DiscussPost();
        post.setUserId(user.getId());
        post.setTitle(title);
        post.setContent(content);
        post.setCreateTime(new Date());
        discussPostService.addDiscussPost(post);
 
        return CommunityUtil.getJSONString(0, "发布成功");
    }
}

再完成JS部分的编写,index.html中101行的【发布按钮】绑定了一个函数publish(),可以在Index.js中查看(双击shift搜索)。

$(function(){
	$("#publishBtn").click(publish);
});
 
function publish() {
	$("#publishModal").modal("hide");
 
	// 获取标题和内容
	var title = $("#recipient-name").val();
	var content = $("#message-text").val();
 
	// 发送异步请求(POST)
	$.post(
	     CONTEXT_PATH + "/discuss/add",
	    {"title":title,"content":content},
	    function(data) {
	        data = $.parseJSON(data);
	        // 在提示框中显示返回消息
	        $("#hintB
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值