IOS開發--第四階段--推送伺服器的實現,ios第四階段
在編寫push notification之擷取device token中拿到device token以後,需要把token字串發送給應用的伺服器端,即provider。
provider將token號、通知內容、通知形式(比如是否彈出提示視窗、是否發聲等)發送給蘋果的伺服器(apns)。
最簡單的provider實現,其實就是通過認證,和蘋果伺服器建立安全連線(tsl或ssl),通過認證建立串連後,向蘋果伺服器發送符合蘋果要求的資料流。
獲得認證
蘋果提供兩種接入方式的認證:
- developer,用於測試
- production,用於產品
如果是自我裝載,使用developer方式即可。
下載認證,通過ios provisioning portal:
這要求:
- 登入的apple developer program帳號必須是層級最高的agent(這是針對企業帳號來說的,如果是個人帳號就無所謂了),agent帳號即創始帳號,否則看不到configure連結;
- 必須經過configure操作,已經enable了developer和product。
然後進入configure連結,點擊download按鈕即可:
處理認證
如果是編寫在mac下跑的objc程式,無需對認證做處理,可跳過這一步。
如果是在java下使用,需要把打認證用的私人專用密鑰和上述的支援通知的認證(注意,不是iphone developer認證)合并匯出。
產生認證:
點擊儲存的時候,會提示產生一個檔案密碼:
當然可以密碼為空白。
之後會提示:
這裡需要輸入mac登入使用者的密碼。
檔案產生。
編寫發送通知的執行個體
如果是編寫mac代碼,有一個現成的項目可用:http://stefan.hafeneger.name/download/PushMeBabySource.zip
匯入到xcode中,只需將:
deviceToken填寫成裝置的token字串,另外,pathForResource改為上面圖中的:
aps_developer_identity
另外,要把剛才獲得認證步驟中下載的認證複製到xcode項目Resources目錄下:
可以看到檔案名稱和上面的pathForResource的參數一致。
之後運行程式就可以在裝置上收到推播通知。
如果是用java編寫,可以用第三方庫,見:
http://code.google.com/p/javapns/
編寫簡單的發送通知代碼:
import org.json.JSONException;
import javapns.back.PushNotificationManager;
import javapns.back.SSLConnectionHelper;
import javapns.data.Device;
import javapns.data.PayLoad;
public class Main {
/**
* @param args
* @throws Exception
*/
public static void main(String[] args) throws Exception {
PayLoad simplePayLoad = new PayLoad();
// Get PushNotification Instance
PushNotificationManager pushManager = PushNotificationManager.getInstance();
// Link iPhone’s UDID (64-char device token) to a stringName
pushManager.addDevice("iPhone", "00000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000 ");
simplePayLoad.addAlert("My alert message測試");
simplePayLoad.addBadge(1);
simplePayLoad.addSound("default");
Device client = PushNotificationManager.getInstance().getDevice("iPhone");
PushNotificationManager.getInstance().initializeConnection("gateway.sandbox.push.apple.com", 2195, "/home/ubuntu/mypush.p12", "password", SSLConnectionHelper.KEYSTORE_TYPE_PKCS12);
PushNotificationManager.getInstance().sendNotification(client, simplePayLoad);
測試中文沒有亂碼問題。
編寫比較複雜的使用樣本(可以控制通知是否有提示視窗、是否有提醒聲音):
- aPayload.addBadge( 2),顯示在手機應用表徵圖上的數字
- aPayload.addAlert("軟體版本有更新"),顯示提示視窗文字
- aPayload.addSound("default.wav"),指定提示聲音
另外,也可以使用php的第三方實現,比如:
http://code.google.com/p/php-apns