使用场景:虚拟产品内购,android使用微信支付,iOS使用IAP。
由于iOS禁止在虚拟产品使用第三方支付,嵌入支付SDK将被拒,而在android则自由使用第三方支付的情况。
@v7lin 在原仓中也做了iOS的版本,但是将android去掉了。 所以在这里做一个能同时适应这种场景的分支
wechat_kit:
git:
url: https://github.com/patrickchoo/wechat_kit.git
ref: ios_nopay
可以直接使用v7lin的原仓 https://github.com/rxreader/wechat_kit
wechat_kit: ^1.1.1
# 不需要做任何额外接入工作
# 混淆已打入 Library,随 Library 引用,自动添加到 apk 打包混淆
<manifest>
<!-- targetSdkVersion >= 29 && compileSdkVersion >= 29, 豁免 Android Q 的外部存储沙箱限制 -->
<application android:requestLegacyExternalStorage="true">
</application>
</manifest>
非官方方法 -> 反编译 Gen_Signature_Android2.apk 所得
命令:
keytool -list -v -keystore ${your_keystore_path} -storepass ${your_keystore_password} 2>/dev/null | grep -p 'MD5:.*' -o | sed 's/MD5://' | sed 's/ //g' | sed 's/://g' | awk '{print tolower($0)}'
示例:
keytool -list -v -keystore example/android/app/infos/dev.jks -storepass 123456 2>/dev/null | grep -p 'MD5:.*' -o | sed 's/MD5://' | sed 's/ //g' | sed 's/://g' | awk '{print tolower($0)}'
28424130a4416d519e00946651d53a46
暂不支持 SceneDelegate 见文档微信-iOS接入指南
在Xcode中,选择你的工程设置项,选中“TARGETS”一栏,在“info”标签栏的“URL type“添加“URL scheme”为你所注册的应用程序id
URL Types
weixin: identifier=weixin schemes=${appId}
iOS 9系统策略更新,限制了http协议的访问,此外应用需要在“Info.plist”中将要使用的URL Schemes列为白名单,才可正常检查其他应用是否安装。
<key>LSApplicationQueriesSchemes</key>
<array>
<string>weixin</string>
<string>weixinULAPI</string>
</array>
<key>NSAppTransportSecurity</key>
<dict>
<key>NSAllowsArbitraryLoads</key>
<true/>
</dict>
Universal Links
Capabilities -> Associated Domain -> Domain -> applinks:${your applinks}
- snapshot
dependencies:
wechat_kit:
git:
url: https://github.com/v7lin/wechat_kit.git
- release
dependencies:
wechat_kit: ^${latestTag}
- example
This project is a starting point for a Flutter plug-in package, a specialized package that includes platform-specific implementation code for Android and/or iOS.
For help getting started with Flutter, view our online documentation, which offers tutorials, samples, guidance on mobile development, and a full API reference.