websocket协调编辑

本文介绍了使用WebSocket实现协同在线编辑的设计思路与详细代码实现过程,包括实体类、Mapper层、ArticleSocketServer、SpringContextUtil、WebSocketConfig和控制层的设置。在设计中,通过线程调用发送信息方法,未来可能采用MQ优化。实现在ruoyi-vue基础上的改动,最终展示了协同编辑的成果。测试账号需使用不同浏览器登录以避免session混乱。
摘要由CSDN通过智能技术生成

websocket实现协同在线编辑

一、设计思路

图片:在这里插入图片描述

目前使用的是线程的形式去调用发送信息方法,后期可以采用mq的形式去做处理。

代码在ruoyi-vue的基础上进行改动的

二、代码实现

1、实体类


/**
 * 文章实体类
 **/

@Data
@Document(collection = "article") //指定要对应的文档名(表名)
@Accessors(chain = true)
@AllArgsConstructor
public class Article {
   
    @Id
    private String id;//文章主键

    private String articleName; //文章名

    private String content; //文章内容

    private List<String> userIds;//用户信息
}

2、Mapper层

@Repository
public class ArticleMapper {
   

    @Autowired
    MongoTemplate mongoTemplate;


    //根据id查询文章
    public  Article findById(String id) {
   
        Article articles = mongoTemplate.findById(id, Article.class, "article");
        return articles;
    }

    //存入文章
   public Article save(String data,String id){
   
       Article article = new Article(id, "article", data, null);
       mongoTemplate.save(article,"article");
        return article;
    }
}

3、ArticleSocketServer

/**
 * Created with IntelliJ IDEA.
 *
 * @Author: fulin
 * @Date: 2023/01/06/11:28
 * @Description:
 */
@ServerEndpoint("/article/{articleId}/{userId}")
@Component
public class ArticleSocketServer {
   

    /**
     * 存放文章集合 key为文章id value 为map
     * value集合 以用户id为key value为ArticleSocketServer对象
     */
    public static ConcurrentHashMap<String, ConcurrentHashMap<String, ArticleSocketServer>> articleMap = new ConcurrentHashMap<>();


    /**
     * 因为无法注入bean对象 所以通过ApplicationContext获取bean
     * @return
     */
    private ArticleMapper getArticleMapper() {
   
        return SpringContextUtil.getBean(Art
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值