uniapp使用腾讯IM实现即时通讯

1.下载sdk和插件

// 从v2.11.2起,SDK 支持了 WebSocket,推荐接入;v2.10.2及以下版本,使用 HTTP
npm install tim-wx-sdk --save
// 发送图片、文件等消息需要腾讯云 即时通信 IM 上传插件
npm install tim-upload-plugin --save
// 拦截或替换敏感词需要本地审核插件
npm install tim-profanity-filter-plugin --save

2.在main.js中写入下列代码

import TIM from "tim-wx-sdk";
import TIMUploadPlugin from "tim-upload-plugin";
import TIMProfanityFilterPlugin from "tim-profanity-filter-plugin";

let options = {
  SDKAppID: '', // 接入时需要将0替换为您的即时通信 IM 应用的 SDKAppID
};
// 创建 SDK 实例,`TIM.create()`方法对于同一个 `SDKAppID` 只会返回同一份实例
let tim = TIM.create(options); // SDK 实例通常用 tim 表示

// 设置 SDK 日志输出级别,详细分级请参见 setLogLevel  https://web.sdk.qcloud.com/im/doc/zh-cn/SDK.html#setLogLevel 接口的说明</a>
tim.setLogLevel(2); // 普通级别,日志量较多,接入时建议使用
// tim.setLogLevel(1); // release 级别,SDK 输出关键信息,生产环境时建议使用

// 注册腾讯云即时通信 IM 上传插件
tim.registerPlugin({ "tim-upload-plugin": TIMUploadPlugin });

// 注册腾讯云即时通信 IM 本地审核插件
tim.registerPlugin({ "tim-profanity-filter-plugin": TIMProfanityFilterPlugin });

// #ifdef APP-PLUS
// v2.22.0 起支持 uni-app 打包 native app 时使用离线推送插件
// 请注意!应合规要求,在用户同意隐私协议的前提下,登录成功后 SDK 会通过推送插件获取推送 token,并将推送 token 传递至后台(若获取 token 失败则会导致离线推送无法正常使用)
const TUIOfflinePush = uni.requireNativePlugin("TencentCloud-TUIOfflinePush");
tim.registerPlugin({
  "tim-offline-push-plugin": TUIOfflinePush,
  offlinePushConfig: {
    // huawei
    huaweiBusinessID: "", // 在腾讯云控制台上传第三方推送证书后分配的证书 ID
    // xiaomi
    xiaomiBusinessID: "", // 在腾讯云控制台上传第三方推送证书后分配的证书 ID
    xiaomiAppID: "", // 小米开放平台分配的应用 APPID
    xiaomiAppKey: "", // 小米开放平台分配的应用 APPKEY
    // meizu
    meizuBusinessID: "", // 在腾讯云控制台上传第三方推送证书后分配的证书 ID
    meizuAppID: "", // 魅族开放平台分配的应用 APPID
    meizuAppKey: "", // 魅族开放平台分配的应用 APPKEY
    // vivo
    vivoBusinessID: "", // 在腾讯云控制台上传第三方推送证书后分配的证书 ID
    // oppo
    oppoBusinessID: "", // 在腾讯云控制台上传第三方推送证书后分配的证书 ID
    oppoAppKey: "", // oppo 开放平台分配的应用 APPID
    oppoAppSecret: "", // oppo 开放平台分配的应用 Secret
    // ios
    iosBusinessID: "", // 在腾讯云控制台上传第三方推送证书后分配的证书 ID
  },
});
// #endif
//挂载到全局
Vue.prototype.TIM = TIM;
Vue.prototype.tim = tim;

3.在项目中引入debug文件夹

在这里插入图片描述
debug文件夹可以从此链接中下载

4.在App.vue文件中登录账号

import { genTestUserSig } from "@/debug/GenerateTestUserSig.js";
onLaunch: function () {
    let userID = "要登录账号的UserID"; // 在腾讯云开发者平台的账号管理页面中创建用户获取用户名(UserID)
    let userSig = genTestUserSig(userID).userSig;
    let promise = this.tim.login({ userID, userSig });
    promise
      .then(function (imResponse) {
        console.log("登录成功");
        // console.log(imResponse.data); // 登录成功
        if (imResponse.data.repeatLogin === true) {
          // 标识帐号已登录,本次登录操作为重复登录。v2.5.1 起支持
          console.log(imResponse.data.errorInfo);
        }
      })
      .catch(function (imError) {
        console.warn("login error:", imError); // 登录失败的相关信息
      });
  },

下面是腾讯im的操作

获取聊天列表:

let onConversationListUpdated = (event) => {
      console.log(event);
};
this.tim.on(this.TIM.EVENT.CONVERSATION_LIST_UPDATED, onConversationListUpdated);

接收发来的消息:

let onMessageReceived = (event) => {
       console.log(event);
};
this.tim.on(this.TIM.EVENT.MESSAGE_RECEIVED, onMessageReceived);

拉取历史消息:

let promise = this.tim.getMessageList({
        conversationID: "C2C" + '对方用户的UserID',
      });
      promise.then((imResponse) => {
        const messageList = imResponse.data.messageList; // 消息列表。
        const nextReqMessageID = imResponse.data.nextReqMessageID; // 用于续拉,分页续拉时需传入该字段。
        const isCompleted = imResponse.data.isCompleted; // 表示是否已经拉完所有消息。
});

发送文字信息:

let message = this.tim.createTextMessage({
        to: '对方用户的UserID',
        conversationType: "C2C",
        payload: {
          text: '要发送的文字消息',
        },
      });
      let promise = this.tim.sendMessage(message);
      promise
        .then((res) => {
           // 发送成功
           console.log(res);
        })
        .catch((err) => {
           // 发送失败
          console.log(err);
        });

发送图片消息:

let message = this.tim.createImageMessage({
            to: '对方用户的UserID',
            conversationType: this.TIM.TYPES.CONV_C2C,
            payload: { file: 'uni.chooseImage API返回的成功参数' },
            onProgress: function (event) {
              // console.log('file uploading:', event)
            },
          });
          // 3. 发送图片
          let promise = this.tim.sendMessage(message);
          promise
            .then((res) => {
               // 发送成功
               console.log(res);
            })
            .catch((err) => {
              // 发送失败
              console.log(err);
});

发送语音消息:

let res = {
        duration: '语音文件的时长',
        fileSize: '语音文件的大小',
        tempFilePath: '语音文件',
      };

      const message = this.tim.createAudioMessage({
        to: '对方用户的UserID',
        conversationType: this.TIM.TYPES.CONV_C2C,
        payload: {
          file: res,
        },
      });

      // 发送消息
      let promise = this.tim.sendMessage(message);
      promise
        .then(function (res) {
          // 发送成功
          console.log(res);
        })
        .catch(function (err) {
          // 发送失败
          console.warn(err);
        });
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在uniapp中接入腾讯地图,你可以按照以下步骤进行操作: 1. 首先,确保你已经创建了uniapp项目并打开了项目文件。 2. 接下来,你需要引入腾讯地图的JavaScript SDK。你可以在uniapp项目中的文件中引入qqmap-wx-jssdk.min.js。这样,你就可以在uniapp使用腾讯地图的相关功能了。 3. 使用uni.getLocation方法获取用户的地理位置信息。这个方法会返回用户的经纬度坐标。通过获取到的经纬度坐标,你可以使用地图中的逆解析reverseGeocoder方法来获取用户的详细地址信息。 4. 如果你的项目无法引入qqmap-wx-jssdk.min.js,那么你可以使用uniapp自带的方法uni.openLocation来打开腾讯地图。这个方法会根据传入的经纬度坐标在地图上显示位置。这个方法适用于uniapp的各个端。 5. 在进行接入腾讯地图之前,你需要申请腾讯位置服务的SDK密钥。你可以在腾讯位置服务平台上申请密钥并下载SDK。这个密钥会用于在uniapp使用腾讯地图相关功能时进行身份验证。 综上所述,要在uniapp中接入腾讯地图,你需要引入腾讯地图的JavaScript SDK,并在适当的位置使用uni.getLocation获取用户的地理位置信息,并使用逆解析方法获取详细地址信息。如果无法引入SDK,你可以使用uni.openLocation方法打开腾讯地图。在开始之前,确保你已经申请了腾讯位置服务的SDK密钥并下载了SDK。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值