iOS第三方推送集成以及推送时铃声的改变

各位大佬们,你们好。很久没更新文章了,今天有在做推送,老板要求把原来系统的铃声换成我们专属的,或者说,当用户给你推送一个重要的消息,可以用独特的声音告知用户,例如:
“您有一份外卖订单,请及时查看”;“您有一个交易信息,请查看”等等。
关于这种根据特殊的推送内容实现特殊的声音,解决后第一时间记录一下文章,以便日后方便使用。我先说一下思路好了:

关于推送,我不用多说,这个是用来推送消息,无论APP是否挂起。而推送内容都是由后台决定。比如说A购买了B的东西,B这个时候不在线,如何让B立马知道有人下单,这时候除了短信就是推送。A在购买的B东西的时候,给服务器发送了请求,而服务器又要给第三方推送平台发送请求,第三方平台又会给B发送推送。整个流程就是这样。然而如果说是音频的话,那自然就是当用户收到推送的时候,调用本地的音频文件完成推送音频播放。

    刚开始的时候,我以为是本地Appdelegate里方法判断并且调用音频播放的功能,所以我考虑到了1.当用户在使用的时候收到了推送。 2.当用户按Home键把APP挂在后台的时候。3.当用户彻底从进程里退出APP的时候。  我考虑如果说调用Appdelegate里的方法的话只有

1.是100%可以的。
2.过一会肯定就停止方法。
3.压根就不会再调用。

所有推翻我之前的想法,不用考虑了,所以只能在推送上做手脚。进入正题,我们先快速的集成一下第三方推送,我用的是友盟的。按照文档慢慢的来肯定没毛病。
1.下载 http://dev.umeng.com/push/ios/integration 下载SDK,只选择装有.a和UMessage.h的文件夹。导入到你的项目里
2.配置需要用的文件系统库等。
3.在Capabilities里打开Push Notification(非常重要!)
4.正常的填写需要的内容

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{ 

//初始化方法,也可以使用(void)startWithAppkey:(NSString *)appKey launchOptions:(NSDictionary * )launchOptions httpsenable:(BOOL)value;这个方法,方便设置https请求。

    [UMessage startWithAppkey:@"your appkey" launchOptions:launchOptions];

    [UMessage setLogEnabled:YES];
    //注册通知,如果要使用category的自定义策略,可以参考demo中的代码。
    [UMessage registerForRemoteNotifications];

    //iOS10必须加下面这段代码。
    UNUserNotificationCenter *center = [UNUserNotificationCenter currentNotificationCenter];
    center.delegate=self;
    UNAuthorizationOptions types10=UNAuthorizationOptionBadge|  UNAuthorizationOptionAlert|UNAuthorizationOptionSound;
    [center requestAuthorizationWithOptions:types10     completionHandler:^(BOOL granted, NSError * _Nullable error) {
    if (granted) {
        //点击允许
        //这里可以添加一些自己的逻辑
    } else {
        //点击不允许
        //这里可以添加一些自己的逻辑
    }
}];

//打开日志,方便调试
[UMessage setLogEnabled:YES];
}

- (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken
{
    // 1.2.7版本开始不需要用户再手动注册devicetoken,SDK会自动注册
    //[UMessage registerDeviceToken:deviceToken];
    //不需要手动注册,但是下面方法可以直接获取你手机的devicetoken
    NSLog(@"%@",[[[[deviceToken description] stringByReplacingOccurrencesOfString: @"<" withString: @""]
                  stringByReplacingOccurrencesOfString: @">" withString: @""]
                 stringByReplacingOccurrencesOfString: @" " withString: @""]);

}
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo
{
    //关闭友盟自带的弹出框
    [UMessage setAutoAlert:NO];
    [UMessage didReceiveRemoteNotification:userInfo];
    //    self.userInfo = userInfo;
}


//iOS10新增:处理前台收到通知的代理方法
-(void)userNotificationCenter:(UNUserNotificationCenter *)center willPresentNotification:(UNNotification *)notification withCompletionHandler:(void (^)(UNNotificationPresentationOptions))completionHandler{
    NSDictionary * userInfo = notification.request.content.userInfo;
    if([notification.request.trigger isKindOfClass:[UNPushNotificationTrigger class]]) {
        //应用处于前台时的远程推送接受
        //关闭友盟自带的弹出框
        [UMessage setAutoAlert:NO];
        //必须加这句代码
        [UMessage didReceiveRemoteNotification:userInfo];
        
    }else{
        //应用处于前台时的本地推送接受
    }
    //当应用处于前台时提示设置,需要哪个可以设置哪一个
    completionHandler(UNNotificationPresentationOptionSound|UNNotificationPresentationOptionBadge|UNNotificationPresentationOptionAlert);
}

//iOS10新增:处理后台点击通知的代理方法
-(void)userNotificationCenter:(UNUserNotificationCenter *)center didReceiveNotificationResponse:(UNNotificationResponse *)response withCompletionHandler:(void (^)())completionHandler{
    NSDictionary * userInfo = response.notification.request.content.userInfo;
    if([response.notification.request.trigger isKindOfClass:[UNPushNotificationTrigger class]]) {
        //应用处于后台时的远程推送接受
        //必须加这句代码
        [UMessage didReceiveRemoteNotification:userInfo];
        
    }else{
        //应用处于后台时的本地推送接受
    }
    
}
- (void)application:(UIApplication *)application didFailToRegisterForRemoteNotificationsWithError:(NSError *)error
{
    //如果没有获得devicetoken的话一定会走进这个方法里,如果报错内容是3001,是因为你的Capabilities里打开Push Notification 没有打开。

    NSString *error_str = [NSString stringWithFormat: @"%@", error];
    NSLog(@"Failed to get token, error:%@", error_str);

}

以上全部在appdeleagte里实现就可以了,然后关于appkey,去友盟里创建一个。创建以后如下图一样


iOS第三方推送集成以及推送时铃声的改变_第1张图片
7051620F-1E4D-450A-B87A-0B2B0B566F1D.png

这个是创建以后的,关于推送需要两个证书:
1.开发证书(只用来内部测试推送)
2.生产证书(上架以后使用的推送证书)
关于证书的东西我就不多说了,网上一堆如何创建打包p.12格式文件。自己看看吧。

iOS第三方推送集成以及推送时铃声的改变_第2张图片
95D1ED5F-5CE0-4F70-80B4-77B55E02CEE9.png

还没上架的话就别着急创建生产证书了,就开发证书就可以了。进入测试模式选择添加测试信息。

进入进来以后你会发现有很多信息可以填写,什么消息描述啊,主标题,副标题,内容。这个随便写。 内容链接也不需要哦

iOS第三方推送集成以及推送时铃声的改变_第3张图片
D984D238-E6B1-4F72-864E-440F75B5C859.png

这里有一个devicetoken,之前在Appdelegate里就已经获取了。直接赋值粘贴进来就行了。然后点击发送,就能收到推送!

-----------------------------我是分割线------------------------------

以上便是推送集成,超级快。五分钟搞定。 接下来是更换铃声了。
我也没啥好的素材,只能从网上找一找。http://www.huiyi8.com/tishiyin/
随便选一首。然后点击进去进入下载

iOS第三方推送集成以及推送时铃声的改变_第4张图片
9F9480D8-B56C-4BF7-9136-377015883BCA.png

然后选择MP3格式,你会发现你进入到这个页面。


iOS第三方推送集成以及推送时铃声的改变_第5张图片
E28DFF7E-F9F0-4D91-8EE0-7A23AC8B657C.png

不用下载,保存一下链接地址。
http://data3.huiyi8.com/2015/dqd/07/31/4.mp3 (这个是我自己找的)

然后咱们去转换类型,我在此强调!!!非常强调!!!严重强调!!!苹果只支持四种格式!!!
Linear PCM、MA4 (IMA/ADPCM)、µLaw、aLaw
必须是这4种格式之一 !!!!(非常重要!!)

这个非常重要! 我们刚才的是mp3不是吗? 所以我们需要转码,什么类型好转呢,就是MA4, 这是苹果官网上写的,但也叫M4A。我也有在线转换的链接!
http://cn.office-converter.com/Online-Audio-Converter

iOS第三方推送集成以及推送时铃声的改变_第6张图片
5E0D7709-F7E0-4560-AC81-6050FF621D79.png

这个就可以转码!我们进去转码一下!

iOS第三方推送集成以及推送时铃声的改变_第7张图片
B1F9BA6A-4C7E-46B8-8D7A-B51AF8664934.png

最上面不要用,因为你转出来的是html格式的,乱码,毫无任何卵用。
用下面的网址转码。

iOS第三方推送集成以及推送时铃声的改变_第8张图片
63A1C8DF-BAC2-460B-AF37-4797D4104A5B.png

转码的下载一点击就变成下面这个样子?

iOS第三方推送集成以及推送时铃声的改变_第9张图片
3CAFC8DB-D233-4D4E-B425-A3025FC14E19.png

这个是正常的,然后复制网址到迅雷里下载就好啦!

iOS第三方推送集成以及推送时铃声的改变_第10张图片
9C30207E-CC6D-46B7-A2C0-BE79F9A9618F.png

然后这个拖到桌面咯,然后拉到我们需要开发的项目里咯。
然后步骤已经快完成咯,记住项目里也好下载也好格式都是m4a

iOS第三方推送集成以及推送时铃声的改变_第11张图片
1EF10201-AB56-4EE4-A00F-8EB7CB05846E.png

然后我们再回到友盟的后台端进行推送,不过这次要加一个步骤咯,那就添加我们的这个音乐名字。 如下


iOS第三方推送集成以及推送时铃声的改变_第12张图片
0D20B960-3EF8-4831-AC19-D458A4C5B22A.png

也就多了一个步骤那就是添加音乐名,然后提交,就可以推送了~~
这个是为了测试而已,但真正名字是由服务器传到他们的第三方平台里的。

http://dev.umeng.com/push/ios/api-doc

这个就是后端的网址。啊哈哈哈哈,就这么简单!只有做完才觉得如此的简单!

看在我花了这么久的份上,点赞关注我哦~

若是有还不懂的地方可以加我的
QQ:1119718338
QQ群:622177838

你可能感兴趣的:(iOS第三方推送集成以及推送时铃声的改变)