Fluwx:让在Flutter中使用微信SDK成为可能

简介: fluwx_logo.png前言之前有了解的小伙伴可能已经看过Fluwx的一篇文章,不过那个时候Fluwx还是不太成熟。现在Fluwx的主体功能已经过成了。
img_0339bd14282dfe00386dd13fd6c33c95.png
fluwx_logo.png

前言

之前有了解的小伙伴可能已经看过Fluwx的一篇文章,不过那个时候Fluwx还是不太成熟。现在Fluwx的主体功能已经过成了。如果你正在或想开发一个Flutter项目但苦于无法使用微信分享、登录,那么Fluwx可能正是你所要寻找的。
尽管Fluwx旨在减化工作量,但在使用Fluwx之前,我还是强烈建议先阅读微信SDK官方文档,这有助于了解一些概念,有利于调试问题。
项目地址

目前功能

  • 文本分享。
  • 网站分享。
  • 图片分享。
  • 音乐分享。
  • 视频分享。
  • 小程序分享。
  • 发送Auth认证。

技术参数

Android部分使用到了kotlin-1.2.60。以下是Android部分所涉及到的技术:

 api 'com.tencent.mm.opensdk:wechat-sdk-android-with-mta:5.1.4'
 implementation 'org.jetbrains.kotlinx:kotlinx-coroutines-core:0.24.0'
 implementation 'org.jetbrains.kotlinx:kotlinx-coroutines-android:0.24.0'
 implementation 'top.zibin:Luban:1.1.8'
 implementation 'com.squareup.okhttp3:okhttp:3.11.0'

其中Luban是用来图片压缩的。
iOS部分涉及到的技术:

 s.dependency 'WechatOpenSDK','~> 1.8.2'

Flutter版本信息

Flutter 0.7.5 • channel dev • https://github.com/flutter/flutter.git

Framework • revision eab5cd9853 (4 days ago) • 2018-08-30 14:47:04 -0700

Engine • revision dc7b5eb89d

Tools • Dart 2.1.0-dev.3.0.flutter-760a9690c2

引入

pubspec.yaml文件中添加如下代码:

dependencies:
  fluwx: ^0.1.3

添加完成后不要忘记flutter packages get

初始化

使用Fluwx前,需要进行初始化操作:

Fluwx.registerApp(RegisterModel(appId: "your app id", doOnAndroid: true, doOnIOS: true));
  • appId:在微信平台申请的appId。
  • doOnAndroid:是否在android平台上执行此操作。
  • doOnIOS:是否在平台上执行此操作。</br>
    每一个字段都是非必须的,但是如果不传appIddoOnAndroid: false或者doOnIOS: false,请务必手动注册WXApi以保证Fluwx正常工作。
    注册完成后,请在使用Fluwx前在对应平台添加如下代码:
    Android上:
FluwxShareHandler.setWXApi(wxapi)

iOS上:

isWeChatRegistered = YES;

注意:尽管可以通过Fluwx完成微信注册,但一些操作依然需要在对应平台进行设置,如配置iOS的URLSchema,Android上的WXEntryActivity等,否则Fluwx无法正常工作。

如何发起分享

很遗憾,Fluwx并不是支持所有的分享类型。目前仅支持文本、图片、网址
音乐、视频以及小程序的分享。其他分享将在未来版本得到支持。

注意:目前分享中涉及到图片的地方仅支持pngjpg,支持网络图片及assets图片。

使用assets图片需要添加assets://

也可以在assets图片添加?package=package_name以读取指定包的图片。

未来可能支持file://,目前以file://图片不会做任何处理。

如果不指定schema或者schema错误,将会被处理为网络图片,请谨慎。

由于微信的限制,一般的缩略图要小于32k(小程序的缩略图要小于120k),所以在使用缩略的时候

很有必要使用一张合格的缩略图,否则Fluwx进行压缩,其结果可能并不是你所预期的。

分享去处

绝大部分分享可以分享到会话,朋友圈,收藏(小程序目前只能分享到会话)。默认分享到会话:

    ///[WeChatScene.SESSION]会话
    ///[WeChatScene.TIMELINE]朋友圈
    ///[WeChatScene.FAVORITE]收藏
    enum WeChatScene {
      SESSION,
      TIMELINE,
      FAVORITE
      }

分享文本

  fluwx.share(WeChatShareTextModel(
      text: "text from fluwx",
      transaction: "transaction}",//仅在android上有效,下同。
      scene: scene
    ));

分享图片

 fluwx.share(WeChatShareImageModel(
        image: _imagePath,
        thumbnail: _thumbnail,
        transaction: _imagePath,
        scene: scene,
        description: "image"));

注意:如果不指定 thumbnail,那么Fluwx将尝试从image中获取缩略图。

分享音乐

  var model = WeChatShareMusicModel(
      title: _title,
      description: _description,
      transaction: "music",
      musicUrl: _musicUrl,
      musicLowBandUrl: _musicLowBandUrl
    );

    fluwx.share(model);

音乐的分享有两种:musicUrlmusicLowBandUrl。这两种形式是不共存的,如果
都二者都进行了赋值,那么只会读取musicUrl

分享视频

   var model = new WeChatShareVideoModel(
     videoUrl: _videoUrl,
     transaction: "video",
     videoLowBandUrl: _videoLowBandUrl,
     thumbnail: _thumnail,
     description: _description,
     title: _title
   );
   fluwx.share(model);

视频的分享有两种:videoUrlvideoLowBandUrl。这两种形式是不共存的,如果
都二者都进行了赋值,那么只会读取videoUrl

分享小程序

 var model =new WeChatShareMiniProgramModel(
      webPageUrl: _webPageUrl,
      miniProgramType: WeChatShareMiniProgramModel.MINI_PROGRAM_TYPE_RELEASE,
      userName: _userName,
      title: _title,
      description: _description,
      thumbnail: _thumbnail
    );
    fluwx.share(model);

miniProgramType仅支持三种:

  • MINI_PROGRAM_TYPE_RELEASE
  • MINI_PROGRAM_TYPE_TEST
  • MINI_PROGRAM_TYPE_PREVIEW

发送Auth认证

对于微信登录,Fluwx只实现了第一步,即获取code,若要获取access_token请在服务器端完成。

   fluwx.sendAuth(WeChatSendAuthModel(
      scope: "snsapi_userinfo",
      state:"wechat_sdk_demo_test",
    ));

发起支付

每个参数的意义请参考官方文档:

Fluwx fluwx = new Fluwx();
fluwx.pay(WeChatPayModel(
                  appId: 'wxd930ea5d5a258f4f', 
                  partnerId: '1900000109',
                  prepayId: '1101000000140415649af9fc314aa427',
                  packageValue: 'Sign=WXPay',
                  nonceStr: '1101000000140429eb40476f8896f4c9',
                  timeStamp: '1398746574',
                  sign: '7FFECB600D7157C5AA49810D2D8F28BC2811827B',
                  signType: '选填',
                  extData: '选填'
                ));

微信回调

fluwx发起分享、支付或登录请求都会有返回值,但这并不是微信回调的值:

    {
      "platform":"Android",//或者iOS
       result:true //或者false,取决于WXApi.sendRequest()的结果
     }

由于微信的回调是异步的,我们需要从response中监听:

    _fluwx.response.listen((response){
      //do something
    });

从微信回调的值为WeChatResponse,其实type字段为枚举:

enum WeChatResponseType {
    SHARE,
    AUTH,
    PAYMENT }

result为微信回传的值,其类型为Map,具体返回值请参阅微信官方文档,但均额外包含一个
platform字段,其值为android或者iOS,以便开发者作差异化处理。
但微信的回调也要根据平台的不同进行差异化处理(如果你不需要回调,请忽略)。

Android

由于机制问题,Android端需要在WXEntryActivityWXPayEntryActivity中添加如下代码:

   override fun onResp(resp: BaseResp) {
        FluwxResponseHandler.handleResponse(resp)
   }

你也可以直接继承FluwxWXEntryActivity
WXEntryActivityWXPayEntryActivity创建规则请参阅官方文档。具体可以参考example wxapi
,也不要忘记在AndroidManifest.mxl中注册:

     <activity
            android:name="your.package.name.registered.on.wechat.wxapi.WXEntryActivity"
            android:theme="@style/DisablePreviewTheme"
            android:exported="true"
            android:launchMode="singleTop"/>
     <activity
            android:name="your.package.name.registered.on.wechat.wxapi.WXPayEntryActivity"
            android:theme="@style/DisablePreviewTheme"
            android:exported="true"
            android:launchMode="singleTop"/>

iOS

在你的AppDelegate.m中重写下面方法:

- (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url {
    return [WXApi handleOpenURL:url delegate:[FluwxResponseHandler responseHandler]];
}

- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<NSString*, id> *)options{
  return [WXApi handleOpenURL:url delegate:[FluwxResponseHandler responseHandler]];
}

结束

以上就是Fluwx的使用方法,希望对大伙有所帮助。
项目地址,多多star。
另外还有一个支付宝支付项目tobias正在开发当中。
希望大家可以关注JarvanMoOpenFlutter

目录
相关文章
|
20天前
|
IDE 开发工具
鸿蒙Flutter实战:11-使用 Flutter SDK 3.22.0
本文介绍了如何使用 Flutter SDK 3.22.0 搭建鸿蒙开发环境。首先安装 Flutter SDK 3.22.0,并通过 FVM 管理多个版本。接着配置项目,使用 `fvm use custom_3.22.0` 设置自定义 SDK 版本。添加鸿蒙平台支持并进行项目签名,最后通过 `fvm flutter run` 运行项目。详细步骤包括安装、项目配置、签名和运行,确保开发环境顺利搭建。
44 7
鸿蒙Flutter实战:11-使用 Flutter SDK 3.22.0
|
1月前
|
JSON 前端开发 API
使用微信JS-SDK调用发票接口的完整开发指南
本文介绍了如何使用微信JS-SDK的`chooseInvoiceTitle`接口来调用微信的发票功能。通过微信发票接口,用户可以选择开具个人或单位发票,并获取相关发票信息,如抬头、税号、公司地址等。在文中,详细描述了JS-SDK的初始化、发票接口的调用方式,并提供了完整的代码示例。文章还介绍了如何处理返回的发票信息,帮助开发者快速集成微信发票功能。
75 2
|
1月前
|
移动开发 安全 API
微信H5支付--微信JS-SDK支付--点金计划
本文详细介绍了微信H5支付和JS-SDK支付的原理、配置和开发流程,涵盖了H5支付在移动端浏览器外唤起微信支付的细节,以及JS-SDK支付在微信内置浏览器中完成支付的相关注意事项。文章还针对微信支付常见问题,提供了解决方案和代码示例。最后,文章深入解析了微信支付点金计划,包括商家小票的自定义开发、API接口以及支付成功后的页面展示逻辑,为开发者提供了完整的开发参考。
35 0
微信H5支付--微信JS-SDK支付--点金计划
|
3月前
|
Dart 开发工具 Android开发
Android Studio导入Flutter项目提示Dart SDK is not configured
Android Studio导入Flutter项目提示Dart SDK is not configured
306 4
|
3月前
|
开发工具 Android开发
Flutter: Android SDK not found at this location,Android Studio not found at xxx
Flutter: Android SDK not found at this location,Android Studio not found at xxx
157 2
|
3月前
|
缓存 JavaScript 前端开发
微信 JS-SDK Demo “分享信息设置” API 及数字签名生成方法(NodeJS版本)
微信 JS-SDK Demo “分享信息设置” API 及数字签名生成方法(NodeJS版本)更新时间(2020-10-29)
|
4月前
|
PHP 开发工具
tp5+微信公众号服务器配置时使用官方sdk还是token验证失败
tp5+微信公众号服务器配置时使用官方sdk还是token验证失败
39 0
|
5月前
|
API 开发工具
企业微信SDK接口API调用-触发推送企业微信微信好友
企业微信SDK接口API调用-触发推送企业微信微信好友
|
1月前
|
JSON 小程序 JavaScript
uni-app开发微信小程序的报错[渲染层错误]排查及解决
uni-app开发微信小程序的报错[渲染层错误]排查及解决
484 7
|
1月前
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
537 1