當APP不在前景執行時,能夠用自己的平台或伺服器發送通知給行動的一項技術。在iOS平台上有APNS(Apple Push Notification Service),而Android平台上則叫做GCM(Google Cloud Messaging),在今天我們先以Android的GCM搭配BaaS服務Kinvey為例子。
Google Cloud Messaging
1.進入網站 https://console.developers.google.com
data:image/s3,"s3://crabby-images/6a25a/6a25a6ec494affbedba4051295e25328d9e66dc0" alt="07"
2.輸入專案名稱跟專案ID
data:image/s3,"s3://crabby-images/521d5/521d5fdbd30fe9a36c8e14045fdf8cc17dc227e0" alt="08"
3.完成後,記得專案編號(等等在其他設定會用到)
data:image/s3,"s3://crabby-images/63202/63202051b3f38a0d214646cf5bc85a7eb5568c45" alt="09"
4.接著點選API 找到 Google Cloud Messageing for Anroid 後按關閉按鈕打開
data:image/s3,"s3://crabby-images/df4cd/df4cdd9f43833ead1ca9ae08eea5584947f1e464" alt="11"
data:image/s3,"s3://crabby-images/7db31/7db310ba00446a6a42f641ff05c0fc8b83fc3af1" alt="12"
五、點選建立新的金鑰
data:image/s3,"s3://crabby-images/7398f/7398f908fb232629f95ad4c803b68c4163edf209" alt="13"
六、點選伺服器金鑰
data:image/s3,"s3://crabby-images/00a2f/00a2fa515c782acc4cfbf06ac2ec676806016975" alt="14"
七、如果沒有特別允許使用IP可以略過後按建立就行了
data:image/s3,"s3://crabby-images/91504/91504c33e322c6dd01864f7dd7576d4002ffa894" alt="15"
八、一樣要記得API金鑰
data:image/s3,"s3://crabby-images/8a215/8a2151b5b5058145b35ecd1fd614b73f398896de" alt="17"
kinvey申請
在行動裝置的開發領域目前有個BaaS(後端即服務:Backend as a Service)的技術概念。BaaS是指為行動裝置開發者提供整合雲端的基礎服務,像是資料/文件的儲存或是帳號管理、訊息推送、社群網路整合等….
而在Delphi XE6中支援二個熱門的服務為Kinvey及Parse,在這邊我們以Kinvey做為例子。
1.進入Kinvey網站(http://www.kinvey.com/)按下Sign Up註冊
data:image/s3,"s3://crabby-images/592b8/592b807edc9ffa81a114348154a25c3e139a8300" alt="01"
2.註冊帳號只要電子郵件跟密碼就行了
data:image/s3,"s3://crabby-images/730b2/730b209fcc74be98e28ce40fb6758bbb011ac4ab" alt="02"
3.點選Individual 個人帳戶的Get Started即可
data:image/s3,"s3://crabby-images/f62ce/f62ce42d9f46199b813c00c625347c0de11b5017" alt="03"
4.接著建立一個新的專案,平台的話選擇Other(其他)的REST API即可
data:image/s3,"s3://crabby-images/e73bd/e73bd2217122ddf9021a900287ea3ab394494f7f" alt="04"
5.建立完成後,右下角的API Keys要記下來data:image/s3,"s3://crabby-images/c997c/c997c0b28e50a127eb5578a7b983805e99f8e2ac" alt="06"
6.接著我們要建立可以存取服務的使用者,點選上面的Addons,在Core內有Users點入data:image/s3,"s3://crabby-images/2b39c/2b39ca9ef5337b6832f21e24e39c953dc435aa13" alt="22"
7.接著點選Add User新增使用者data:image/s3,"s3://crabby-images/ba215/ba2155e69e9edad92ab75010eb1f48387d2747b7" alt="23"
8.只要輸入帳號密碼就可以,我們建立一個test使用者data:image/s3,"s3://crabby-images/0c404/0c404d899ac9a448d19ac3d84b37ff97eb10b6c0" alt="24"
9. 建立完成後可以看見使用者列表
data:image/s3,"s3://crabby-images/099d1/099d164b32dc0b73f308eda893b39e17441b50f4" alt="25"
10.接著建立待會使用的 Push Notification,一樣在Addons的目錄下有一個Messaging,裡面有一個Push
data:image/s3,"s3://crabby-images/fb346/fb346f3416add273a0b79ced237b5b881d94fbb6" alt="18"
11.接著我們將剛才在Google控制台的專案編號填入Project ID、API金鑰填入API Key,接著按下Save GCM Configuration。右上角會由inactive轉為active。這樣就完成了相關的申請跟設定,不過先別關掉它。等等會再使用到!
data:image/s3,"s3://crabby-images/363f3/363f355a42ef5e895bffa26ed3c9abe22f8ac73d" alt="21"
程式開發
1.我們延續剛才的通知範例,在畫面加上ListView元件,將Align設為Bottom
data:image/s3,"s3://crabby-images/c839d/c839dbe44a8389ceb86dabbe5f8d55916f6d8b8e" alt="螢幕快照 2014-06-17 下午3.40.05"
2.接著在畫面上放上二個元件,一個是TKinveyProvider以及TPushEvents
data:image/s3,"s3://crabby-images/6cb04/6cb0444b09f3ae17f0a98901ff9798180ba0abbc" alt="螢幕快照 2014-06-17 下午3.40.38"
data:image/s3,"s3://crabby-images/d0379/d03797a216f91f0547bfcf196b6776ae752f9f96" alt="螢幕快照 2014-06-17 下午3.41.01"
3.PushEvents1中的AutoActivate、AutoRegisterDevice設為True以及Provider指定KinveyProvider1
data:image/s3,"s3://crabby-images/3233c/3233c255b68100882752d61aa3b8bde3ae870986" alt="螢幕快照 2014-06-17 下午3.41.33"
4.設定 OnPushReceived事件,在裡面的程式寫上
data:image/s3,"s3://crabby-images/11e79/11e79e6c1d9602972087815ecf0b1d18b38e1f2a" alt="螢幕快照 2014-06-17 下午3.42.21"
1
2
3
4
5
|
procedure TForm1.PushEvents1PushReceived(Sender: TObject;
const AData: TPushData);
begin
ListView1.Items.Add.Text := AData.Message;
end;
|
5.接著在KinveyProvider1設定相關參數
data:image/s3,"s3://crabby-images/408a5/408a59f23b1c8d7c67930c1a3cb1975e7a32344e" alt="螢幕快照 2014-06-17 下午3.43.31"
6.最後開啟專案目錄下的AndroidManifest.template.xml(這個檔案是Delphi編譯過程中產生AndroidManifest.xml的範本檔。
在幾個位置加入設定
.<%uses-permisson%>後面加上
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
<!-- GCM connects to Google Services. -->
<uses-permission android:name= "android.permission.INTERNET" />
<!-- GCM requires a Google account. -->
<uses-permission android:name= "android.permission.GET_ACCOUNTS" />
<!-- Keeps the processor from sleeping when a message is received. -->
<uses-permission android:name= "android.permission.WAKE_LOCK" />
<!--
Creates a custom permission so only this app can receive its messages.
NOTE: the permission *must* be called PACKAGE.permission.C2D_MESSAGE,
where PACKAGE is the application's package name.
-->
<permission android:name= "%package%.permission.C2D_MESSAGE"
android:protectionLevel= "signature" />
<uses-permission android:name= "%package%.permission.C2D_MESSAGE" />
<!-- This app has permission to register and receive data message. -->
<uses-permission
android:name= "com.google.android.c2dm.permission.RECEIVE" />
|
.</intent-filter></activity> 後面加上
1
2
3
4
5
6
7
8
|
<receiver
android:name= "com.embarcadero.gcm.notifications.GCMNotification" android:exported= "true"
android:permission= "com.google.android.c2dm.permission.SEND" >
<intent-filter>
<action android:name= "com.google.android.c2dm.intent.RECEIVE" />
<category android:name= "%package%" />
</intent-filter>
</receiver>
|
接著就可以執行程式了!
程式執行後,我們回到Kinvey網站,輸入要推播的訊息後按 Send Push Notification
data:image/s3,"s3://crabby-images/2b6c2/2b6c2ccbd89951d32b519900f77df7b35de0f1cc" alt="pushmessage"
可以看到程式的Listview會出現推播的訊息。
data:image/s3,"s3://crabby-images/7062f/7062f53b18247e11796fe5f56795b09fb64280ac" alt="1907712_10152077090231541_3460962835102390423_n"
最後附上原始碼
https://github.com/superlevin/xe6notification