handleopenurl 不调用这个方法,怎么使用

>>>>iOS 支付宝 微信支付 集成 支付成功不执行代理方法
iOS 支付宝 微信支付 集成 支付成功不执行代理方法
iOS 支付宝或微信支付当支付成功后都会在AppDelegate中调用
- (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)
- (BOOL)application:(UIApplication *)application&openURL:(NSURL *)url&sourceApplication:(NSString *)sourceApplication&annotation:(id)
这两个方法进行回调操作,可是前段时间还好好的,这两天就不能用了,经过一番查找得知
- (BOOL)application:(UIApplication *)application&openURL:(NSURL *)url&sourceApplication:(NSString *)sourceApplication&annotation:(id)
此方法成ios9中已过期,把回调放到新的代理方法中就可以了。
ios9中的方法:
- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary&NSString *,id& *)options{
& & if ([url.host isEqualToString:@"safepay"]) {
& & & & [[AlipaySDK defaultService] processOrderWithPaymentResult:url standbyCallback:^(NSDictionary *resultDic) {
& & & & & & NSLog(@"result = %@",resultDic);
& & & & }];
& & & &return YES;
& & }else{
& & & & return [WXApi handleOpenURL:url delegate:[WXApiManager sharedManager]];
转载请注明:>>
喜欢就分享一下吧^_^
正文部分到此结束
博文总数:187篇
友情链接:11个
待审链接:0个
评论总数:88个
网站运行: 天UIApplication 用法解析 - 推酷
UIApplication 用法解析
UIApplication,代表的是整个应用做的事,因此每个程序只能有一个,系统使用的是单例模式,就是上面的[UIApplication sharedApplication]来得到一个实例。这个单例实
例是在系统启动时由main函数里面的UIApplicationMain方法生成,就是每个程序里都有的AppDelegate,它实现了UIApplicationDelegate的Protocol,也就是AppDelegate的一
个实例。每次通过[UIApplication sharedApplication]调用的就是它。
UIApplication在程序里的角色:它保存一个UIWindow对象序列,用来快速恢复views
UIApplication的核心作用是提供了iOS程序运行期间的控制和协作工作。
每一个程序在运行期必须有且仅有一个UIApplication(或则其子类)的一个实例。回想一下我在前面的文章“main函数研究”的文章中提到的main函数的代码,可以看出,在
程序开始运行的时候,UIApplicationMain函数是程序进入点,这个函数做了很多工作,其中一个重要的工作就是创建一个UIApplication的单例实例。在你的代码中你,你可以
通过调用[UIApplication sharedApplication]来得到这个单例实例的指针。
UIApplication的一个主要工作是处理用户事件,它会起一个队列,把所有用户事件都放入队列,逐个处理,在处理的时候,它会发送当前事件到一个合适的处理事件的目标控
件。此外,UIApplication实例还维护一个在本应用中打开的window列表(UIWindow实例),这样它就可以接触应用中的任何一个UIView对象。UIApplication实例会被赋予一个
代理对象,以处理应用程序的生命周期事件(比如程序启动和关闭)、系统事件(比如来电、记事项警告)等等。
新建一个任意类型的iOS应用工程,加入我们在Class Prefix输入是TC,我们可以看到工程中生成一个类:
TCAppDelegate :UIResponder &UIApplicationDelegate&
这里这个类的基类是UIResponder,和4.2以前生成的工程是不同的,以前是继承自NSObject。不论如何,本类实现了一个名叫UIApplicationDelegate的接口,这个表明这个类
就是这个工程中UIApplication实例的代理类。
在main函数中,
@autoreleasepool {
returnUIApplicationMain(argc, argv, nil,NSStringFromClass([TCAppDelegateclass]));
这里传入了代理类到UIApplicationMain函数中,UIApplicationMain函数在生成唯一个UIApplication的时候就可以把代理类的实例指针告诉这个单例对象了。
1、- (void)applicationWillResignActive:(UIApplication *)application
说明:当应用程序将要入非活动状态执行,在此期间,应用程序不接收消息或事件,比如来电话了
2、- (void)applicationDidBecomeActive:(UIApplication *)application
说明:当应用程序入活动状态执行,这个刚好跟上面那个方法相反
3、- (void)applicationDidEnterBackground:(UIApplication *)application
说明:当程序被推送到后台的时候调用。所以要设置后台继续运行,则在这个函数里面设置即可
4、- (void)applicationWillEnterForeground:(UIApplication *)application
说明:当程序从后台将要重新回到前台时候调用,这个刚好跟上面的那个方法相反。
5、- (void)applicationWillTerminate:(UIApplication *)application
说明:当程序将要退出是被调用,通常是用来保存数据和一些退出前的清理工作。这个需要要设置UIApplicationExitsOnSuspend的键值。
6、- (void)applicationDidReceiveMemoryWarning:(UIApplication *)application
说明:iPhone设备只有有限的内存,如果为应用程序分配了太多内存操作系统会终止应用程序的运行,在终止前会执行这个方法,通常可以在这里进行内存清理工作防止程序被终止
7、- (void)applicationSignificantTimeChange:(UIApplication*)application
说明:当系统时间发生改变时执行
8、- (void)applicationDidFinishLaunching:(UIApplication*)application
说明:当程序载入后执行
9、- (void)application:(UIApplication)application willChangeStatusBarFrame:(CGRect)newStatusBarFrame
说明:当StatusBar框将要变化时执行
10、- (void)application:(UIApplication*)application willChangeStatusBarOrientation:
(UIInterfaceOrientation)newStatusBarOrientation
duration:(NSTimeInterval)duration
说明:当StatusBar框方向将要变化时执行
11、- (BOOL)application:(UIApplication*)application handleOpenURL:(NSURL*)url
说明:当通过url执行
12、- (void)application:(UIApplication*)application didChangeStatusBarOrientation:(UIInterfaceOrientation)oldStatusBarOrientation
说明:当StatusBar框方向变化完成后执行
13、- (void)application:(UIApplication*)application didChangeSetStatusBarFrame:(CGRect)oldStatusBarFrame
说明:当StatusBar框变化完成后执行
iPhone中的应用程序很容易受到打扰,比如一个来电可能导致应用程序失去焦点,如果这个时候接听了电话,那么应用程序会转到后台运行。还有很多其它类似的事件会导致
iPhone应用程序失去焦点,在应用程序失去焦点前会调用委托类的applicationWillResignActive()方法,而应用程序再次获取到焦点的时候会调用
applicationDidBecomeActive()方法。比如在运行应用程序的时候锁屏会调用委托类的applicationWillResignActive()方法,而当屏幕被解锁的时候,又会调用
applicationDidBecomeActive()方法。
另外一个非常重要的方法就是applicationDidReceiveMemoryWarning(),因为iPhone设备只有有限的内存,如果为应用程序分配了太多内存操作系统会终止应用程序的运行,但
在终止之前操作系统会通过先调用委托类的applicationDidReceiveMemoryWarning()方法警告应用程序,在UIApplication接收到这个事件后它会传递给委托类的
applicationDidReceiveMemoryWarning()方法,委托类在这个方法内可以进行释放内存的操作以防止操作系统强制终止应用程序的运行。
下面是这个类的一些功能:
UIApplication还可以远程提醒,就是push notification注册;
可以连接到UIUndoManager;
检查能否打开某个URL,并且打开URL;这个功能可以配合应用的自定义URL功能,来检测是否安装了某个应用。比如检测是否安装了淘宝的应用,可以用下面的代码:
NSURL *url = [NSURL URLWithString:[NSString stringWithFormat:@&taobao:///item.htm?id=&]];
// 判断当前系统是否有安装淘宝客户端
if ([[UIApplication sharedApplication] canOpenURL:url]) {
// 如果已经安装淘宝客户端,就使用客户端打开链接
[[UIApplication sharedApplication] openURL:url];
NSURL *url = [NSURL URLWithString:[NSString stringWithFormat:@&taobao:///item.htm?id=&]];
// 判断当前系统是否有安装淘宝客户端
if ([[UIApplication sharedApplication] canOpenURL:url]) {
// 如果已经安装淘宝客户端,就使用客户端打开链接
[[UIApplication sharedApplication] openURL:url];
1.设置icon上的数字图标
//设置主界面icon上的数字图标,在2.0中引进, 缺省为0
[UIApplication sharedApplication].applicationIconBadgeNumber = 4;
2.设置摇动手势的时候,是否支持redo,undo操作
//摇动手势,是否支持redo undo操作。
//3.0以后引进,缺省YES
[UIApplication sharedApplication].applicationSupportsShakeToEdit =YES;
3.判断程序运行状态
//判断程序运行状态,在2.0以后引入
UIApplicationStateActive,
UIApplicationStateInactive,
UIApplicationStateBackground
if([UIApplication sharedApplication].applicationState == UIApplicationStateInactive){
NSLog(@&程序在运行状态&);
4.阻止屏幕变暗进入休眠状态
//阻止屏幕变暗,慎重使用,缺省为no 2.0
[UIApplication sharedApplication].idleTimerDisabled = YES;
慎重使用本功能,因为非常耗电。
5.显示联网状态
//显示联网标记 2.0
[UIApplication sharedApplication].networkActivityIndicatorVisible = YES;
6.在map上显示一个地址
NSString* addressText =@&1 Infinite Loop, Cupertino, CA 95014&;
// URL encode the spaces
addressText =
[addressTextstringByAddingPercentEscapesUsingEncoding:NSASCIIStringEncoding];
NSString* urlText = [NSStringstringWithFormat:@&/maps?q=%@&, addressText];
[[UIApplication sharedApplication]openURL:[NSURLURLWithString:urlText]];
7.发送电子邮件
NSString *recipients =@&mailto:?cc=,&subject=Hello from California!&;
NSString *body =@&&body=It is raining in sunny California!&;
NSString *email = [NSStringstringWithFormat:@&%@%@&, recipients, body];
email = [emailstringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
[[UIApplication sharedApplication]openURL:[NSURLURLWithString:email]];
8.打电话到一个号码
// Call Google 411
[[UIApplication sharedApplication]openURL:[NSURLURLWithString:@&tel://&]];
9.发送短信
// Text to Google SMS
[[UIApplication sharedApplication]openURL:[NSURLURLWithString:@&sms://466453&]];
10.打开一个网址
// Lanuch any iPhone developers fav site
[[UIApplication sharedApplication]openURL:[NSURLURLWithString:@&&]];
已发表评论数()
请填写推刊名
描述不能大于100个字符!
权限设置: 公开
仅自己可见
正文不准确
标题不准确
排版有问题
主题不准确
没有分页内容
图片无法显示
视频无法显示
与原文不一致iOS 问题:- (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url
//这里如果我要响应不止一个应用程序的回调,应该怎么写
用什么来区分这些应用程序
return [self.sinaweibo handleOpenURL:url];
求高人指点迷津,多谢多谢
- (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url{
//这里如果我要响应不止一个应用程序的回调,应该怎么写
用什么来区分这些应用程序
return [self.sinaweibo handleOpenURL:url];}求高人指点迷津,多谢多谢
共有 2 个回答
比如新浪微博和Facebook的sso登陆,都要用到(BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url这个函数,应该怎么写呢?
登录后方可回复
可以下载本站的新浪微博登录demo看看呀。
登录后方可回复
登录后方可回答Object-C(37)
接着上篇的自定义URL scheme & 在挂起和回调app的时候又遇到了问题、如下:
handleOpenURL && openURL的不同
handleOpenURL是其它应用通过调用你的app中设置的URL
scheme打开你的应用、例如做分享回调到自己app就调用这个方法;
OpenURL是你通过打开一个url的方式打开其它的应用或链接、在支付或者分享时需要打开其他应用的方法。
Appdelegate.m中有多个handleopenURL,互相冲突,怎么处理?
解决方法如下:先分开调用、在handleopenURL中nslog[&%@&, &url ];获取url的前缀
- (BOOL)application:(UIApplication *)application
& & & handleOpenURL:(NSURL *)url
& & NSString *string =[url absoluteString];
& & if ([string hasPrefix:@&微博url的前缀&])
& & & & return [WeiboSDK handleOpenURL:url delegate:self];
& & else if ([string hasPrefix:@&微信的url的前缀&])
& & & & return [WXApi handleOpenURL:url delegate:self];
参考知识库
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
访问:8815次
排名:千里之外
原创:33篇
转载:10篇
(3)(2)(1)(5)(1)(7)(7)(7)(1)(10)6109人阅读
ShareSDK最新的是3.x版本,以前老的2.x需要更新,毕竟ios9已经更新啦。然后ShareSDK里的最新方法也是肯定更换,这是比较痛苦的事情,项目里又要重新来一遍,检查、测试等。
按照官网的文档以及demo进行集成,设置白名单、添加文件等。配置微信、支付宝等。
开始运行项目,编译通过,测试支付,微信支付也成功了,但是发现不回调onResp方法,openURL方法也没有进入,难道项目引入头文件缺少?(onResp、openURL、handleOpenUR方法写在Appdelegate里边)。
开始查找问题:
1.&ShareSDK 2.x的sdk是可以回调onResp。
2. 也按照官网的配置要求进行设置。
3. 官网的demo是可以回调onResp,说明sdk应该是最新的、没有问题。
4. 检查微信配置文件,appleid、密钥等。
最后得出问题肯定是初始化sdk的时候出现的。
那就检查对比官网demo是不是少写了配置,直接检查微信的配置,果然发现问题了,微信的代理没有写,因为这个代码是在官网上复制的,和官网给的demo是不一样的。
demo代码截图
官网网站代码
两边对比可以发现:缺少&delegate:self
&[ShareSDKConnector connectWeChat:[WXApi class]];
&[ShareSDKConnector connectWeChat:[WXApi class] delegate:self];
还需要注意一下Appdelegate需要添加三个方法以及onResp:
- (BOOL)application:(UIApplication *)application
handleOpenURL:(NSURL *)url
[WXApi handleOpenURL:url delegate:self];
-(BOOL)application:(UIApplication*)app openURL:(NSURL*)url options:(NSDictionary&NSString *,id& *)options
[WXApi handleOpenURL:url delegate:self];
- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation
[WXApi handleOpenURL:url delegate:self];
-(void) onResp:(BaseResp*)resp
NSString *strMsg = [NSString stringWithFormat:@&errcode:%d&, resp.errCode];
if([resp isKindOfClass:[PayResp class]]){
//支付返回结果
switch (resp.errCode) {
case WXSuccess:
strMsg = @&支付结果:成功!&;
NSLog(@&支付成功-PaySuccess,retcode = %d&, resp.errCode);
strMsg = [NSString stringWithFormat:@&支付结果:失败!retcode = %d, retstr = %@&, resp.errCode,resp.errStr];
NSLog(@&错误,retcode = %d, retstr = %@&, resp.errCode,resp.errStr);
参考知识库
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
访问:417482次
积分:4237
积分:4237
排名:第5766名
原创:98篇
评论:71条
(3)(4)(3)(1)(4)(5)(4)(3)(1)(4)(1)(2)(1)(1)(2)(2)(2)(3)(7)(1)(2)(3)(7)(5)(4)(5)(2)(2)(5)(14)}

我要回帖

更多关于 ios handleopenurl 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信