Fluwx:让在Flutter中使用微信SDK成为可能
前言
之前有了解的小伙伴可能已经看过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> 每一个字段都是非必须的,但是如果不传appId
或doOnAndroid: false
或者doOnIOS: false
,请务必手动注册WXApi
以保证Fluwx
正常工作。 注册完成后,请在使用Fluwx
前在对应平台添加如下代码: Android上:FluwxShareHandler.setWXApi(wxapi) iOS上:isWeChatRegistered = YES;注意:尽管可以通过Fluwx
完成微信注册,但一些操作依然需要在对应平台进行设置,如配置iOS的URLSchema,Android上的WXEntryActivity等,否则Fluwx
无法正常工作。
如何发起分享
很遗憾,Fluwx
并不是支持所有的分享类型。目前仅支持文本、图片、网址
音乐、视频以及小程序的分享。其他分享将在未来版本得到支持。
注意:目前分享中涉及到图片的地方仅支持
png
和jpg
,支持网络图片及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);
音乐的分享有两种:musicUrl
和musicLowBandUrl
。这两种形式是不共存的,如果
都二者都进行了赋值,那么只会读取musicUrl
。
分享视频
var model = new WeChatShareVideoModel(
videoUrl: _videoUrl,
transaction: "video",
videoLowBandUrl: _videoLowBandUrl,
thumbnail: _thumnail,
description: _description,
title: _title
);
fluwx.share(model);
视频的分享有两种:videoUrl
和videoLowBandUrl
。这两种形式是不共存的,如果
都二者都进行了赋值,那么只会读取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
端需要在WXEntryActivity
或WXPayEntryActivity
中添加如下代码:
override fun onResp(resp: BaseResp) {
FluwxResponseHandler.handleResponse(resp)
}
你也可以直接继承FluwxWXEntryActivity
。
WXEntryActivity
和WXPayEntryActivity
创建规则请参阅官方文档。具体可以参考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
的使用方法,希望对大伙有所帮助。另外还有一个支付宝支付项目tobias正在开发当中。
希望大家可以关注JarvanMo和OpenFlutter。
- 网站源文件被注入了iframe代码—ARP欺骗的木马病毒攻击
- ASP.NET MVC5+EF6+EasyUI 后台管理系统--工作流演示截图
- 基于CPPN与GAN+VAE生成高分辨率图像
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(54)-工作流设计-所有流程监控
- (收藏)搭建.NET Framework 3.0开发环境 及SharePoint 2007/WSS 3环境
- WCF技术剖析之八:ClientBase<T>中对ChannelFactory<T>的缓存机制
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(48)-工作流设计-起草新申请
- 把windows2003“搬”到手机上。
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(53)-工作流设计-我的批阅
- ASP.NET MVC5+EF6+EasyUI 后台管理系统--任务调度系统解析
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(52)-美化EasyUI皮肤和图标
- ASP.NET MVC5+EF6+EasyUI 后台管理系统--系统权限全套完整图
- 互联网时代的产品升级和用户反馈故事
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(50)-Easyui 扁平化皮肤
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- php和redis实现秒杀活动的流程
- CentOS 7中搭建NFS文件共享存储服务的完整步骤
- PHP检测一个数组有没有定义的方法步骤
- Yii2.0框架模型多表关联查询示例
- Yii2.0框架模型添加/修改/删除数据操作示例
- thinkphp5.1框架容器与依赖注入实例分析
- 在CentOS VPS上通过SSH安装 MySQL的办法图解
- 详解PHP 7.4 中数组延展操作符语法知识点
- linux下安装boost库的完整步骤记录
- Python图像处理二值化方法实例汇总
- 利用Python实现斐波那契数列的方法实例
- Python如何实现大型数组运算(使用NumPy)
- 因str_replace导致的注入问题总结
- laravel框架中间件 except 和 only 的用法示例
- 浅析Python 多行匹配模式