React Native 的友盟集成

前言

最近从iOS开发转到RN开发, 碰到许多坑, 想记录下来巩固学习. 希望本文能帮到你~~

免费获得:

  • SDK下载及文档
  • 安卓集成指南
  • iOS集成指南

SDK下载及文档

SDK地址: 官方下载 (记得关VPN访问友盟官网哟~)
文档地址: 偷看一下

安卓集成指南

未接触过安卓开发的, 看到文档的时候一定头很大. 没事我来带大家一步一步趟过去.

1.检查SDK文件

我们SDK下载下来后看到的文件夹, 包括Android和ReactNative部分.Android里放的是jar文件, ReactNative里放的是java文件. 参考如下:


图1
图2

2.放jar文件

这个最简单! 放进工程目录的libs文件夹下, 搞定~ 路径如下:


图3

2-1添加依赖

我们先到android/app/build.gradle


图4

找到dependencies, 添加架包(有两种方式,自己搭配啦~):

1.通用:
dependencies {
    compile fileTree(include: ['*.jar'], dir: 'libs')
2.每个都添加一次:
dependencies {
    compile files('libs/umeng-analytics-7.5.3.jar')
    compile files('libs/umeng-common-1.5.3.jar')

2-2查看权限配置

到android/app/src/main/AndroidMainifest.xml


图5

配置好权限, 当然你可以参考官方demo, 选择其他权限获取更精准的数据啦~

    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
    <uses-permission android:name="android.permission.READ_PHONE_STATE"/>

3. 放java文件

文档没写路径, 只写了文件引用. 超超找了路径给你们~ 如下:


图6

这里不要直接抄demo, 要放在包名路径下.
比如你的包名是com.umeng, 那么可以在java/com/umeng/里建个'invokenative'放java文件, 如下:


图7

剩下的就是根据警告, 修正引用路径~

4.引用问题

如果之前没开发安卓的经验, 这里要注意'引用路径'的问题:
所有demo中引用的路径一定不能照抄demo的如:
import com.umeng.soexample.invokenative.RNUMConfigure;
如果你的路径是com/umeng/invokenative, 那要改成:
import com.umeng.invokenative.RNUMConfigure;

5.初始化

5-1MainActivity中初始化

代码如下:

public class MainActivity extends ReactActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        //ShareModule.initSocialSDK(this);
        //PushModule.initPushSDK(this);
        MobclickAgent.setSessionContinueMillis(1000);
        MobclickAgent.setScenarioType(this, EScenarioType.E_DUM_NORMAL);
        MobclickAgent.openActivityDurationTrack(false);
        //PushAgent.getInstance(this).onAppStart();
    }


    @Override
    public void onResume() {
        super.onResume();
        MobclickAgent.onResume(this);
    }
    @Override
    protected void onPause() {
        super.onPause();
        MobclickAgent.onPause(this);
    }

5-2MainApplication中初始化

代码如下:

 @Override
        protected List<ReactPackage> getPackages() {
            return Arrays.<ReactPackage>asList(
                new MainReactPackage(),
                new DplusReactPackage()
            );
        }
    };


    @Override
    public void onCreate() {
        super.onCreate();
        SoLoader.init(this, /* native exopackage */ false);
        UMConfigure.setLogEnabled(true);
        //初始化组件化基础库, 统计SDK/推送SDK/分享SDK都必须调用此初始化接口
        RNUMConfigure.init(this, "59892f08310c9307b60023d0", "Umeng", UMConfigure.DEVICE_TYPE_PHONE,
            "669c30a9584623e70e8cd01b0381dcb4");
        //initUpush();

    }

注意:未集成推送功能, secret参数可以传空字符串"".

iOS集成指南:

跟安卓一样, iOS有单独的文件夹, 放着对应的framework, 我们只要打开工程, 学着demo做:

1.引用framework和桥接文件

  • 找到framework如下:


    图8
  • 找到2个必要的桥接文件


    图9
图10

为了以后统一管理, 把framework放到UMComponents文件夹里, 把桥接文件放到文件夹UMReactBridge文件夹.
再把这两个文件夹用鼠标拖到工程中. 如下图:


图11

接下来按照demo里初始化代码如下:

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
  [UMConfigure setLogEnabled:NO];
  [RNUMConfigure initWithAppkey:@"我的appkey" channel:@"App Store"];
  
  [MobClick setScenarioType:E_UM_NORMAL];
  [MobClick setCrashReportEnabled:YES];

到这里iOS友盟就集成完毕了~~

2.魔性BUG

注意: demo写了 [UMessage addLaunchMessage]; 记得删掉哦! 不然app会有魔性的启动屏哦~ 感兴趣的小伙伴可以自己玩玩看~
到此, 友盟的集成完毕!
如果小伙伴们有埋点的需求的可以参考文章:React Native 友盟统计--打点/埋点

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,014评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,796评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,484评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,830评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,946评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,114评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,182评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,927评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,369评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,678评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,832评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,533评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,166评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,885评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,128评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,659评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,738评论 2 351

推荐阅读更多精彩内容