Android - 极光推送 即时通讯

极光推送 即时通讯

准备应用

Demo 项目地址github

  1. 打开极光官网 链接: 极光 到极光推送官方网站注册开发者帐号;

  2. 登录进入管理控制台,创建应用程序,得到 Appkey(SDK 与服务器端通过 Appkey 互相识别);

  3. 在推送设置中给 Android
    设置包名、给 iOS 上传证书、启用 WinPhone,根据你的需求进行选择;

  4. 集成sdk

集成极光推送sdk

Jcenter 自动集成步骤

使用 jcenter 自动集成的开发者,不需要在项目中添加 jar 和 so,
jcenter 会自动完成依赖;在 AndroidManifest.xml 中不需要添加任何
 JPush SDK 相关的配置,jcenter 会自动导入。
 添加依赖
	implementation 'cn.jiguang.sdk:jpush:3.8.5'  // 此处以JPush 3.8.5 版本为例。 推送
    implementation 'cn.jiguang.sdk:jmessage:2.9.2'  // 此处以JMessage 2.9.2 版本为例。  即时通讯
    implementation 'cn.jiguang.sdk:jcore:2.5.5'  // 此处以JCore 2.5.5 版本为例。
//在moudle的build.gradle
defaultConfig{
	ndk {
            //选择要添加的对应 cpu 类型的 .so 库。
            abiFilters 'armeabi', 'armeabi-v7a', 'arm64-v8a'
            // 还可以添加 'x86', 'x86_64', 'mips', 'mips64'
        }

        manifestPlaceholders = [
                JPUSH_PKGNAME : "com.demo.message",//包名
                JPUSH_APPKEY : "21d83f3cf12878c554ef54b6", //极光开发平台上注册的包名对应的appkey.
                JPUSH_CHANNEL : "developer-default", //暂时填写默认值即可.
        ]
        }
	<uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
  <!-- Since JCore2.0.0 Required SDK核心功能 -->
        <!-- 可配置android:process参数将Service放在其他进程中;android:enabled属性不能是false -->
        <!-- 这个是自定义Service,要继承极光JCommonService,可以在更多手机平台上使得推送通道保持的更稳定 -->
        <service
            android:name=".JPush.JPService"
            android:enabled="true"
            android:exported="false"
            android:process=":pushcore">
            <intent-filter>
                <action android:name="cn.jiguang.user.service.action" />
            </intent-filter>
        </service> 

		<!-- Required since 3.0.7 -->
        <!-- 新的 tag/alias 接口结果返回需要开发者配置一个自定的广播 -->
        <!-- 3.3.0开始所有事件将通过该类回调 -->
        <!-- 该广播需要继承 JPush 提供的 JPushMessageReceiver 类, 并如下新增一个 Intent-Filter -->
        <receiver
            android:name=".JPush.JPReceiver"
            android:enabled="true"
            android:exported="false">
            <intent-filter>
                <action android:name="cn.jpush.android.intent.RECEIVE_MESSAGE" />

                <category android:name="com.demo.message" />
            </intent-filter>
        </receiver>

        <service
            android:name="cn.jpush.android.service.PushService"
            android:process=":multiprocess"
            tools:node="replace">
         </service>

在Application中初始化sdk

		JPushInterface.setDebugMode(true);
        JPushInterface.init(this);//推送

        JMessageClient.init(context,true);//即时通讯

注册

/**
     * 注册
     * 参数说明
     * String username 用户名
     * String password 用户密码
     * RegisterOptionalUserInfo optionalUserInfo 注册时的用户其他信息
     * BasicCallback callback 结果回调
     */
    public void register(final Context context, String username, String password, final JPCallBack.RegisterCallBack registerCallBack) {
        JMessageClient.register(username, password, new BasicCallback() {
            @Override
            public void gotResult(int i, String s) {
                Log.i("TAG", "register:code:" + i + "  msg:" + s);
                if (i == 0) {
                    registerCallBack.onResult(i, s);
                } else {
                    checkCode(context, i);
                }
            }
        });
    }

登录

 /**
     * 登录
     * 参数说明
     * String username 用户名
     * String password 用户密码
     * BasicCallback callback 结果回调
     */
    public void login(final Context context, String username, String password, final JPCallBack.RegisterCallBack registerCallBack) {
        JMessageClient.login(username, password, new BasicCallback() {
            @Override
            public void gotResult(int i, String s) {
                Log.i("TAG", "register:code:" + i + "  msg:" + s);
                if (i == 0) {
                    registerCallBack.onResult(i, s);
                } else {
                    checkCode(context, i);
                }
            }
        });
    }
/**
     * 创建单聊会话
     * 参数说明
     * String username 会话对象的username.
     * String appkey 用户所属应用的appkey,如果填空则默认为本应用的appkey
     */
    public void createConversation(String userName) {
        Conversation singleConversation = Conversation.createSingleConversation(userName, BaseContract.APP_KEY);
        mConversation = singleConversation;
    }

/**
     * 发送消息     使用默认的配置参数发送
     * 参数说明
     * Message message 消息对象
     */
    public void sendMessage(Context context, String userName, String text, JPCallBack.SendCallBack sendCallBack) {
        Message message = JMessageClient.createSingleTextMessage(userName, BaseContract.APP_KEY, text);
        JMessageClient.sendMessage(message);
        checkSendResult(context, message, sendCallBack);
    }
 /**
     * 发送消息    附带控制参数的消息发送
     * 参数说明
     * Message message 消息对象
     */
    public void sendMessage(String text, MessageSendingOptions options) {

    }
 /**
     * 校验消息发送结果监听
     *
     * @param message
     * @param sendCallBack
     */
    private void checkSendResult(final Context context, Message message, final JPCallBack.SendCallBack sendCallBack) {
        message.setOnSendCompleteCallback(new BasicCallback() {
            @Override
            public void gotResult(int i, String s) {
                Log.i("TAG", "register:code:" + i + "  msg:" + s);
                if (i == 0) {
                    sendCallBack.onResult(i, s);
                } else {
                    checkCode(context, i);
                }
            }
        });
    }
 /**
     * 校验JMessage返回值
     *
     * @param context
     * @param i
     */
    private void checkCode(Context context, int i) {
        switch (i) {
            case 871102:
                ToastUtils.showToast(context, "请求失败,请检查网络");
                break;
            case 871103:
            case 871104:
                ToastUtils.showToast(context, "服务器内部错误");
                break;
            case 871105:
                ToastUtils.showToast(context, "请求的用户信息不存在");
                break;
            case 871201:
                ToastUtils.showToast(context, "响应超时");
                break;
            case 871303:
                ToastUtils.showToast(context, "用户名不合法");
                break;
            case 871304:
                ToastUtils.showToast(context, "密码不合法");
                break;
            case 871305:
                ToastUtils.showToast(context, "名称不合法");
                break;
            case 871308:
                ToastUtils.showToast(context, "SDK尚未初始化");
                break;
            case 871310:
                ToastUtils.showToast(context, "网络连接已断开,请检查网络");
                break;
            case 898001:
                ToastUtils.showToast(context, "用户已存在");
                break;
            case 801003:
                ToastUtils.showToast(context, "登录的用户名未注册,登录失败");
                break;
            case 801004:
                ToastUtils.showToast(context, "登录的用户密码错误,登录失败");
                break;
            case 801005:
                ToastUtils.showToast(context, "登录的用户设备有误,登录失败");
                break;
            case 801006:
                ToastUtils.showToast(context, "登录的用户被禁用,登录失败");
                break;
            case 872100:
                ToastUtils.showToast(context, "音视频引擎初始化失败,appkey为空");
                break;
            case 872101:
                ToastUtils.showToast(context, "音视频引擎由于一些问题初始化失败,详情请看日志");
                break;
            case 872102:
                ToastUtils.showToast(context, "音视频引擎初始化失败,由于网络异常造成");
                break;
            case 872103:
                ToastUtils.showToast(context, "音视频引擎初始化失败,由于服务器端返回内容错误造成");
                break;
            case 872104:
                ToastUtils.showToast(context, "音视频引擎初始化失败,由于服务器端内部错误造成");
                break;
            case 872105:
                ToastUtils.showToast(context, "音视频引擎初始化失败,由于需要的权限没有获取成功造成");
                break;
            case 872106:
                ToastUtils.showToast(context, "音视频引擎还未初始化");
                break;
        }
    }

消息处理

//用户在线期间收到的消息都会以MessageEvent的方式上抛
    public void onEvent(MessageEvent event) {
        Message msg = event.getMessage();

        checkMessage(msg);
    }

    //用户离线期间收到的消息会以OfflineMessageEvent的方式上抛,处理方式类似上面的
    //MessageEvent
    public void onEvent(OfflineMessageEvent event) {
        List<Message> msgs = event.getOfflineMessageList();
        for (Message msg : msgs) {
            checkMessage(msg);
        }
    }

处理消息

//处理消息通知事件  需要注册绑定
JMessageClient.registerEventReceiver(context);//事件接收类的注册

JMessageClient.unRegisterEventReceiver(context);//事件接收类的解绑
private void checkMessage(Message msg) {
        switch (msg.getContentType()) {
            case text:
                //处理文字消息
                TextContent textContent = (TextContent) msg.getContent();
                final String message = textContent.getText();
                this.runOnUiThread(new Runnable() {
                    @Override
                    public void run() {
                        datas.add(new MessageBean(MessageBean.LEFT, message));
                        adapter.setNewData(datas);
                        adapter.reflush();
                    }
                });

//                adapter.notifyDataSetChanged();
                break;
            case image:
                //处理图片消息
                ImageContent imageContent = (ImageContent) msg.getContent();
                imageContent.getLocalPath();//图片本地地址
                imageContent.getLocalThumbnailPath();//图片对应缩略图的本地地址
                break;
            case voice:
                //处理语音消息
                VoiceContent voiceContent = (VoiceContent) msg.getContent();
                voiceContent.getLocalPath();//语音文件本地地址
                voiceContent.getDuration();//语音文件时长
                break;
            case custom:
                //处理自定义消息
                CustomContent customContent = (CustomContent) msg.getContent();
                customContent.getNumberValue("custom_num"); //获取自定义的值
                customContent.getBooleanValue("custom_boolean");
                customContent.getStringValue("custom_string");
                break;
            case eventNotification:
                //处理事件提醒消息
                EventNotificationContent eventNotificationContent = (EventNotificationContent) msg.getContent();
                switch (eventNotificationContent.getEventNotificationType()) {
                    case group_member_added:
                        //群成员加群事件
                        break;
                    case group_member_removed:
                        //群成员被踢事件
                        break;
                    case group_member_exit:
                        //群成员退群事件
                        break;
                    case group_info_updated://since 2.2.1
                        //群信息变更事件
                        break;
                }
                break;
            case unknown:
                // 处理未知消息,未知消息的Content为PromptContent 默认提示文本为“当前版本不支持此类型消息,请更新sdk版本”,上层可选择不处理
                PromptContent promptContent = (PromptContent) msg.getContent();
                promptContent.getPromptType();//未知消息的type是unknown_msg_type
                promptContent.getPromptText();//提示文本,“当前版本不支持此类型消息,请更新sdk版本”
                break;
        }
    }
  • 4
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 7
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值