在上班工作中的一个项目中使用到了百度推送,以前对推送一无了解,现将百度推送学习总结分享如下。
1、首先配置权限。
<!-- Push service 运行需要的权限 --> <uses-permission android:name="android.permission.INTERNET"/> <uses-permission android:name="android.permission.READ_PHONE_STATE" /> <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" /> <uses-permission android:name="android.permission.BROADCAST_STICKY" /> <uses-permission android:name="android.permission.WRITE_SETTINGS" /> <uses-permission android:name="android.permission.VIBRATE" /> <!-- for log. --> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> <uses-permission android:name="android.permission.ACCESS_DOWNLOAD_MANAGER"/> <uses-permission android:name="android.permission.DOWNLOAD_WITHOUT_NOTIFICATION" /> <uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW"/> <uses-permission android:name="android.permission.DISABLE_KEYGUARD" /> <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" /> <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" /> <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
2、客户端实现自己的Receiver(继承自BroadcastReceiver),用于处理当接收到推送消息时的处理响应事件。
<! -- push service client --> <receiver android:name="your.package.PushMessageReceiver"> <intent-filter> <! -- 接收 push 消息 --> <action android:name="com.baidu.android.pushservice.action.MESSAGE" /> <! -- 接收 bind、setTags 等 method 的返回结果 --> <action android:name="com.baidu.android.pushservice.action.RECEIVE" /> <! -- 可选。如果不声明,用户点击通知后,默认打开应用,如果在应用中进行了申明,点击通知消息时不会打开应用,应该在自己写的Receiver类里进行处理,如打开某个Activity,同时Receiver会接收到用户点击行为的intent,并获取通知的标题,内容或自定义内容等--> <action android:name=" com.baidu.android.pushservice.action.notification.CLICK” /> </intent-filter> </receiver>
if (intent.getAction().equals(PushConstants.ACTION_RECEIVER_NOTIFICATION_CLICK)) { // 通知标题 String title = intent.getStringExtra(PushConstants.EXTRA_NOTIFICATION_TITLE); // 通知内容 String content = intent.getStringExtra(PushConstants.EXTRA_NOTIFICATION_CONTENT); }
3、配置PushService服务
<! -- push service start --> <! -- 用于接收系统消息以保证 PushService 正常运行 --> <receiver android:name="com.baidu.android.pushservice.PushServiceReceiver" android:process=":bdservice_v1"> <intent-filter> <action android:name="android.intent.action.BOOT_COMPLETED" /> <action android:name="android.net.conn.CONNECTIVITY_CHANGE" /> <action android:name="com.baidu.android.pushservice.action.notification.SHOW" /> <action android:name="com.baidu.android.pushservice.action.media.CLICK" /> </intent-filter> </receiver> <! -- Push 服务接收客户端发送的各种请求--> <receiver android:name="com.baidu.android.pushservice.RegistratonReceiver" android:process=":bdservice_v1"> <intent-filter> <action android:name="com.baidu.android.pushservice.action.METHOD" /> <action android:name="com.baidu.android.pushservice.action.BIND_SYNC" /> </intent-filter> <intent-filter> <action android:name="android.intent.action.PACKAGE_REMOVED"/> <data android:scheme="package" /> </intent-filter> </receiver> <! -- Push 服务 --> <service android:name="com.baidu.android.pushservice.PushService" android:exported="true" android:process=":bdservice_v1"/> <! -- push service end -->
4、调用API
>>1. 在主 Activiy 的 OnCreate 方法中,调用接口 startWork,其中 loginValue 是百度账户的accessToken 或者是 ApiKey,由 loginType 决定。
PushManager.startWork(context, loginType, loginValue)
功能:完成 Push 服务的初始化, 并且完成自动 bind 工作
参数
context:当前执行 Context
loginType:String 绑定认证方式——无账号认证方式用 PushConstants.LOGIN_TYPE_API_KEY ;百度 Auth2.0 认证方式用
PushConstants.LOGIN_TYPE_ACCESS_TOKEN
loginValue: 和 loginType 对应,分别是应用的 API KEY,或者百度 Auth2.0 Access Token
>>2. 自定义通知样式(可选)
通知样式定制, 改变 Notification 里的铃声、震动、显示与消失行为,并定制通知栏的 layout、图标、标题、内容、状态栏图标等。
CustomPushNotificationBuilder cBuilder = new CustomPushNotificationBuilder(layoutId, layoutIconId, layoutTitleId, layoutTextId ); cBuilder.setNotificationFlags(Notification.FLAG_AUTO_CANCEL); cBuilder.setNotificationDefaults(Notification.DEFAULT_SOUND | Notification.DEFAULT_VIBRATE); cBuilder.setStatusbarIcon( statusbarIconId); cBuilder.setLayoutDrawable( notificationIconId); PushManager.setNotificationBuilder(this, notificationId, cBuilder);
>>3.客户端程序需要自己实现一个 BroadcastReceiver 来接收 Push 消息和接口回调
public class PushMessageReceiver extends BroadcastReceiver { public static final String TAG = PushMessageReceiver.class.getSimpleName(); @Override public void onReceive(final Context context, Intent intent) {if (intent.getAction().equals(PushConstants.ACTION_MESSAGE)) {// 处理push消息 String message = intent.getExtras().getString( PushConstants.EXTRA_PUSH_MESSAGE_STRING); Intent responseIntent = null; responseIntent = new Intent(PushDemoActivity.ACTION_MESSAGE); responseIntent.putExtra(PushDemoActivity.EXTRA_MESSAGE, message); responseIntent.setClass(context, PushDemoActivity.class); responseIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); context.startActivity(responseIntent); } else if (intent.getAction().equals(PushConstants.ACTION_RECEIVE)) {// 处理bind、setTags 等方法口的返回数据 final String method = intent .getStringExtra(PushConstants.EXTRA_METHOD); final int errorCode = intent .getIntExtra(PushConstants.EXTRA_ERROR_CODE, PushConstants.ERROR_SUCCESS); final String content = new String( intent.getByteArrayExtra(PushConstants.EXTRA_CONTENT)); Intent responseIntent = null; responseIntent = new Intent(PushDemoActivity.ACTION_RESPONSE); responseIntent.putExtra(PushDemoActivity.RESPONSE_METHOD, method); responseIntent.putExtra(PushDemoActivity.RESPONSE_ERRCODE, errorCode); responseIntent.putExtra(PushDemoActivity.RESPONSE_CONTENT, content); responseIntent.setClass(context, PushDemoActivity.class); responseIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); context.startActivity(responseIntent); } else if (intent.getAction().equals( PushConstants.ACTION_RECEIVER_NOTIFICATION_CLICK)) {// 处理用户点击通知消息时响应事件 Intent aIntent = new Intent(); aIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); aIntent.setClass(context, CustomActivity.class); String title = intent .getStringExtra(PushConstants.EXTRA_NOTIFICATION_TITLE); aIntent.putExtra(PushConstants.EXTRA_NOTIFICATION_TITLE, title); String content = intent .getStringExtra(PushConstants.EXTRA_NOTIFICATION_CONTENT); aIntent.putExtra(PushConstants.EXTRA_NOTIFICATION_CONTENT, content); context.startActivity(aIntent); } } }
5、常用的类和API
>>1.常用的类:
Class | 描述 |
PushManager | PushManager 提供了所有使用 Push 服务的静态方法 |
CustomPushNotificationBuilder |
提供了改变 Notification 里的铃声、 |
PushSettings | PushSettings 提供了端上 Push 服务的配置静态方法 |
>>2.API
method | detail | class.api |
Push 服务接口 | 提供 Push 服务 | startWork |
Tag 管理接口 | Tag 的创建与删除 | setTags(Context,List<String>),delTags(...) |
通知管理接口 | 自定义通知样式 |
CustomPushNotificationBuilder, setNotificationFlags, |
推送效果反馈 | 反馈推送通知的效果 | activityStarted, activityStoped |
设置接口 | Push 服务设置 | enableDebugMode |