Flutter 插件开发-实战京东SDK唤醒(ios)

本项目基于Flutter版本1.12开发,功能是flutter可以通过京东的sdk唤醒京东app打开商品的详情。项目中的appkey需要自己申请,在这文章主要记录本人学习写插件的过程。

项目地址

总体的效果如下所示:

创建插件工程

通过Android stuido 工具来创建插件工程,其他方式可以用命令来创建。

写上包名就可以,这里默认不选,指的是插件以java和oc的实现。下一步等待创建完成。

创建后的工程目录

lib:插件flutter调用原生的代码

android: 实现Android的插件代码

ios: 实现ios的插件代码

example: 默认示例的代码

编译和运行ios插件示例

这里先把创建的插件工程编译和运行起来,因为ios有些坑需要记录下。不像android那样直接跑就行了。

首先需要在example工程下的ios目录,执行futter build ios,主要是需要pod install,生成xxx.workspace的一些配置

flutter build ios

运行xcode ,报错Building for iOS, but the linked and embedded framework ‘App.framework’,如果你能顺利跑起来,无视接下来的解决方案,跳过就此小节。

回到项目的根目录,执行flutter clean

flutter clean

然后删除ios/Flutter/App.framework

rm -rf ios/Flutter/App.framework

再次运行xcode就可以了。

编写flutter的插件调用代码

打开lib目录,默认有一个官方提供的方法是调用原生代码获取版本号的功能。本项目有两个功能,一个是京东sdk的初始化,一个是通过京东商品的url唤醒京东app的商品详情页。

import 'dart:async';

import 'package:flutter/foundation.dart';

import 'package:flutter/services.dart';

class Jdsdk {

static const MethodChannel _channel =

const MethodChannel('jdsdk');

static Future get platformVersion async {

final String version = await _channel.invokeMethod('getPlatformVersion');

return version;

}

///初始化sdk

static Future init({@required String appKey, @required String appSecret}) async {

final String version = await _channel.invokeMethod('init',{"appKey": appKey, "appSecret": appSecret});

return version;

}

///打开京东任意url

static Future openUrl({@required String url}) async {

final String version = await _channel.invokeMethod('openUrl',{"url": url});

return version;

}

}

导入SDK的Bundler和Framework

这里演示ios端添加京东sdk的几个步骤

sdk的内容有两个,一个bundle,一个Framework

打开xcode工程,通过下面的方式打开,还可以使用example目录下的ios目录打开也一样

JDSDK.bundle的添加,这里选择了copy item和Create groups。这个bundle下面只有一张safe.jpg的安全图片,需要到京东官方后天管理去下载生成才可以用。

4.Framework的添加

新建Framework文件夹,并将SDK的framework拉入该文件夹下。

回到xcode工程,添加刚刚framework,弹框不用选择copy。

添加几个系统的库,这是接入文档要求的。

最后在插件podspec文件,添加如下代码,终端进入example下ios目录执行pod install

s.vendored_frameworks = 'Framework/*.framework'

开发ios原生的实现接口

目录有点深,看图

JdsdkPlugin.m就是要实现的原生代码,handleMethodCall就是dart调用的函数。直接上代码,init 和openUrl就是上面lib目录定义的接口参数要一致,不然调用不到。

- (void)handleMethodCall:(FlutterMethodCall*)call result:(FlutterResult)result {

if ([@"getPlatformVersion" isEqualToString:call.method]) {

result([@"iOS " stringByAppendingString:[[UIDevice currentDevice] systemVersion]]);

} else if ([@"init" isEqualToString:call.method]) {

NSLog(@"init flutter");

//初始化sdk具体实现

NSString *appKey = call.arguments[@"appKey"];

NSString *appSecret = call.arguments[@"appSecret"];

NSLog (@"appKey is :%@", appKey);

NSLog (@"appSecret is :%@", appSecret);

[[KeplerApiManager sharedKPService]asyncInitSdk:appKey secretKey:appSecret sucessCallback:^(){

NSLog (@"success");

result(@"{status:1}");

}failedCallback:^(NSError *error){

NSLog (@"fail");

result(@"{status:0}");

}];

}else if ([@"openUrl" isEqualToString:call.method]) {

//打开京东任意url

NSString *url = call.arguments[@"url"];

if ([[UIApplication sharedApplication]canOpenURL:[NSURL URLWithString:[NSString stringWithFormat:@"openapp.jdmobile://"]]]) {//判断是否安装京东app

[ [KeplerApiManager sharedKPService]openKeplerPageWithURL:url userInfo:nil successCallback:^{

NSLog (@"success");

result(@"{status:1}");

} failedCallback:^(NSInteger code, NSString * _Nonnull url) {

NSLog (@"fail");

result(@"{status:0}");

}];

}else{

result(@"{status:0}");

}

}else {

result(FlutterMethodNotImplemented);

}

}

具体如何使用?

本文地址:https://blog.csdn.net/weixin_42797048/article/details/106750190

希望与广大网友互动??

点此进行留言吧!

京东下单接口sdk java,Flutter 插件开发-接入京东SDK唤醒(ios篇)相关推荐

  1. 在线客服软件海豚客服APP接入方法二:IOS篇

    在线客服软件海豚客服支持安卓和IOS应用接入,本篇分享IOS系统APP应用接入方法分享: 选择[系统接入]-[APP]-[新增渠道] 设置[新增渠道–渠道名称–确定],部署配置,复制链接,并由APP开 ...

  2. Unreal Engine 虚幻引擎 接入第三方SDK

    前言 虚幻引擎对SDK接入有着一套专门的方式,本文主要描述了如何给使用虚幻引擎开发的项目接入第三方SDK,并分享了接入微信SDK的分享等基础功能的实践过程,还涉及到调试和提高整合SDK效率的一些方法. ...

  3. 圆通开放平台电子面单下单接口,适用于第三方系统对接

    圆通开放平台电子面单下单接口 语言JAVA 作者:不停留的风 1.查询需要下单的圆通订单数据 2.把需要进行电子面单下单的数据转成XML格式 3.传输数据 4.获取服务端的反馈信息 5.把反馈的信息 ...

  4. 京东开普勒php接口,IOS菜鸟初学第十五篇:接入京东开普勒sdk,呼起京东app打开任意京东的链接-Go语言中文社区...

    我之前写了一篇关于接入京东联盟sdk的文章,但是最近,由于这个原因,如下图 导致需要重新集成京东的sdk,但是由于某种原因,因为android和ios端不统一,android接入的是京东开普勒的SDK ...

  5. 京东评论接口,item_review - 获得JD商品评论接口接入参数解决方案

    一.京东评论接口,item_review - 获得JD商品评论接口接入解决方案 点击注册获取key和secret测试账号 提取京东商品详情页评论,评论内容,评论日期,评论图片,买家昵称,评论商品属性, ...

  6. 支付宝统一下单接口的接入(1)

    因为公司需求所以就去看了一下支付宝的支付接入,在这里记录一下,也为了加深一下印象. 首先需要进入到支付宝的开放平台根据文档配置好相应的配置. 配置依赖 <!-- https://mvnrepos ...

  7. APP 对接 java 微信支付统一下单接口

    首先插入微信支付的时序图 统一下单时候的请求对象,需要把这个转为xml 文件格式所以需要在pom.xml 文件中导入 .和微信支付的sdk <dependency> <groupId ...

  8. java微信支付 [统一下单接口] 与 [订单查询接口] 调用成功完整代码与结果

    公司最近要搞微信支付, 之前也没有做过, 但是搞过阿里云, 想来也不是很难. 在网上找了很多贴子, 在eclipse里做了5个测试工程, 没有测试成功, 后来下了微信SDK, 也做了个测试样例, 期间 ...

  9. 微信小程序接入微信支付(二):后台调用统一下单接口

    微信统一支付官方文档:https://pay.weixin.qq.com/wiki/doc/api/wxa/wxa_api.php?chapter=9_1 因该接口需要商户系统中自己的订单编号,笔者先 ...

  10. java异步调用微信接口_微信支付V3 SDK(Java版,支持同步异步调用)

    我们在开发微信支付时,发现微信官方已经对SDK做了升级,V3版本的SDK从设计上符合RESTful规范. 我们再在开源库中寻找是否有现成de开箱即用.并且支持响应式编程的SDK版本.经过一凡寻找,令我 ...

最新文章

  1. 数据结构之二叉搜索树(BST)
  2. 2016百度星资格赛1002 大数相加
  3. 根据输入的日期计算你活了多少天(新手)
  4. tnsname.ora文件配置详解
  5. 系统ICP通信参数配置
  6. App乱世,3721离我们有多远
  7. 5. extjs 中buttonAlign什么意思
  8. .net Mvc Controller 接收 Json/post方式 数组 字典 类型 复杂对象
  9. 第二篇:操纵MySQL数据库(2) - 基于ORM思想的SQLAlchemy库
  10. 19.TCP/IP 详解卷1 --- TCP 的交互数据流
  11. 写c++好的软件_族谱家谱制作怎么写?专业的家谱族谱编辑制作软件哪个好
  12. 大话Elasticsearch常用操作和核心原理
  13. 疫情推动下的云联络中心终于引起了销售行业的重视。
  14. 如何用微云永久外链MP3做QQ空间背景音乐?
  15. ssh 报 You don't exist, go away
  16. 学大伟业Day1解题报告
  17. Es refresh index
  18. 前端进阶-ES6函数
  19. Nacos服务健康监测
  20. 【移动网络】Ch. 1 5G标准化与频谱

热门文章

  1. stm32矩阵键盘学习笔记
  2. 背包问题1:【SSL】1059.01背包问题——2021-03-10更
  3. 《软件测试的艺术》笔记
  4. 中国环境统计年鉴(2000到2018年)
  5. FileUtils工具类的使用
  6. 文件资源管理软件EagleFiler for Mac
  7. 正确方式安装Acrobat DC(附安装包)
  8. pyecharts在jupyter notebook中使用报错
  9. 宏杉科技中标中国移动存储集采喜获50%份额
  10. python达梦数据库_Python 封装 DM 达梦 数据库操作(使用类封装基本的增删改查)...