[ios] APNS 클라이언트 구현 (pdf)
첨부 '3' |
---|
애플 푸시 알림 서비스 (Apple Push Notification Service)
APNS 란?
애플의 푸시 알림 서비스(APNS)는 푸시 알림 기능의 중심이며 아이폰, 아이패드, 아이팟 터치와 같은 장치에
정보를 전송하기 위한 강력하고 고효율적인 서비스입니다.
소프트웨어 개발사 및 개발자가 제작한 응용 프로그램은 새 데이터가 도착하면 데이터를 모니터링 하면서 영 구적 보안 채널을 통해 APNS와 공급자를 연결하여 대상 장치에 알림을 보냅니다.
시스템 구성
(그림 출처 : apple.com)
개발 방법
1. APNS를 하기 위한 인증서 생성
- iOS Provisioning Portal 사이트에서 App ID를 생성하고 푸시 서비스를 할 App ID를 선택하여 “Enable for Apple push notification service”란에 체크하여 해당 앱이 푸시 서비스를 사용할 수 있도 록 활성화
- Provisioning 메뉴에서 App ID에 대한 Profile을 생성하고 다운로드
- Profile 을 실행하여 맥 OS의 “키체인 접근” 유틸리티에 APNS용 인증서 등록
2. APNS 와 연동할 푸시 서버용 인증서 생성
- 맥 OS의 “키체인 접근” 유틸리티에서 APNS 인증서를 Export하여 저장
- 맥 OS 터미널에서 Export 한 인증서 파일(확장자 “.p12”)들을 “.pem” 파일로 변환
$openssl pkcs12 -clcerts -nokeys -out apns-dev-cert.pem -in apns-dev-cert.p12
$openssl pkcs12 -nocerts -out apns-dev-key.pem -in apns-dev-key.p12
생성된 각각의 pem 파일들을 서버에 저장한다
3. 푸시 서버를 서비스에 맞게 수정
PHP : APNS-PHP
http://code.google.com/p/apns-php/
4. 앱 (클라이언트)에서 푸시 관련 이벤트 처리
단말기가 APNS에 등록후 APNS로 부터 디바이스 토큰을 받았을 때 호출되는 콜백 메서드 (디바이스 토큰을 멤버 변수에 저장해 놓고 적당한 시점에 디바이스 토큰을 푸시 서버로 전송한다.)
- (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken {
NSLog(@"deviceToken: %@", deviceToken);
[self.myDeviceToken appendData:deviceToken];
}
APNS에 등록을 시도했으나 실패한 경우 호출되는 콜백 메서드
- (void)application:(UIApplication *)application
didFailToRegisterForRemoteNotificationsWithError:(NSError *)error
{
NSLog(@"Registeration error: %@", error);
}
어플이 실행중일 때 알림이 오면 호출되는 메서드
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary
*)userInfo
{
NSDictionary *aps = [userInfo valueForKey:@"aps"]; NSLog(@"%@", [aps valueForKey:@"alert"]);
NSString *alert = [aps valueForKey:@"alert"]; NSString *badge = [aps objectForKey:@"badge"];
NSLog(@"Received Push Badge: %@", badge);
NSString *customKey = [aps objectForKey:@"custom_key"];
NSLog(@"%@", customKey);
application.applicationIconBadgeNumber = [[aps objectForKey:@"badge"] integerValue];
if ([customKey isEqualToString:@"ATTEND"]){
[self.viewController switchTab:0];
}else if ([customKey isEqualToString:@"NOTIFY"]){
[self.viewController switchTab:1];
}
[SimpleAlertView showSimpleAlert:self TitleText:@"알림" MessageText:alert]; }
어플이 실행중이 아닐때 알림이 올경우
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:
(NSDictionary *)launchOptions
{
self.myDeviceToken = [NSMutableData data];
// 어플은 APNS에 등록을 시도하는데, 알림 방식을 지정 (배지, 소리, 경고)
[application registerForRemoteNotificationTypes:(UIRemoteNotificationTypeBadge | UIRemoteNotificationTypeSound | UIRemoteNotificationTypeAlert)];
// 배지 개수 재설정
application.applicationIconBadgeNumber = 0;
NSDictionary *notification = [launchOptions valueForKey:UIApplicationLaunchOptionsRemoteNotificationKey];
NSLog(@"%@", [notification valueForKey:@"custom"]); ...
}
번호 | 분류 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|---|
717 | Develop | [git] 쉬운 버전관리 Git 설명 | hooni | 2015.08.18 | 963 |
716 | Develop | [html] HTML5 튜토리얼 링크 ㅋㅋ | hooni | 2013.04.23 | 12826 |
715 | Develop | [html] SVG(Scalable Vector Graphics) 간단 정리 | hooni | 2014.02.13 | 8869 |
714 | Develop | [html] 메타태그 사용예.. 은지나 바라~ | hooni | 2003.04.23 | 7255 |
713 | Develop | [html] 캐쉬된 웹페이지 사용하지 않도록 하는 방법 | hooni | 2003.04.23 | 13070 |
712 | Etc | [htm] DOM에 대해 ㅎㅎ | hooni | 2003.04.23 | 14759 |
711 | Develop | [ios] UIView 계층구조 | hooni | 2015.01.03 | 1226 |
710 | Develop | [ios] @property의 속성 (strong, weak, copy) 사용 경우 | hooni | 2014.08.08 | 1777 |
709 | Develop | [ios] AES256 알고리즘을 이용해 데이터 암호화/복호화 방법 | hooni | 2015.07.21 | 4192 |
708 | Develop | [ios] APNS 샘플 코드.. | hooni | 2013.06.27 | 0 |
» | Develop | [ios] APNS 클라이언트 구현 (pdf) | hooni | 2013.06.27 | 15835 |
706 | Develop | [ios] APNS, Remote Push 사용자가 수신을 동의했는지 확인하기 | hooni | 2018.10.19 | 1372 |