美文网首页
WechatOpenSDK 1.8.6 iOS接入指南

WechatOpenSDK 1.8.6 iOS接入指南

作者: 秦枫桀 | 来源:发表于2019-10-10 16:14 被阅读0次

    为什么要升级 WechatOpenSDK ?

    由于苹果iOS 13系统版本安全升级,为此WechatOpenSDK在1.8.6版本进行了适配。 1.8.6版本支持 Universal Links方式跳转,对WechatOpenSDK分享进行合法性校验,提升使用过程中的安全性。

    一、SDK 集成

    • CocoaPods 自动集成

      • 在工程的Podfile文件中添加以下代码:
      pod 'WechatOpenSDK'
      
      • 保存并执行pod install

      注意: 如果安装后是低于1.8.6的版本,请更新本地repo,命令行 pod repo update

    • 手动集成

      • 根据业务需求,选择合适的iOS开发工具包下载
      • 将 SDK 文件中包含的 libWeChatSDK.aWXApi.hWXApiObject.h 三个文件添加到你所建的工程中
      • 在工程中链接上: Security.framework, CoreGraphics.framework, WebKit.framework
      • 选择 Build Setting,在Other Linker Flags中加入-ObjC -all_load,在 Search Paths 中添加 libWeChatSDK.aWXApi.hWXApiObject.h,文件所在位置

    二、工程配置

    • URL Types 配置

      选中TARGETS一栏,在Info标签栏的URL type添加URL scheme为你所注册的应用程序 id

    • 白名单配置

      选中TARGETS一栏,在 Info标签栏的LSApplicationQueriesSchemes添加weixinweixinULAPI

    三、配置 Universal Links

    四、调用 SDK

    • 引入头文件

      #import "WXApi.h"
      
    • 向微信注册

      - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
      {
          // 向微信注册
          [WXApi registerApp:APP_ID
      universalLink:UNIVERSAL_LINK];
          return YES;
      }
      
    • 重写 AppDelegate 的 handleOpenURL 和 openURL 方法:

      - (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url
      {
          return  [WXApi handleOpenURL:url delegate:self];
      }
      
      - (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation
      {
          return [WXApi handleOpenURL:url delegate:self];
      }
      
    • 重写 AppDelegate 的 continueUserActivity 方法:

      - (BOOL)application:(UIApplication *)application
      continueUserActivity:(NSUserActivity *)userActivity
      restorationHandler:(void(^)(NSArray<id<UIUserActivityRest
      oring>> * __nullable
      restorableObjects))restorationHandler {
      return [WXApi handleOpenUniversalLink:userActivity
      delegate:self];
      }
      
    • 实现WXApiDelegate

      - (void) onReq:(BaseReq*)reqonReq
      {
        // 所有的请求处理
      }
      
      -(void) onResp:(BaseResp*)resp
      {
         // 所有的响应处理
      }
      
    • 向微信发送请求

      在1.8.6版中,sendReq:方法已被删除,改用下面的方法:

      + (void)sendReq:(BaseReq *)req completion:(void (^
      __nullable)(BOOL success))completion;
      

      注意: 这个方法带了一个可选的callback,微信授权登陆的响应代码不可写在callback里,因为这个callback没提供response对象,我们无法获得那个唯一授权的凭证code。所以微信登陆后的响应代码还是得写在WXApiDelegateonResp:方法里。

    五、1.8.6 版本存在的问题

    ​ 这个版本在授权登陆时,会有个error日志:

    2019-10-10 15:45:59.778864+0800 Demo[1609:270501] -canOpenURL: failed for URL: "weixinULAPI://" - error: "The operation couldn’t be completed. (OSStatus error -10814.)"
    2019-10-10 15:45:59.781316+0800 Demo[1609:270501] -canOpenURL: failed for URL: "weixinULAPI://" - error: "The operation couldn’t be completed. (OSStatus error -10814.)"
    2019-10-10 15:45:59.782868+0800 Demo[1609:270501] -canOpenURL: failed for URL: "weixinULAPI://" - error: "The operation couldn’t be completed. (OSStatus error -10814.)"
    2019-10-10 15:45:59.784924+0800 Demo[1609:270501] -canOpenURL: failed for URL: "weixinULAPI://" - error: "The operation couldn’t be completed. (OSStatus error -10814.)"
    

    查阅了官方的论坛,至今无解。

    下面是官方论坛的此问题的帖子链接:

    https://developers.weixin.qq.com/community/search?query=weixinULAPI&blogcategory=0&sort=0&time=0&starttime=&endtime=&block=0&page=1

    经过测试,此问题并不影响授权登陆跳转和分享跳转。

    相关文章

      网友评论

          本文标题:WechatOpenSDK 1.8.6 iOS接入指南

          本文链接:https://www.haomeiwen.com/subject/vjrapctx.html