Asroads'Blog 君子不器
iOS微信开发如何运行官方demo
发布于: 2024-09-29 更新于: 2024-11-11 分类于: game 阅读次数: 

最近项目要接入App的微信登陆功能,于是就去看看官方的文档和范例,下面是如何把官方的范例在本地运行起来的过程,做个记录吧,日后再次使用的时候,可以方便查阅。

环境

  • Mac
  • Xcode
  • ios 手机一部

相关文档

运行官方demo

下载资源

资源下载

使用微信分享、登录、收藏、支付等功能需要的库以及文件。通过CocoaPods集成(详情查看接入流程)或点击下载以下开发工具包:

  1. iOS开发工具包(直接提供.a静态库文件的形式,2.0.4版本,包含支付功能)。
  2. iOS开发工具包(直接提供.a静态库文件的形式,2.0.4版本,不包含支付功能)。
  3. iOS开发工具包(XCFramework的形式,2.0.4版本,包含支付功能)。
  4. iOS开发工具包(XCFramework的形式,2.0.4版本,不包含支付功能)。

注意 官方demo使用的是 .a静态库文件的形式

范例代码

包含了一个完整的范例工程,该范例的使用可以参阅iOS平台上手指南。点击下载 范例代码

说明:我们这里下载 iOS开发工具包.a静态库文件的形式 包含支付功能和 范例代码

  1. 下载后,我们这里新建一个目录 名字这里叫做 WeChatiOS

image-20240904143135212

  1. 修改名字,由于demo里面配置文件的路径是../../WeChatSDK/SDKExport 如下

    image-20240904142937499

    image-20240904142957493

1
2
3
4
5
6
7
8
9
10
11
12
13
C9F1D7C11E49BD5D006316E3 /* SDKExport */ = {
isa = PBXGroup;
children = (
C9F1D7C21E49BD5D006316E3 /* libWeChatSDK.a */,
C9F1D7C31E49BD5D006316E3 /* README.txt */,
C9F1D7C41E49BD5D006316E3 /* WechatAuthSDK.h */,
C9F1D7C51E49BD5D006316E3 /* WXApi.h */,
C9F1D7C81E49BD5D006316E3 /* WXApiObject.h */,
);
name = SDKExport;
path = ../../WeChatSDK/SDKExport;
sourceTree = "<group>";
};
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
F05029BB1505F71800C3E5E5 /* Debug */ = {
isa = XCBuildConfiguration;
buildSettings = {
CLANG_ENABLE_OBJC_ARC = YES;
CODE_SIGN_ENTITLEMENTS = SDKSample.entitlements;
CODE_SIGN_IDENTITY = "iPhone Distribution: Foshan Nationstar Optoelectronics Co., Ltd.";
"CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
DEVELOPMENT_TEAM = 8P7343TG54;
ENABLE_BITCODE = YES;
GCC_PRECOMPILE_PREFIX_HEADER = YES;
GCC_PREFIX_HEADER = "SDKSample-Prefix.pch";
INFOPLIST_FILE = "SDKSample-Info.plist";
IPHONEOS_DEPLOYMENT_TARGET = 7.0;
LIBRARY_SEARCH_PATHS = (
"$(inherited)",
"$(SRCROOT)/../../WeChatSDK/SDKExport",
);
OTHER_LDFLAGS = (
"-Objc",
"-all_load",
);
PRODUCT_BUNDLE_IDENTIFIER = "com.tencent.wc.xin.${PRODUCT_NAME:rfc1034identifier}";
PRODUCT_NAME = "$(TARGET_NAME)";
PROVISIONING_PROFILE = "62a1937d-84eb-4fc3-a04d-cc7b1167098e";
PROVISIONING_PROFILE_SPECIFIER = "match Development com.tencent.wc.xin.SDKSample";
WRAPPER_EXTENSION = app;
};
name = Debug;
};
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
F05029BC1505F71800C3E5E5 /* Release */ = {
isa = XCBuildConfiguration;
buildSettings = {
CLANG_ENABLE_OBJC_ARC = YES;
CODE_SIGN_ENTITLEMENTS = SDKSample.entitlements;
CODE_SIGN_IDENTITY = "iPhone Distribution: Foshan Nationstar Optoelectronics Co., Ltd.";
"CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Distribution";
DEVELOPMENT_TEAM = 8P7343TG54;
ENABLE_BITCODE = YES;
GCC_PRECOMPILE_PREFIX_HEADER = YES;
GCC_PREFIX_HEADER = "SDKSample-Prefix.pch";
INFOPLIST_FILE = "SDKSample-Info.plist";
IPHONEOS_DEPLOYMENT_TARGET = 7.0;
LIBRARY_SEARCH_PATHS = (
"$(inherited)",
"$(SRCROOT)/../../WeChatSDK/SDKExport",
);
OTHER_LDFLAGS = (
"-Objc",
"-all_load",
);
PRODUCT_BUNDLE_IDENTIFIER = "com.tencent.wc.xin.${PRODUCT_NAME:rfc1034identifier}";
PRODUCT_NAME = "$(TARGET_NAME)";
PROVISIONING_PROFILE = "f97d601b-2fe2-4ff5-b892-9096070b6ed6";
PROVISIONING_PROFILE_SPECIFIER = SDKSample_Inhouse;
WRAPPER_EXTENSION = app;
};
name = Release;
};

要使这个路径正常工作,你需要确保项目结构符合以下形式:

项目结构:

1
2
3
4
5
WeChatiOS/
├── ReleaseSample
│   └── SDKSample//范例代码目录就是`SDKSample.xcodeproj`父目录
└── WeChatSDK
└── SDKExport

具体解释:

  • WeChatiOS/ 是项目的工作目录,包含了项目和 SDK 文件夹。
  • WeChatSDK/ 文件夹位于 Root/ 目录下,里面包含 SDKExport 文件夹。
  • SDKExport/ 文件夹中存放了微信 SDK 的相关文件,如静态库 libWeChatSDK.a 以及头文件 WechatAuthSDK.hWXApi.hWXApiObject.h 等。
  • SDKSample/ 是上面下载的范例 Xcode 项目文件夹,SDKSample.xcodeproj 就是范例的项目文件。

注意 重点是 ../../WeChatSDK/SDKExport这个路径 其中 SDKExport这个目录 就是上面的 OpenSDK2.0.4 ,所以下面为了构建这个路径,本地运行要对项目进行修改。

修改项目配置

  1. 新建WeChatSDK文件夹 把OpenSDK2.0.4重命名为 SDKExport,新建一个目录SDKSample 把原来ReleaseSample内的文件 全部移动到SDKSample目录,最终效果如下:

image-20240904143329076

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
├── ReleaseSample
│   └── SDKSample
│   ├── 其他文件...
│   ├── SDKSample-Info.plist
│   ├── SDKSample-Prefix.pch
│   ├── SDKSample.entitlements
│   ├── SDKSample.xcodeproj
└── WeChatSDK
└── SDKExport
├── PrivacyInfo.xcprivacy
├── README.txt
├── WXApi.h
├── WXApiObject.h
├── WechatAuthSDK.h
└── libWeChatSDK.a
  1. 对引用的SDK 重新建立索引路径

image-20240904143724729

  • 点击左侧项目内的SDKExport目录

image-20240904143708237

  • 选择刚刚重命名好的目录SDKExport

image-20240904143812227

  • 修改完成后,同理 对 SDKSample 文件进行重新索引映射 发现文件不再显示标红错误

image-20240904143901708

image-20240904143946647

  1. 设置我们运行设备,这里选择真机

image-20240904144044869

  1. 删除不支持的设备 以及设置 bundleid 和 team

image-20240904144130362

image-20240904144645391

  1. 设置我们支持的iOS版本 这里选择一个 大于 10 的版本 这里选择 12.0

image-20240904144202765

设置后如下

image-20240904144220910

  1. 重新设置失去链接或者过期的库

image-20240904144255498

  • 先删除原来的 红色的库
  • 然后重新添加,添加后如下:

image-20240904144328781

image-20240904144346908

image-20240904144441725

  1. 修改完毕后运行我们的项目 点击 运行按钮等待构建完成。

image-20240904144750760

发现构建失败:

image-20240904144811352

image-20240904144733047

这些错误与 WKWebView 相关,说明项目使用了 WKWebView,但是在链接阶段找不到相关的类。这通常是因为没有正确链接 WebKit.framework

解决方法:
  • 打开 Xcode 项目,选择项目的 Target。
  • 进入 “Build Phases” 选项卡。
  • 在 “Link Binary With Libraries” 部分,点击左下角的 +,搜索并添加 WebKit.framework

image-20240904144903374

image-20240904144927878

  1. 再次构建运行项目

    image-20240904145006311

  2. 手机效果如下:

image-20240904145022750

  1. 至此,官方微信范例运行成功!!!
--- 本文结束 The End ---