Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Fluwx:让在Flutter中使用微信SDK成为可能

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

原创
作者头像
JarvanMo
发布于 2018-09-05 15:34:34
发布于 2018-09-05 15:34:34
4.2K0
举报
文章被收录于专栏:JarvanMo的IT专栏JarvanMo的IT专栏
fluwx_logo.png
fluwx_logo.png

前言

之前有了解的小伙伴可能已经看过Fluwx的一篇文章,不过那个时候Fluwx还是不太成熟。现在Fluwx的主体功能已经过成了。如果你正在或想开发一个Flutter项目但苦于无法使用微信分享、登录,那么Fluwx可能正是你所要寻找的。

尽管Fluwx旨在减化工作量,但在使用Fluwx之前,我还是强烈建议先阅读微信SDK官方文档,这有助于了解一些概念,有利于调试问题。

目前功能

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

技术参数

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

代码语言:txt
复制
代码语言:txt
AI代码解释
复制
api 'com.tencent.mm.opensdk:wechat-sdk-android-with-mta:5.1.4'
代码语言:txt
AI代码解释
复制
implementation 'org.jetbrains.kotlinx:kotlinx-coroutines-core:0.24.0'
代码语言:txt
AI代码解释
复制
implementation 'org.jetbrains.kotlinx:kotlinx-coroutines-android:0.24.0'
代码语言:txt
AI代码解释
复制
implementation 'top.zibin:Luban:1.1.8'
代码语言:txt
AI代码解释
复制
implementation 'com.squareup.okhttp3:okhttp:3.11.0'
代码语言:txt
复制

其中Luban是用来图片压缩的。

iOS部分涉及到的技术:

代码语言:txt
复制
代码语言:txt
AI代码解释
复制
s.dependency 'WechatOpenSDK','~> 1.8.2'
代码语言:txt
复制

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文件中添加如下代码:

代码语言:txt
AI代码解释
复制
dependencies:
  fluwx: ^0.1.3

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

初始化

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

代码语言:txt
复制

Fluwx.registerApp(RegisterModel(appId: "your app id", doOnAndroid: true, doOnIOS: true));

代码语言:txt
复制
  • 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并不是支持所有的分享类型。目前仅支持文本、图片、网址

代码语言:txt
AI代码解释
复制
音乐、视频以及小程序的分享。其他分享将在未来版本得到支持。

注意:目前分享中涉及到图片的地方仅支持pngjpg,支持网络图片及assets图片。 使用assets图片需要添加assets://。 也可以在assets图片添加?package=package_name以读取指定包的图片。 未来可能支持file://,目前以file://图片不会做任何处理。 如果不指定schema或者schema错误,将会被处理为网络图片,请谨慎。 由于微信的限制,一般的缩略图要小于32k(小程序的缩略图要小于120k),所以在使用缩略的时候 很有必要使用一张合格的缩略图,否则Fluwx进行压缩,其结果可能并不是你所预期的。分享去处

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

代码语言:txt
AI代码解释
复制
    ///[WeChatScene.SESSION]会话
    ///[WeChatScene.TIMELINE]朋友圈
    ///[WeChatScene.FAVORITE]收藏
    enum WeChatScene {
      SESSION,
      TIMELINE,
      FAVORITE
      }

分享文本

代码语言:txt
AI代码解释
复制
  fluwx.share(WeChatShareTextModel(
      text: "text from fluwx",
      transaction: "transaction}",//仅在android上有效,下同。
      scene: scene
    ));

分享图片

代码语言:txt
AI代码解释
复制
 fluwx.share(WeChatShareImageModel(
        image: _imagePath,
        thumbnail: _thumbnail,
        transaction: _imagePath,
        scene: scene,
        description: "image"));

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

分享音乐

代码语言:txt
AI代码解释
复制
  var model = WeChatShareMusicModel(
      title: _title,
      description: _description,
      transaction: "music",
      musicUrl: _musicUrl,
      musicLowBandUrl: _musicLowBandUrl
    );

    fluwx.share(model);

音乐的分享有两种:musicUrlmusicLowBandUrl。这两种形式是不共存的,如果

都二者都进行了赋值,那么只会读取musicUrl

分享视频

代码语言:txt
AI代码解释
复制
   var model = new WeChatShareVideoModel(
     videoUrl: _videoUrl,
     transaction: "video",
     videoLowBandUrl: _videoLowBandUrl,
     thumbnail: _thumnail,
     description: _description,
     title: _title
   );
   fluwx.share(model);

视频的分享有两种:videoUrlvideoLowBandUrl。这两种形式是不共存的,如果

都二者都进行了赋值,那么只会读取videoUrl

分享小程序

代码语言:txt
AI代码解释
复制
 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请在服务器端完成。

代码语言:txt
AI代码解释
复制
   fluwx.sendAuth(WeChatSendAuthModel(
      scope: "snsapi_userinfo",
      state:"wechat_sdk_demo_test",
    ));

发起支付

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

代码语言:txt
AI代码解释
复制
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发起分享、支付或登录请求都会有返回值,但这并不是微信回调的值:

代码语言:txt
AI代码解释
复制
    {
      "platform":"Android",//或者iOS
       result:true //或者false,取决于WXApi.sendRequest()的结果
     }

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

代码语言:txt
AI代码解释
复制
    _fluwx.response.listen((response){
      //do something
    });

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

代码语言:txt
AI代码解释
复制
enum WeChatResponseType {
    SHARE,
    AUTH,
    PAYMENT }

result为微信回传的值,其类型为Map,具体返回值请参阅微信官方文档,但均额外包含一个

platform字段,其值为android或者iOS,以便开发者作差异化处理。

但微信的回调也要根据平台的不同进行差异化处理(如果你不需要回调,请忽略)。

Android

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

代码语言:txt
AI代码解释
复制
   override fun onResp(resp: BaseResp) {
        FluwxResponseHandler.handleResponse(resp)
   }

你也可以直接继承FluwxWXEntryActivity

WXEntryActivityWXPayEntryActivity创建规则请参阅官方文档。具体可以参考example wxapi

,也不要忘记在AndroidManifest.mxl中注册:

代码语言:txt
AI代码解释
复制
     <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中重写下面方法:

代码语言:txt
AI代码解释
复制
- (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的使用方法,希望对大伙有所帮助。另外还有一个支付宝支付项目tobias正在开发当中。

希望大家可以关注JarvanMoOpenFlutter

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
最新Flutter 微信分享功能实现【Flutter专题23】
Flutter 用来快速开发 Android iOS平台应用,在Flutter 中,通过 fluwx或者fluwx_no_pay 插件来实现微信分享功能
徐建国
2022/03/30
1.9K0
最新Flutter 微信分享功能实现【Flutter专题23】
react-native集成微信分享记录
去微信官方网址https://open.weixin.qq.com/,注册移动应用,填写相关信息,获取到相关到key
w候人兮猗
2020/06/24
2.5K0
unity3d+androidstudio:接微信官方分享sdk
1.得到的签名在微信后台一定要填对,不然返回-6 2.如果测试微信调不起来,清除微信缓存,即可,因为上次的错误信息保存了
立羽
2023/08/24
2450
unity3d+androidstudio:接微信官方分享sdk
react-native集成微信分享记录
关于微信分享,主要用到了这两个库 react-native-wechat-lib react-native-wechat
w候人兮猗
2020/07/01
1.1K1
react-native集成微信分享记录
Android App跳转微信小程序教程
最近,有一个App跳转小程序的需求,参考微信的官方文档,接入还是比较简单的,不过中途遇到了一个坑,所以记录一下。
PHP开发工程师
2022/05/06
4.8K0
Android App跳转微信小程序教程
AppDelegate减负之常用三方封装 - 友盟分享 / 三方登录篇
http://www.cnblogs.com/zhouxihi/p/7113511.html
周希
2019/10/15
5850
Flutter实战:手把手教你写Flutter Plugin
如果你对移动端有所关注,那么你一定会听说过Flutter。得益于Google,Flutter一经推出便得受到了广泛关注。很多开发者跃跃欲试,国内部分大厂,诸如美团、闲鱼等团队已经开始了Flutter实践之旅了。笔者也是蹭了一波热度,学习了一下Flutter。Flutter虽然真香,但目前社区显然还是很不健全,像微信SDK、支付宝等第三方SDK都无法在Flutter项目上直接使用。想要使用这些SDK就曲线救国了。 本文并不探讨如何发布一个Flutter Plugin,只谈如何实现Plugin。下面我将以我的开源项目fluwx为例,手把手教你如何写Flutter Plugin。
JarvanMo
2018/10/10
5.8K0
Flutter实战:手把手教你写Flutter Plugin
Android项目实战(五十):微信支付 坑总结
   包名在app目录下的build.gradle文件中可以查看,为applicationId 键的值
听着music睡
2018/09/20
1.2K0
Android项目实战(五十):微信支付 坑总结
Fluwx:微信SDK在Flutter上的实现
随着 Flutter越来越火热,我相信越来越多的小伙伴都跃跃欲试。但是一个很重要的问题是,很多第三方
JarvanMo
2018/08/25
1.7K0
Flutter中实现微信支付流程
上面的流程图来自于官方,看起来比较复杂,其实大部分的流程都是由官方自己完成的,下面是一个简易的流程图示例:
越陌度阡
2021/03/02
4.2K0
Flutter中实现微信支付流程
安卓app和微信授权登录及分享完整对接
注册微信开放平台,创建移动应用,填写一系列的信息,在应用平台填写app签名和包名,审核通过之后,取得AppID和 AppSecret
chuchur
2022/10/25
1.6K0
Flutter 微信SDK集成相关的轮子
简介 这是一个帮助开发者在Flutter中快速集成微信相关功能的一个插件 目前功能 文本分享。Fluwx fluwx = new Fluwx(); fluwx.share(WeChatShareImageModel( image: _imagePath, thumbnail: _thumbnail, transaction: _imagePath, scene: scene, description: "image")); 网站
坑吭吭
2018/08/27
1.6K0
Flutter 微信SDK集成相关的轮子
手把手教你Android端微信支付接入
  在你的package目录下,创建wxapi目录,比如说我使用的demo项目,wxapi就在目录net.sourceforge.simcpux目录下
顾翔
2019/12/12
1.3K0
手把手教你Android端微信支付接入
Flutter Notes | Android 借壳分享微信
每个生命体的存在,其实本质都是一个复杂的过程。很多时候,无需追求完美的理想情况,毕竟,You are just you。
贺biubiu
2020/06/29
1.2K0
Android微信之简单文本分享(集成官方SDK-Android Studio)
1.帐号申请 https://open.weixin.qq.com/ 首先登录微信开放平台,注册一个帐号 2.提交APP审核 为什么必须提交app审核呢?
专注APP开发
2019/11/07
2K0
Android微信之简单文本分享(集成官方SDK-Android Studio)
Android微信之登录授权(集成官方SDK-Eclipse)
文章参考:http://www.jianshu.com/p/2ea8ae0618ef
专注APP开发
2019/11/07
1.9K0
Android微信之登录授权(集成官方SDK-Eclipse)
集成微信登录和分享真的很简单
http://blog.csdn.net/lxk_1993/article/details/53066384
103style
2022/12/19
2840
集成微信登录和分享真的很简单
iOS微信之简单文本分享(集成官方SDK)
前期准备工作:可以参考这篇博文http://www.jianshu.com/p/839dc30f2250 iOS版本只需要提供Bundle Id即可
专注APP开发
2019/11/07
2.1K0
iOS微信之简单文本分享(集成官方SDK)
android微信支付
compile ‘com.tencent.mm.opensdk:wechat-sdk-android-with-mta:+’
tea9
2022/07/16
2.7K0
android微信支付
android 微信支付 简单实用
最后,关于测试,因为前面是线上的,所以本地测试是非常不方便的,这里有个小技巧,我们只要本地环境使用线上签名就行了。
yechaoa
2022/06/10
7980
android 微信支付 简单实用
相关推荐
最新Flutter 微信分享功能实现【Flutter专题23】
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档