Vue中集成环信

1. 通过 NPM 安装 Web SDK。

npm install easemob-websdk --save

2.main.js中先 import ,再访问 Web IM

import websdk from "easemob-websdk"
注:该方式只引用了 Web SDK ,仍需在项目里配置 WebIMConfig 文件内的参数,用于实例化 websdk。

3.新建webim.config.js文件

webim.config.js.png

在 webim.config.js 文件内进行以下配置:

const config = {
     xmppURL: 'im-api.easemob.com',            // xmpp Server地址,对于在console.easemob.com创建的appKey,固定为该值

     apiURL: 'http://a1.easemob.com',          // rest Server地址,对于在console.easemob.com创建的appkey,固定为该值

     appkey: 'easemob-demo#chatdemoui',        // App key

      https : false,                            // 是否使用https

      isHttpDNS: true,                         //防止DNS劫持从服务端获取XMPPUrl、restUrl

      isMultiLoginSessions: false,              // 是否开启多页面同步收消息,注意,需要先联系商务开通此功能

      isAutoLogin: true,                        // 自动出席,(如设置为false,则表示离线,无法收消息,需要在登录成功后手动调 用conn.setPresence()才可以收消息)

      isDebug: false,                           // 打开调试,会自动打印log,在控制台的console中查看log

      autoReconnectNumMax: 2,                   // 断线重连最大次数

      autoReconnectInterval: 2,                 // 断线重连时间间隔

      heartBeatWait: 4500,                       // 使用webrtc(视频聊天)时发送心跳包的时间间隔,单位ms

        delivery: true,                           // 是否发送已读回执
     }
export default config;

4.在main.js中引入webim.config.js

import webimconfig from './common/webim.config'

引入的websdk和webimconfig

5.在main.js中创建环信实例

// 环信
// 环信
let WebIM = window.WebIM = websdk;
WebIM.config = webimconfig;
// 环信实例
var conn = WebIM.conn = new WebIM.connection({
  appKey: WebIM.config.appkey,
  isHttpDNS: WebIM.config.isHttpDNS,
  isMultiLoginSessions: WebIM.config.isMultiLoginSessions,
  https: WebIM.config.https,
  url: WebIM.config.xmppURL,
  apiUrl: WebIM.config.apiURL,
  isAutoLogin: true,
  heartBeatWait: WebIM.config.heartBeatWait,
  autoReconnectNumMax: WebIM.config.autoReconnectNumMax,
  autoReconnectInterval: WebIM.config.autoReconnectInterval,
  isStropheLog: WebIM.config.isStropheLog,
  delivery: WebIM.config.delivery
})
// 账号密码登录配置
var optionsIm = {
  apiUrl: WebIM.config.apiURL,
  user: '', //换成自己申请的账号就行,密码也需要换  
  pwd: '',
  appKey: WebIM.config.appkey,
  success: function (re) {
    console.log('登陆成功')
  },
  error: function (err) {
    console.log(err)
  }
}
Vue.prototype.$WebIM = WebIM;
Vue.prototype.$imconn = conn
Vue.prototype.$imoption = optionsIm;

6.使用方法

    // 登录账号
    loginWebIM() {
      // 这儿是测试用的账号和密码
      this.$imoption.user = this.util.getUser().id;

      this.$imconn.open(this.$imoption);
      let _this = this;
      // 监听回调
      this.$imconn.listen({
        onOpened: function(message) {
          console.log("用户已上线");
        },
        onClosed: function(message) {
          console.log("用户下线");
          _this.$emit("isclose", true);
        },
        // 收到文本消息
        onTextMessage: function(message) {
          if (message.from == _this.accept) {
            _this.chatContent.push({
              replyImg: require("./../../src/assets/img/hom/herderservice.png"),
              replyContent: message.data
            });
            _this.keepbottom();
          }
        }
      });
    },
    //发送文本消息
    sendMessage(textMessage) {
      let val = textMessage.replace(/[\r\n]/g, "").replace(/[ ]/g, "");
      if (val != "") {
        var id = this.$imconn.getUniqueId();
        let to = this.accept;
        // 生成本地消息id
        var msg = new WebIM.message("txt", id);
        let _this = this; // 创建文本消息
        msg.set({
          msg: val, // 消息内
          to: to, // 接收消息对象(用户id)
          roomType: false,
          success: function(id, serverMsgId) {
            //  追加本地缓存处理
            console.log(msg);
            _this.chatContent.push({
              //把发送者的头像和文本数据push到数组中在页面上展示
              askImg: require("./../../src/assets/img/hom/logo_blue.png"),
              askContent: msg.value
            });
            _this.keepbottom();
          },
          fail: function(e) {
            console.log("消息发送失败");
          }
        });
        msg.body.chatType = "singleChat";
        this.$imconn.send(msg.body);
        this.textMessage = "";
      }
    },
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,332评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,508评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,812评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,607评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,728评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,919评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,071评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,802评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,256评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,576评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,712评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,389评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,032评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,798评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,026评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,473评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,606评论 2 350

推荐阅读更多精彩内容

  • "strophe.js": "^1.3.1", "easemob-websdk": "^1.8.4", webIm...
    丶阿难阅读 1,371评论 0 0
  • 记录贴部分内容转载自:《VUE项目集成环信webIM随笔》 最新版本环信这个方法已经不适用了,详情跳转Vue中集成...
    北悸安凉_b2de阅读 3,561评论 8 1
  • 最近做实时通讯,项目需要集成环信IM,网上资料比较少,也是比较头大,捣鼓了两天,实现最基本的图文交流功能,分享一下...
    Dr_喜禾阅读 8,762评论 5 5
  • 点击查看原文 Web SDK 开发手册 SDK 概述 网易云信 SDK 为 Web 应用提供一个完善的 IM 系统...
    layjoy阅读 13,708评论 0 15
  • jHipster - 微服务搭建 CC_简书[https://www.jianshu.com/u/be0d56c4...
    quanjj阅读 800评论 0 2