iOS开发中push方式被什么取代

DeprecatedPushseguesaredeprecatediniOS8.0andlater... Deprecated

Push segues are deprecated in iOS8.0 and later
展开
 我来答
帐号已注销
2015-09-07 · TA获得超过4.5万个赞
知道大有可为答主
回答量:1.2万
采纳率:77%
帮助的人:2189万
展开全部

IOS开发中PUSH通过开发者push证书实现的,要实现通知推送只能使用push,无其他代替方法。

PUSH原理及实现方法:

原理图:

注:

Provider :应用自己的服务器;

APNS :Apple Push Notification Service的简称,苹果的PUSH服务器;

实现方法:

一、生成push证书。

1、用付费帐号登录到IOS开发者中心。

2、生成开发证书,生成开发证书过程中需要通过Keychain生成一个CSR文件,默认名为CertificateSigningRequest.certSigningRequest,这个文件将在生成push证书的时候用到。

二、创建一个App ID。

注:要用push功能的Bundle Identifier一定不能出现通配符,比如com.mycompany.* ,这样的名字是不能使用push的。

创建过程中Description可以任意填写,比如叫 push_demo ;

Bundle Identifier一般用 com.company.appname 这样的格式,例如com.mycompany.demo ;

三、生成Push SSL Certificate。

1、打开 Enable for Apple Push Notification service 选项,该选项下有 Development Push SSL Certificate 和 Production Push SSL Certificate 两个SSL Certificate可以配置,前面一个是用来的开发的push证书,后面一个是用来发布的。我们以开发push证书为例,点击 Development Push SSL Certificate -> Configure ,后面会要求选择CSR文件,这就是生成开发证书时的CertificateSigningRequest.certSigningRequest文件,选择好CSR后就生成好相应的SSL Certificate了。下载下来,保存名为 aps_developer.cer 。

2、从Keychain中导出私钥、设置好密码,命名为private_key.p12。

3、生成push证书。

将aps_developer.cer转成pem格式

openssl x509 -in aps_developer.cer -inform DER -out aps_developer.pem -outform PEM
将private_key.p12格式的私钥转换成private_key.pem

openssl pkcs12 -nocerts -out private_key.pem -in private_key.p12
4、这一步会要求输入p12私钥的密码,以及设置新生成的pem的密码。

5、创建用于服务端的SSL p12格式证书,命名为aps_developer.p12

openssl pkcs12 -export -in aps_developer.pem -inkey private_key.pem -certfile CertificateSigningRequest.certSigningRequest -name "aps_developer" -out aps_developer.p12
6、这一步会要求输入private_key.pem的密码,注意不是private_key.p12的密码。如果密码错误,或者CertificateSigningRequest.certSigningRequest文件不匹配都不能正常生成aps_developer.p12文件,如果生成的aps_developer.p12文件大小是0,说明生成过程中出了问题,请检查pem私钥、密码、以及CertificateSigningRequest.certSigningRequest是否正确。

aps_developer.p12就是Provider向APNS发送push消息需要的SSL证书。把这个证书和密码提供给服务端,服务端就可以发送push消息给APNS了。这时服务端已经可以工作了,但客户端还必须配置相应的Provisioning Profile才能启动应用的push功能。

服务器配置需注意的是,由于我们生成的是开发环境的push证书,所以服务器应该连接APNS的sandbox环境地址:gateway.sandbox.push.apple.com:2195 ,如果应用正式发布,就要连接正式环境,必须生成相应的发布证书,并连接APNS正式环境地址:gateway.push.apple.com:2195 。

CertificateSigningRequest.certSigningRequest

private_key.p12

aps_developer.cer

四、生成Provisioning Profile

1、新建Profile,命名为push_dev;

2、选择相应证书;

3、App ID选择push_demo;

4、选择设备;

5、下载并安装该Profile供开发使用;

6、Xcode证书设置、Info.plist设置

用Xcode打开客户端工程,设置Info.plist的Bundle identifier为com.mycompany.demo 。

打开工程设置,必须将证书设置为与push_dev关联的证书。

7、客户端获取deviceToken

服务端要发送push消息给某一设备还必须知道该设备的deviceToken。应用运行后获取到deviceToken,然后上传给服务器,下面介绍应用如何获取deviceToken。应用必须先注册使用push功能。

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
     [[UIApplication sharedApplication] registerForRemoteNotificationTypes:(UIRemoteNotificationTypeAlert | UIRemoteNotificationTypeSound | UIRemoteNotificationTypeBadge)];
     // do something
     // ...
 }

在AppDelegate中添加下面方法来获取deviceToken:

- (void)application:(UIApplication *)app didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken {
     NSString *token = [NSString stringWithFormat:@"%@", deviceToken];
     NSLog(@"%@", token);
 }

 - (void)application:(UIApplication *)app didFailToRegisterForRemoteNotificationsWithError:(NSError *)error {
     NSLog(@"%@", error);
 }

应用获取到deviceToken后,上传给Provider,Provider就可以用这个deviceToken给这个设备push消息了。

SSLDUN
2020-01-14 · 多品牌域名证书,代码签名证书,IP证书
SSLDUN
ssldun.com为河南聚妍网络科技有限公司(微信公众号:ssldun 微信公众号名:聚妍)名下网站,商标名:聚妍,Digicert官网授权合作伙伴,主营业务:全球可信便宜SSL证书
向TA提问
展开全部
没有其他取代的方法
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
tj2xy_04020
2014-11-12
知道答主
回答量:19
采纳率:0%
帮助的人:9万
展开全部
没有被取代啊
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
摩羯Mr_huang
2014-11-15
知道答主
回答量:11
采纳率:0%
帮助的人:3.5万
展开全部
没有被取代
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
小脾7
2014-11-21 · TA获得超过862个赞
知道小有建树答主
回答量:108
采纳率:0%
帮助的人:80.3万
展开全部
storyBoard里不推荐了,应该是用show
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式