我已经创建了2个示例(单视图)项目来测试推送通知,除了如下所示的通知设置代码外,我没有添加任何代码:
专案1(快速2):
func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {
let settings = UIUserNotificationSettings(forTypes: [.Alert, .Badge, .Sound], categories: nil)
UIApplication.sharedApplication().registerUserNotificationSettings(settings)
UIApplication.sharedApplication().registerForRemoteNotifications()
return true
}
func application(application: UIApplication, didRegisterUserNotificationSettings notificationSettings: UIUserNotificationSettings) {
print("didRegisterUserNotificationSettings got called")
}
func application(application: UIApplication, didRegisterForRemoteNotificationsWithDeviceToken deviceToken: NSData) {
let trimmedDeviceToken = deviceToken.description .stringByTrimmingCharactersInSet(NSCharacterSet(charactersInString: "<>"))
.stringByReplacingOccurrencesOfString(" ", withString: "")
print("Device Token \(trimmedDeviceToken)")
}
func application(application: UIApplication, didFailToRegisterForRemoteNotificationsWithError error: NSError) {
print("Failed to get token, error: \(error)")
}
Project2(目标C):
-(BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
UIUserNotificationSettings* notificationSettings =
[UIUserNotificationSettings settingsForTypes:(UIUserNotificationTypeSound | UIUserNotificationTypeAlert|UIUserNotificationTypeBadge) categories:nil];
[application registerUserNotificationSettings:notificationSettings];
[application registerForRemoteNotifications];
return YES;
}
-(void)application:(UIApplication *)application didRegisterUserNotificationSettings:(UIUserNotificationSettings *)notificationSettings {
NSLog(@"didRegisterUserNotificationSettings got called");
}
-(void)application:(UIApplication*)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData*)deviceToken
{
NSString* newToken = [deviceToken description];
newToken = [newToken stringByTrimmingCharactersInSet:[NSCharacterSet characterSetWithCharactersInString:@"<>"]];
newToken = [newToken stringByReplacingOccurrencesOfString:@" " withString:@""];
NSLog(@"Device Token %@", newToken);
}
-(void)application:(UIApplication*)application didFailToRegisterForRemoteNotificationsWithError:(NSError*)error
{
NSLog(@"Failed to get token, error: %@", error);
}
Objective-C项目在所有经过测试的设备上都能正常工作:注册自己以获取远程通知,并在委托回调方法中接收设备令牌,但是swift项目无法获取任何委托回调。
在将此问题标记为重复之前,请先阅读我的尝试:
1)AppID已启用推送通知
2)推送证书类型为生产且Provisioning配置文件为AdHoc生产
3)两个项目均使用相同的AppID,推送证书和供应配置文件
4)两个项目均已在3种不同的iPhone(5、6和6Plus)全部运行iOS 9.2,每次安装都删除了该应用程序,并多次重新启动了它们
。5)在2台不同的Mac Pro机器上使用Xcode 7.2构建了两个项目
6)所有3部iPhone均使用互联网连接而没有防火墙,并且所有端口均打开(如本技术说明中所述),还将3台设备上的Internet连接更改为3G连接而不是WIFI。
7)在项目设置中检查/未检查推送通知->两个项目的功能(顺便说一句,这一点在我测试时没有效果)
8)尝试了两个项目的Xcode Run(顶部按钮)和Export ipa包
9)同时尝试了(application)和(使用objective-c的[UIApplication sharedApplication]和使用registerForRemoteNotifications
10方法快速进行的UIApplication.sharedApplication())尝试了两个全新的AppID,推送证书和供应配置文件。
11)删除两个项目,并使用与上面相同的代码创建另外两个新项目
经过所有这些尝试后,objective-c项目工作正常,并通过didRegisterForRemoteNotificationsWithDeviceToken方法接收了设备令牌,但是快速的项目不起作用。
我已经使用PersistentConnectionLogging.mobileconfig
Apple的配置文件从iPhone 6Plus设备生成了3个APN日志文件,并将它们上传到此处,(在apsd_2016_02_24_11_36_29+0300.log
文件内部,objective-c项目BundleID是XXXXX.push.notification
,而swift项目BundleID是XXXXX.apnsswift
)
事实证明,这个奇怪问题的背后原因是swift的print
方法与相比,它不会在设备日志中显示输出NSLog
,而swift应用程序没有问题,它只需要用于NSLog
在Push Notification委托回调方法中显示消息即可。
//print("Device Token \(trimmedDeviceToken)")
NSLog("Device Token: %@",trimmedDeviceToken)
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句