Simple IOS APNs Test project with SNS integration.
-
Create a new project in XCode.
- Choose Single View Application.
- Enter APNSSampleApp for Product Name.
- Enter com.example for Organization Identifier.
- Leave Language to Objective-C.
-
Replace AppDelegate.m file content with the following:
// // AppDelegate.m // APNSSampleApp // // #import "AppDelegate.h" @interface AppDelegate () @end @implementation AppDelegate - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { // Override point for customization after application launch. // Register for push rotifications if ([[[UIDevice currentDevice] systemVersion] floatValue] >= 8.0) { [[UIApplication sharedApplication] registerUserNotificationSettings:[UIUserNotificationSettings settingsForTypes:(UIUserNotificationTypeSound | UIUserNotificationTypeAlert | UIUserNotificationTypeBadge) categories:nil]]; [[UIApplication sharedApplication] registerForRemoteNotifications]; } else { [[UIApplication sharedApplication] registerForRemoteNotificationTypes: (UIUserNotificationTypeBadge | UIUserNotificationTypeSound | UIUserNotificationTypeAlert)]; } return YES; } - (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken { NSString * deviceTokenString = [[[[deviceToken description] stringByReplacingOccurrencesOfString: @"<" withString: @""] stringByReplacingOccurrencesOfString: @">" withString: @""] stringByReplacingOccurrencesOfString: @" " withString: @""]; NSLog(@"Successfully registered for push notifications."); NSLog(@"Device token: %@", deviceTokenString); } - (void)application:(UIApplication *)application didFailToRegisterForRemoteNotificationsWithError:(NSError *)error { NSLog(@"Failed to register for push notifications."); NSLog(@"%@, %@", error, error.localizedDescription); } -(void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo { application.applicationIconBadgeNumber = 0; if (application.applicationState == UIApplicationStateActive) { NSString *title = [[userInfo objectForKey:@"aps"] objectForKey:@"title"]; NSString *alert = [[userInfo objectForKey:@"aps"] objectForKey:@"alert"]; UIAlertView *alertView = [[UIAlertView alloc] initWithTitle:title message:alert delegate:self cancelButtonTitle:@"OK" otherButtonTitles:nil]; [alertView show]; } } - (void)applicationWillResignActive:(UIApplication *)application { } - (void)applicationDidEnterBackground:(UIApplication *)application { } - (void)applicationWillEnterForeground:(UIApplication *)application { } - (void)applicationDidBecomeActive:(UIApplication *)application { } - (void)applicationWillTerminate:(UIApplication *)application { } @end
- Open iTunes Connect by visiting here.
- Add a new App ID:
- Name: APNSSampleApp.
- Bundle ID: com.example.APNSSampleApp.
- Enable Services: Push Notifications.
- Continue -> Submit -> Done.
- Click newly added App Id APNSSampleApp.
- Click Edit.
- For Push Notifications under Development SSL Certificate click Create Certificate.
- Click Continue to get to Upload CSR page.
- Generate a new CSR using Keychain:
- Open Keychain Access.
- From Keychain Access menu -> Certificate Assistant sub menu click Request a Certificate From a Certificate Authority...
- Enter your email address, APNSSampleApp Development in the Common Name field.
- Select Saved to disk option.
- Click Continue and Save.
- Back in upload CSR page in iTunes Connect click Choose file, select the saved CSR and upload.
- Click Generate button.
- After certificate is generated click Download button to download.
- Save it as APNSSampleAppDevelopment.cer.
- Double click APNSSampleAppDevelopment.cer to add to Keychain.
- Right click the added certificate in Keychain and click Export.
- Save as APNSSampleAppDevelopment.p12.
- DO NOT ENTER A PASSWORD when prompted to secure the exported certificate.
- Back in iTunes Connect under Provisioning Profiles click Development.
- Add a new Provisioning profile to allow the app installed on your development device:
- Under Development choose iOS App Development.
- Click Continue.
- Select APNSSampleApp from App ID drop down menu and click Continue.
- Select your certificate and click Continue.
- Select your device from the list and click Continue.
- Enter APNSSampleApp in the Profile Name: field.
- Click Generate and Download.
- Open the downloaded provisioning profile to add to xCode.
- Open project setting tab General in Xcode, deselecte Automatically manage signing if it is selected
- Select the provisioning profile added in step 8 for Signing (Debug)
- In xCode click on Project name APNSSampleApp then click Capabilities tab.
- Switch On Push Notifications.
- Run the app in xCode and select your device as the target to run on.
- Tap OK to allow push notifications as the application starts. Notifications can also be turned On from device settings -> notifications.
- As the application starts it will register with Apple and will log device token in xCode console which we will need for sending notification to the device.
Advantage of using SNS is scalability which is required when publishing tens of millions of notifications in a very short time and abstracts interaction with different push services behind a unified API.
-
Create a new platform application in SNS console -> Side Menu - Mobile - Push notifications.
-
Enter APNSSampleApp for the name.
-
Select Apple iOS/VoIP/Mac from the Push notification platform drop down menu.
-
Select Used for development in sandbox as the generated certificate is for development
-
Select iOS push certificate from the Push certificate type drop down menu.
-
Click Choose file button.
-
Select APNSSampleAppDevelopment.p12 file that we exported from Keychain.
-
Click Load Credentials from File to populate Certificate and Private Key boxes.
-
Click Create platform application button.
-
Click on the new application name to enter.
-
Click Create application endpoint button.
-
Paste your Device Token in the Device token field.
-
Enter optional data in User Data field.
-
Click Create application endpoint button.
-
Select the newly added endpoint from the list.
-
Click Publish message button.
-
Enter the following in the Message body to send to the endpoint box and click Publish message button.
{ "APNS_SANDBOX":"{\"aps\":{\"alert\":\"Test message from SNS console.\", \"title\": \"APNSSampleApp\"}}" }