版權聲明:本文爲HaiyuKing原創文章,轉載請註明出處!javascript
這個Demo只是記錄華爲推送的集成,不能運行。html
另外,由於可能用到存儲權限,因此還須要搭配運行時權限申請功能。java
注意事項:android
一、 導入類文件後須要change包名以及從新import R文件路徑web
二、 Values目錄下的文件(strings.xml、dimens.xml、colors.xml等),若是項目中存在,則複製裏面的內容,不要整個覆蓋json
參考官網《接入準備》api
註冊成爲開發者——》建立應用——》獲取PUSH服務參數 服務器
最終是要能得到appid值網絡
(1)下載HMS Agent套件app
(2)下載HMS SDK
由於如今大部分是使用Android Studio開發環境,因此直接使用Gradle+maven集成方式。
在項目的build.gradle文件中添加如下代碼
// Top-level build file where you can add configuration options common to all sub-projects/modules. buildscript { repositories { google() jcenter() } dependencies { classpath 'com.android.tools.build:gradle:3.2.1' // NOTE: Do not place your application dependencies here; they belong // in the individual module build.gradle files } } allprojects { repositories { google() jcenter() //<!-- ======================華爲推送SDK====================== --> maven {url 'http://developer.huawei.com/repo/'} } } task clean(type: Delete) { delete rootProject.buildDir }
爲了便於統一管理,我在demo中新建立了一個ThirdLib的module,集成華爲推送SDK都放到ThirdLib這個module中。
apply plugin: 'com.android.library'
android {
compileSdkVersion 28
defaultConfig {
minSdkVersion 16
targetSdkVersion 28
versionCode 1
versionName "1.0"
testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
}
}
dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
implementation 'com.android.support:appcompat-v7:28.0.0'
testImplementation 'junit:junit:4.12'
androidTestImplementation 'com.android.support.test:runner:1.0.2'
androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2'
//華爲推送SDK api 'com.huawei.android.hms:push:2.6.1.301'
}
apply plugin: 'com.android.application'
android {
compileSdkVersion 28
defaultConfig {
applicationId "com.why.project.hwpushdemo"
minSdkVersion 16
targetSdkVersion 28
versionCode 1
versionName "1.0"
testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
}
}
dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
implementation 'com.android.support:appcompat-v7:28.0.0'
implementation 'com.android.support.constraint:constraint-layout:1.1.3'
testImplementation 'junit:junit:4.12'
androidTestImplementation 'com.android.support.test:runner:1.0.2'
androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2'
//thirdlib implementation project(':thirdlib')
}
GetHMSAgent_cn.bat爲中文腳本
GetHMSAgent_oversea.bat爲英文腳本
此時,多了一個copysrc目錄
參考copysrc目錄下的AppManifestConfig.xml文件中的相關代碼和官網的資料!
注意,是app這個module,而不是thirdlib這個module!
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.why.project.hwpushdemo"> <!-- ======================華爲推送SDK====================== --> <!--HMS-SDK引導升級HMS功能,訪問OTA服務器須要網絡權限 | HMS-SDK upgrade HMS Feature, access to OTA server requires network privileges--> <uses-permission android:name="android.permission.INTERNET" /> <!--HMS-SDK引導升級HMS功能,保存下載的升級包須要SD卡寫權限 | HMS-SDK upgrade HMS Feature, save downloaded upgrade pack requires SD card Write permission--> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> <!--檢測網絡狀態 | Detecting Network status--> <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/> <!--檢測wifi狀態 | Detecting WiFi status--> <uses-permission android:name="android.permission.ACCESS_WIFI_STATE"/> <!--獲取用戶手機的IMEI,用來惟一的標識設備。 | Gets the IMEI of the user's phone, used to uniquely identify the device.--> <uses-permission android:name="android.permission.READ_PHONE_STATE"/> <!--若是是安卓8.0,應用編譯配置的targetSdkVersion>=26,請務必添加如下權限 --> <uses-permission android:name="android.permission.REQUEST_INSTALL_PACKAGES" /> <!-- 接收PUSH TOKEN的廣播以及PUSH消息須要定義該權限 ${PACKAGE_NAME} 要替換上您應用的包名 --> <permission android:name="${applicationId}.permission.PROCESS_PUSH_MSG" android:protectionLevel="signatureOrSystem"/> <!--接收PUSH TOKEN的廣播以及PUSH消息須要定義該權限 ${PACKAGE_NAME} 要替換上您應用的包名 --> <uses-permission android:name="${applicationId}.permission.PROCESS_PUSH_MSG" /> <application android:allowBackup="true" android:icon="@mipmap/ic_launcher" android:label="@string/app_name" android:roundIcon="@mipmap/ic_launcher_round" android:supportsRtl="true" android:theme="@style/AppTheme"> <activity android:name=".MainActivity"> <intent-filter> <action android:name="android.intent.action.MAIN"/> <category android:name="android.intent.category.LAUNCHER"/> </intent-filter> </activity> <!-- ======================華爲推送SDK====================== --> <!-- 接入HMSSDK 須要註冊的appid參數。value的值中「100222233444」用實際申請的appid替換,來源於開發者聯盟網站應用的權益詳情。 格式 android:value="appid=xxxxxx" Access HMSSDK need to register AppID parameters. Value "100223344" is replaced with the actual application APPID, derived from the Developer affiliate website application. Format android:value= "appid=xxxxxx"--> <meta-data android:name="com.huawei.hms.client.appid" android:value="appid=1000222233444"/> <!-- 接入HMSSDK 須要註冊的activity | Access HMSSDK activity to be registered 定義了HMS-SDK中一些跳轉所須要的透明頁面--> <activity android:name="com.huawei.hms.activity.BridgeActivity" android:configChanges="orientation|locale|screenSize|layoutDirection|fontScale" android:excludeFromRecents="true" android:exported="false" android:hardwareAccelerated="true" android:theme="@android:style/Theme.Translucent" > <meta-data android:name="hwc-theme" android:value="androidhwext:style/Theme.Emui.Translucent" /> </activity> <!-- 接入HMSSDK 須要註冊的activity | Access HMSSDK activity to be registered 是應用自升級接口所須要使用的頁面--> <activity android:name="com.huawei.updatesdk.service.otaupdate.AppUpdateActivity" android:configChanges="orientation|screenSize" android:exported="false" android:theme="@style/upsdkDlDialog" > <meta-data android:name="hwc-theme" android:value="androidhwext:style/Theme.Emui.Translucent.NoTitleBar" /> </activity> <!-- 接入HMSSDK 須要註冊的activity | Access HMSSDK activity to be registered 是應用自升級接口所須要使用的頁面--> <activity android:name="com.huawei.updatesdk.support.pm.PackageInstallerActivity" android:configChanges="orientation|keyboardHidden|screenSize" android:exported="false" android:theme="@style/upsdkDlDialog" > <meta-data android:name="hwc-theme" android:value="androidhwext:style/Theme.Emui.Translucent" /> </activity> <!-- 接入HMSSDK 須要註冊的provider,authorities 必定不能與其餘應用同樣,因此這邊 com.why.project.hwpushdemo 要替換上您應用的包名 Access HMSSDK need to register provider,authorities must not be the same as other applications, so this side ${package_name} to replace the package name you applied 用於應用自升級--> <provider android:name="com.huawei.updatesdk.fileprovider.UpdateSdkFileProvider" android:authorities="com.why.project.hwpushdemo.updateSdk.fileProvider" android:exported="false" android:grantUriPermissions="true"> </provider> <!-- 接入HMSSDK 須要註冊的應用下載服務 | Access HMSSDK need to register app download service 用於應用自升級--> <service android:name="com.huawei.updatesdk.service.deamon.download.DownloadService" android:exported="false"/> <!-- 使用 HMSAgent 代碼接入HMSSDK 須要註冊的activity | Use hmsagent code to access HMSSDK activity that requires registration--> <!--解決華爲移動服務升級問題的透明界面(必須聲明)--> <activity android:name="com.huawei.android.hms.agent.common.HMSAgentActivity" android:configChanges="orientation|locale|screenSize|layoutDirection|fontScale" android:excludeFromRecents="true" android:exported="false" android:hardwareAccelerated="true" android:theme="@android:style/Theme.Translucent" > <meta-data android:name="hwc-theme" android:value="androidhwext:style/Theme.Emui.Translucent" /> </activity> <!-- 接入HMSSDK 須要註冊的provider,authorities 必定不能與其餘應用同樣,因此這邊 com.why.project.hwpushdemo 要替換上您應用的包名 Access HMSSDK need to register provider,authorities must not be the same as other applications, so this side ${package_name} to replace the package name you applied 用於HMS-SDK引導升級HMS,提供給系統安裝器讀取升級文件--> <provider android:name="com.huawei.hms.update.provider.UpdateProvider" android:authorities="com.why.project.hwpushdemo.hms.update.provider" android:exported="false" android:grantUriPermissions="true"/> <!-- 接入HMSSDK PUSH模塊須要註冊,第三方相關 :接收Push消息(註冊、Push消息、Push鏈接狀態)廣播, 此receiver類須要開發者本身建立並繼承com.huawei.hms.support.api.push.PushReceiver類, 參考示例代碼中的類:com.huawei.hmsagent.HuaweiPushRevicer Access to the HMSSDK push module requires registration: Receive push message (registration, push message, push connection state) broadcast. This receiver class requires the developer to create and inherit the com.huawei.hms.support.api.push.PushReceiver class. Reference to class in sample code: Com.huawei.hmsagent.HuaweiPushRevicer--> <!--用來接收PUSH消息的receiver--> <!-- 接入HMSSDK PUSH模塊須要註冊,第三方相關 :接收Push消息(註冊、Push消息、Push鏈接狀態)廣播, 此receiver類須要開發者本身建立並繼承com.huawei.hms.support.api.push.PushReceiver類, 參考示例代碼中的類:com.huawei.hmsagent.HuaweiPushRevicer Access to the HMSSDK push module requires registration: Receive push message (registration, push message, push connection state) broadcast. This receiver class requires the developer to create and inherit the com.huawei.hms.support.api.push.PushReceiver class. Reference to class in sample code: Com.huawei.hmsagent.HuaweiPushRevicer--> <receiver android:name="com.why.project.hwpushdemo.huaweipush.HuaweiPushRevicer" > <intent-filter> <!-- 必須,用於接收token | Must, for receiving token --> <action android:name="com.huawei.android.push.intent.REGISTRATION" /> <!-- 必須,用於接收消息 | Must, used to receive messages--> <action android:name="com.huawei.android.push.intent.RECEIVE" /> <!-- 可選,用於點擊通知欄或通知欄上的按鈕後觸發onEvent回調 | Optional, click the button on the notification bar or the notification bar to trigger the onevent callback --> <action android:name="com.huawei.android.push.intent.CLICK" /> <!-- 可選,查看push通道是否鏈接,不查看則不須要 | Optional, query whether the push channel is connected or not --> <action android:name="com.huawei.intent.action.PUSH_STATE" /> </intent-filter> </receiver> <!-- 接入HMSSDK PUSH模塊須要註冊 :接收通道發來的通知欄消息 | The access HMSSDK push module needs to be registered: the notification bar message sent from the receiving channel --> <!--接收通道發來的通知欄消息--> <receiver android:name="com.huawei.hms.support.api.push.PushEventReceiver" > <intent-filter> <action android:name="com.huawei.intent.action.PUSH" /> </intent-filter> </receiver> <!-- 華爲推送自定義動做打開的界面【須要透明】,須要注意scheme必須設置惟一的,和手機上其餘的APP使用的scheme不同 --> <!--hwdemoscheme://{包名}/notify_detail?title={標題}&content={內容}--> <activity android:name="com.why.project.hwpushdemo.huaweipush.HWpushActivity" android:theme="@android:style/Theme.Translucent"> <intent-filter> <action android:name="android.intent.action.VIEW"/> <category android:name="android.intent.category.DEFAULT"/> <data android:host="${applicationId}" android:path="/notify_detail" android:scheme="hwdemoscheme"/> </intent-filter> </activity> </application> </manifest>
一、appid須要換成本身的;
二、將黃色標記的代碼中的包名(com.why.project.hwpushdemo)所有替換成本身的包名(若是是從copysrc的AppManifestConfig.xml文件複製的代碼,直接是本身的包名);
三、HuaweiPushRevicer【華爲推送的回調,好比獲取token】的完整路徑須要更換成真實的;
四、HWpushActivity【點擊通知後打開的界面】的完整路徑須要更換成真實的;
五、HWpushActivity下的host、path、scheme要換成本身項目的,另外這三個字段的值在推送的時候用的到;
其中,HuaweiPushRevicer不用管,HWpushActivity須要根據實際狀況修改下,activity_hwpush.xml文件不用管,就是個空佈局。
package com.why.project.hwpushdemo.huaweipush; import android.app.Activity; import android.content.Context; import android.content.Intent; import android.os.Bundle; import android.util.Log; import com.why.project.hwpushdemo.R; import org.json.JSONObject; /** * Created by HaiyuKing * Used 華爲推送自定義動做打開的界面【華爲推送SDK】 * https://www.jianshu.com/p/3b0df1c976a5 * https://blog.csdn.net/gaoshang0304/article/details/80463246 * https://blog.csdn.net/nsacer/article/details/80346965 * https://blog.csdn.net/u013904672/article/details/71079278 */ public class HWpushActivity extends Activity { private static final String TAG = HWpushActivity.class.getSimpleName(); private Context mContext; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_hwpush); mContext = this; //獲取自定義動做的值 Intent intent = getIntent(); String intentUri = intent.toUri(Intent.URI_INTENT_SCHEME); Log.e(TAG,"action是:" + intentUri); //intent://com.why.project.hwpushdemo/notify_detail?title=測試標題&content=測試內容&exTraTitle=界面標題&url=http://www.baidu.com#Intent;scheme=hwdemoscheme;launchFlags=0x13000000;component=com.why.project.hwpushdemo/.huaweipush.HWpushActivity;end //關閉當前界面,跳轉到指定的界面 try { String title = getIntent().getData().getQueryParameter("title"); String content = getIntent().getData().getQueryParameter("content"); String exTraTitle = getIntent().getData().getQueryParameter("exTraTitle"); String url = getIntent().getData().getQueryParameter("url"); JSONObject extraJson = new JSONObject(); extraJson.put("exTraTitle",exTraTitle); extraJson.put("url",url); Bundle bundle = new Bundle(); bundle.putString(JPushInterface.EXTRA_NOTIFICATION_TITLE,title);//通知的標題 bundle.putString(JPushInterface.EXTRA_ALERT,content);//通知內容 bundle.putString(JPushInterface.EXTRA_EXTRA,extraJson.toString());//通知附加字段 bundle.putInt(JPushInterface.EXTRA_NOTIFICATION_ID,0);//通知id值【沒什麼用】 Intent i = new Intent(mContext, JpushActivity.class); i.putExtras(bundle); i.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);//必須使用這個,這個保證了多個通知,點擊返回返回到的是上一個通知界面 mContext.startActivity(i); finish(); } catch (Exception e){ e.printStackTrace(); } } }
這裏稍微講解下,這個activity的主要做用是下面兩點:
一、獲取自定義動做的值;
二、關閉當前界面,跳轉到指定的界面(傳值過去);
上面代碼中跳轉界面那裏(橙色標記的代碼),是須要根據實際狀況修改的。
package com.why.project.hwpushdemo; import android.content.Context; import android.content.Intent; import android.content.res.Resources; import android.os.Bundle; import android.support.v7.app.AppCompatActivity; import android.support.v7.widget.Toolbar; import android.view.KeyEvent; import android.view.View; import android.widget.TextView; import org.json.JSONException; import org.json.JSONObject; /** * Used 極光推送點開通知後打開的界面 * 和WebViewPreviewActivity共用一個佈局文件 * 須要先檢查是否已經登陸,若是沒有登陸,直接登陸便可,不須要返回到登陸界面了 * 極光推送SDK */ public class JpushActivity extends AppCompatActivity { private static final String TAG = JpushActivity.class.getSimpleName(); /**從登陸界面打開的標記(傳遞參數用)*/ public static final String EXTRA_ONLOGIN = "onlogin"; /*Jpush傳遞過來的參數*/ private Bundle jPushBundle; /**通知標題*/ private String jPushTitle; /**通知內容*/ private String jPushContent; /**通知附加字段*/ private String jPushExtraJson; /**通知id值*/ private int jPushId; //展示在導航欄上的標題 private String bundle_title; //網頁url地址 private String bundle_url; /**標記是否從登陸界面打開的狀態值*/ private boolean bundle_onlogin = false; private Context mContext; private Toolbar mToolbar; private MyWebView myWebView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_webviewpreview); mContext = this; //初始化控件 initViews(); //初始化數據 initData(); initToolBar();//初始化toolbar } @Override public void onDestroy() { //銷燬webview控件 myWebView.removeAllViews(); myWebView.destroy(); super.onDestroy(); } /** * 初始化view */ private void initViews() { myWebView = (MyWebView)findViewById(R.id.id_webView); myWebView.setCanBackPreviousPage(true,JpushActivity.this);//能夠返回上一頁 } /** * 初始化數據【接收點擊通知欄傳過來的數據:通知、自定義消息兩種(這裏只須要處理通知的便可)】 */ private void initData() { Intent intent = getIntent(); if (null != intent) { jPushBundle = getIntent().getExtras(); jPushTitle = jPushBundle.getString(JPushInterface.EXTRA_NOTIFICATION_TITLE);//保存服務器推送下來的通知的標題 jPushContent = jPushBundle.getString(JPushInterface.EXTRA_ALERT);//保存服務器推送下來的通知內容 jPushExtraJson = jPushBundle.getString(JPushInterface.EXTRA_EXTRA);//保存服務器推送下來的附加字段。這是個 JSON 字符串 jPushId = jPushBundle.getInt(JPushInterface.EXTRA_NOTIFICATION_ID);//SDK 1.3.5 以上版本支持,通知欄的Notification ID,能夠用於清除Notification bundle_onlogin = jPushBundle.getBoolean(EXTRA_ONLOGIN); } if(!jPushExtraJson.equals("")){ try { JSONObject extraJsonObj = new JSONObject(jPushExtraJson); if(extraJsonObj.has("from")){ extraJsonObj = new JSONObject(extraJsonObj.getString("from")); } if(!extraJsonObj.getString("exTraTitle").equals("")){ //獲取標題 bundle_title = extraJsonObj.getString("exTraTitle"); } if(!extraJsonObj.getString("url").equals("")){ //獲取網頁地址 bundle_url = extraJsonObj.getString("url"); } } catch (Resources.NotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (JSONException e) { // TODO Auto-generated catch block e.printStackTrace(); } } if(! bundle_onlogin){//若是是從登陸界面打開的話,那麼不用驗證了 initCheckLoginState();//驗證是否須要從新登陸 }else{ loadWebUrl();//打開網頁 } } private void initToolBar() { mToolbar = findViewById(R.id.toolbar_base); mToolbar.setTitle("");//這樣設置的話,自帶的標題就不會顯示 //設置自定義的標題(居中) TextView toolBarTitle = mToolbar.findViewById(R.id.toolbarTitle); toolBarTitle.setText(bundle_title); setSupportActionBar(mToolbar);//因爲toolbar只是一個普通控件,咱們將ToolBar設置爲ActionBar //設置導航圖標要在setSupportActionBar方法以後 mToolbar.setNavigationIcon(R.drawable.nav_back);//設置爲空的話,就會不顯示左側的圖標 //對NavigationIcon添加點擊 mToolbar.setNavigationOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { //返回到首頁界面(從新登陸的狀況下)或者直接關閉本身(不須要從新登陸的狀況下) backHomeOrFinish(); } }); } /** * 點擊返回鍵 * event.getRepeatCount() == 0:點後退鍵的時候,爲了防止點得過快,觸發兩次後退事件,故作此設置。 */ @Override public boolean onKeyDown(int keyCode, KeyEvent event) { // TODO Auto-generated method stub if (keyCode == KeyEvent.KEYCODE_BACK && event.getRepeatCount() == 0) { //返回到首頁界面(若是是從登陸界面打開的)或者關閉本身(從通知打開的) backHomeOrFinish(); } return super.onKeyDown(keyCode, event); } //返回功能 private void backHomeOrFinish() { if (bundle_onlogin) { ActivityJump.NormalJumpAndFinish(JpushActivity.this, HomeActivity.class); } else { ActivityJump.Back(this); } } /** * 網絡請求檢查登陸狀態,主要判斷是否在線 */ private void initCheckLoginState() { if(result.indexOf("alert(") != -1){ //登錄身份失效,請從新登錄 ActivityJump.BundleJumpAndFinish(JpushActivity.this, LoginActivity.class,jPushBundle); } else{ loadWebUrl();//加載網頁 } } /** * 加載URL地址 */ private void loadWebUrl() { syncCookie(JpushActivity.this, ServerApi.SERVER_URL); if (!bundle_url.equals("")) { myWebView.loadWebUrl(ServerApi.SERVER_URL + bundle_url); } else { myWebView.loadUrl("about:blank");//加載一個空白頁 } } /** * Sync Cookie */ public static void syncCookie(Context context, String url){ //參考本博客的《okhttputils【 Android 一個改善的okHttp封裝庫】使用(二)》 } }
在application的onCreate方法中初始化HMSAgent。若是沒有本身的application類,請建立並在manifest文件中配置application節點的name屬性。
package com.why.project.hwpushdemo; import android.app.Application; import com.huawei.android.hms.agent.HMSAgent; /** * Created by HaiyuKing * Used */ public class MyApplication extends Application { @Override public void onCreate() { super.onCreate(); //華爲推送SDK initHuaWeiPush(); } //華爲推送SDK private void initHuaWeiPush(){ HMSAgent.init(this); } @Override public void onTerminate() { super.onTerminate(); //華爲推送SDK HMSAgent.destroy(); } }
建議在應用啓動時調用Connect。在哪一個Activity中調用,哪一個Activity的alertDialog不彈出,返回軟鍵點擊後無響應。
package com.why.project.hwpushdemo; import android.content.Context; import android.content.Intent; import android.os.Bundle; import android.support.v7.app.AppCompatActivity; import com.huawei.android.hms.agent.HMSAgent; import com.huawei.android.hms.agent.common.handler.ConnectHandler; import com.huawei.android.hms.agent.push.handler.GetTokenHandler; import com.why.project.hwpushdemo.huaweipush.HuaweiPushRevicer; import static com.why.project.hwpushdemo.huaweipush.HuaweiPushRevicer.ACTION_TOKEN; import static com.why.project.hwpushdemo.huaweipush.HuaweiPushRevicer.ACTION_UPDATEUI; /** * Created by HaiyuKing * Used */ public class WelcomeActivity extends AppCompatActivity implements HuaweiPushRevicer.IPushCallback{ private static final String TAG = WelcomeActivity.class.getSimpleName(); private Context mContext; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_welcome); mContext = this; /*====華爲推送SDK相關=======*/ HuaweiPushRevicer.registerPushCallback(this); /*========================華爲推送SDK相關=======================*/ HMSAgent.connect(this, new ConnectHandler() { @Override public void onConnect(int rst) { LogUtil.d(TAG,"HMS connect end:" + rst); //Push的Token會過時和失效,應用集成Push後,推薦在每次啓動應用時調用getToken方法申請Token,該方法能夠重複調用,在有效期內得到的Token值不會變化。 //建議在應用的首個Activity的onCreate方法中,調用申請token接口。【爲何呢?由於若是在HomeActivity中調用的,alertDialog不彈出,返回軟鍵點擊後無響應】 LogUtil.d(TAG,"get token: begin"); HMSAgent.Push.getToken(new GetTokenHandler() { @Override public void onResult(int rtnCode) { LogUtil.d(TAG,"get token: end code=" + rtnCode); } }); } }); //檢查應用升級,暫時用不到 /*HMSAgent.checkUpdate(this, new CheckUpdateHandler() { @Override public void onResult(int rst) { LogUtil.d(TAG,"check app update end:" + rst); } });*/ } @Override protected void onDestroy() { super.onDestroy(); /*====華爲推送SDK相關=======*/ HuaweiPushRevicer.unRegisterPushCallback(this); } @Override public void onReceive(Intent intent) { //===============華爲推送SDK相關=============== //其實放在這裏有個風險,那就是可能執行不到這裏,由於時間短,尚未等到返回數據就執行onDestory方法了 if (intent != null) { String action = intent.getAction(); Bundle b = intent.getExtras(); if (b != null && ACTION_TOKEN.equals(action)) { String hwToken = b.getString(ACTION_TOKEN); LogUtil.e(TAG,"hwToken="+hwToken); //保存數據,HomeActivity中用獲得 PreferencesUtils.putString(mContext,Globals.HWPUSH_TOKEN_KEY,hwToken); } else if (b != null && ACTION_UPDATEUI.equals(action)) { String log = b.getString("log"); LogUtil.e(TAG,log); } } } }
Globals.java文件
package com.why.project.hwpushdemo; /** * Created by HaiyuKing * Used */ public class Globals { /*=======================================華爲推送SDK相關=============================================*/ //華爲推送的token值 public static final String HWPUSH_TOKEN_KEY = "HWPushToken"; }
package com.why.project.hwpushdemo; import android.content.Context; import android.os.Bundle; import android.support.v7.app.AppCompatActivity; public class MainActivity extends AppCompatActivity { private static final String TAG = WelcomeActivity.class.getSimpleName(); private Context mContext; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mContext = this; /*====華爲推送SDK相關=======*/ getToken(); } /*========================華爲推送SDK相關======start====================*/ private void getToken(){ String hwToken = PreferencesUtils.getString(mContext,Globals.HWPUSH_TOKEN_KEY,""); LogUtil.e(TAG,"hwToken="+hwToken); requestDeviceId(hwToken);//判斷是請求接口仍是彈出對話框 } //請求接口存儲設備id或者token的方法 private void requestDeviceId(String regId) { //首要條件是設備id值或者token值不爲空,不然下面的判斷沒有意義了 //若是沒有設置過別名,或者則須要設置別名 //若是服務器上的deviceID值是空值,代表當前用戶尚未綁定任何設備,則直接請求接口,不須要彈出對話框; //若是服務器上的deviceID值不爲空,而且客戶端獲取的設備id值和服務器上的deviceID值相同,則不須要彈出對話框,直接請求接口(這個是卸載從新安裝的狀況) //若是服務器上的deviceid值不爲空,而且客戶端獲取的設備id值和服務器上的deviceID值不一樣,則須要彈出對話框(這個是換設備的狀況) //若是已經設置過別名(存儲過了設備id值)了,可是當前的別名(設備id值)和服務器上的不一致,則須要從新設置別名(存儲設備id值)(這個是其餘設備上登陸的狀況) } }
參考官網《發送消息》
# Add project specific ProGuard rules here.
# You can control the set of applied configuration files using the
# proguardFiles setting in build.gradle.
#
# For more details, see
# http://developer.android.com/guide/developing/tools/proguard.html
# If your project uses WebView with JS, uncomment the following
# and specify the fully qualified class name to the JavaScript interface
# class:
#-keepclassmembers class fqcn.of.javascript.interface.for.webview {
# public *;
#}
# Uncomment this to preserve the line number information for
# debugging stack traces.
#-keepattributes SourceFile,LineNumberTable
# If you keep the line number information, uncomment this to
# hide the original source file name.
#-renamesourcefileattribute SourceFile
#=====================華爲推送SDK===================== #注意:不要混淆HMS SDK自帶的資源文件。部分應用和遊戲會混淆工程中的全部資源文件,請注意不要混淆HMS SDK的相關資源文件。 -ignorewarning -keepattributes *Annotation* -keepattributes Exceptions -keepattributes InnerClasses -keepattributes Signature -keepattributes SourceFile,LineNumberTable -keep class com.hianalytics.android.**{*;} -keep class com.huawei.updatesdk.**{*;} -keep class com.huawei.hms.**{*;} -keep class com.huawei.android.hms.agent.**{*;} -keep class com.huawei.gamebox.plugin.gameservice.**{*;}
集成華爲推送,華爲手機App在活動點開推送重啓App而且未進入到推送落地頁
連接:https://pan.baidu.com/s/13fw_2o4FGzdV9Q5-s-mxiw 提取碼:qhk4