Android - 极光推送 即时通讯

Android - 极光推送 即时通讯,第1张

概述极光推送即时通讯准备应用集成极光推送sdk准备应用Demo项目地址github打开极光官网链接:极光到极光推送官方网站注册开发者帐号;登录进入管理控制台,创建应用程序,得到Appkey(SDK与服务器端通过Appkey互相识别);在推送设置中给Android设置包名、给iOS上

极光推送 即时通讯准备应用集成极光推送sdk

准备应用

Demo 项目地址github

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

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

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

集成sdk

集成极光推送sdk

Jcenter 自动集成步骤

@H_301_44@使用 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.gradledefaultConfig{	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;        }    }
总结

以上是内存溢出为你收集整理的Android - 极光推送 即时通讯全部内容,希望文章能够帮你解决Android - 极光推送 即时通讯所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1055244.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-25
下一篇 2022-05-25

发表评论

登录后才能评论

评论列表(0条)

保存