day15:友盟


看官方API :https://www.umeng.com/

一.推送

在这里插入图片描述

1.添加产品

在这里插入图片描述

2.查看官方文档

在这里插入图片描述

在这里插入图片描述
剩下的直接看官方文档就OK了!!!!

二.分享

1.产品

在这里插入图片描述

2.官方文档

在这里插入图片描述
在这里插入图片描述
剩下的看官方文档就OK了
注意:建议手动集成SDK,官方文档都有介绍!!!!!

三.统计

1.产品

在这里插入图片描述

2.官方文档

在这里插入图片描述剩下的看官方文档就OK了!!

四.多渠道打包

1. 配置:

implementation 'com.umeng.sdk:common:1.5.1'
implementation 'com.umeng.sdk:analytics:7.5.0'

2.清单文件配置

application的子标签

<!--value的值填写你在友盟后台申请的应用Appkey-->
<meta-data android:value="5d3572c53fc19544630000d6" android:name="UMENG_APPKEY"/>
<!--value的值填写渠道名称,例如yingyongbao。这里设置动态渠道变量-->
<meta-data android:value="${UMENG_CHANNEL_VALUE}" android:name="UMENG_CHANNEL"/>

app中初始化

        UMConfigure.init(this,UMConfigure.DEVICE_TYPE_PHONE,"d7fcec413fce5cccd025907e910df4ea");

3. moudle gradle配置

android {
    compileSdkVersion 28
    buildToolsVersion "29.0.0"
    defaultConfig {
        flavorDimensions "default"//添加这句胡 不然报错
 
        applicationId "com.example.ument"
        minSdkVersion 15
        targetSdkVersion 28
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
        }
    }
    productFlavors {
        Alpha {//自己打包测试使用
             manifestPlaceholders = [UMENG_CHANNEL_VALUE: Alpha]
        }
        Tencent {//投放应用宝市场
             manifestPlaceholders = [UMENG_CHANNEL_VALUE: Tencent]
        }
        Baidu {//投放百度市场
             manifestPlaceholders = [UMENG_CHANNEL_VALUE: Baidu]
        }
        Qihoo {//投放360市场
             manifestPlaceholders = [UMENG_CHANNEL_VALUE: Qihoo]
        }
        Alibaba {//投放阿里巴巴
             manifestPlaceholders = [UMENG_CHANNEL_VALUE: Alibaba]
        }
        Vivo {//投放vivo市场
             manifestPlaceholders = [UMENG_CHANNEL_VALUE: Vivo]
        }
        Oppo {//投放oppo市场
             manifestPlaceholders = [UMENG_CHANNEL_VALUE: Oppo]
        }
        Xiaomi {//投放小米市场
             manifestPlaceholders = [UMENG_CHANNEL_VALUE: Xiaomi]
        }
        Huawei {//投放华为应用市场
             manifestPlaceholders = [UMENG_CHANNEL_VALUE: Huawei]
        }

        productFlavors.all { flavor ->
            flavor.manifestPlaceholders = [UMENG_CHANNEL_VALUE: name]
        }
        //这个属性会自定安装版本号来打包
android.applicationVariants.all { variant ->
            variant.outputs.all {
                outputFileName = "${name}_${variant.versionName}.apk"
            }
        }
    }

}

4.代码混淆

(1).gradle设置允许混淆

在这里插入图片描述

(2).以下是混淆文件 proguard-rules.pro

-dontshrink
-dontoptimize
-dontwarn com.google.android.maps.**
-dontwarn android.webkit.WebView
-dontwarn com.umeng.**
-dontwarn com.tencent.weibo.sdk.**
-dontwarn com.facebook.**
-keep public class javax.**
-keep public class android.webkit.**
-dontwarn android.support.v4.**
-keep enum com.facebook.**
-keepattributes Exceptions,InnerClasses,Signature
-keepattributes *Annotation*
-keepattributes SourceFile,LineNumberTable

-keep public interface com.facebook.**
-keep public interface com.tencent.**
-keep public interface com.umeng.socialize.**
-keep public interface com.umeng.socialize.sensor.**
-keep public interface com.umeng.scrshot.**

-keep public class com.umeng.socialize.* {*;}


-keep class com.facebook.**
-keep class com.facebook.** { *; }
-keep class com.umeng.scrshot.**
-keep public class com.tencent.** {*;}
-keep class com.umeng.socialize.sensor.**
-keep class com.umeng.socialize.handler.**
-keep class com.umeng.socialize.handler.*
-keep class com.umeng.weixin.handler.**
-keep class com.umeng.weixin.handler.*
-keep class com.umeng.qq.handler.**
-keep class com.umeng.qq.handler.*
-keep class UMMoreHandler{*;}
-keep class com.tencent.mm.sdk.modelmsg.WXMediaMessage {*;}
-keep class com.tencent.mm.sdk.modelmsg.** implements com.tencent.mm.sdk.modelmsg.WXMediaMessage$IMediaObject {*;}
-keep class im.yixin.sdk.api.YXMessage {*;}
-keep class im.yixin.sdk.api.** implements im.yixin.sdk.api.YXMessage$YXMessageData{*;}
-keep class com.tencent.mm.sdk.** {
   *;
}
-keep class com.tencent.mm.opensdk.** {
   *;
}
-keep class com.tencent.wxop.** {
   *;
}
-keep class com.tencent.mm.sdk.** {
   *;
}

-keep class com.twitter.** { *; }

-keep class com.tencent.** {*;}
-dontwarn com.tencent.**
-keep class com.kakao.** {*;}
-dontwarn com.kakao.**
-keep public class com.umeng.com.umeng.soexample.R$*{
    public static final int *;
}
-keep public class com.linkedin.android.mobilesdk.R$*{
    public static final int *;
}
-keepclassmembers enum * {
    public static **[] values();
    public static ** valueOf(java.lang.String);
}

-keep class com.tencent.open.TDialog$*
-keep class com.tencent.open.TDialog$* {*;}
-keep class com.tencent.open.PKDialog
-keep class com.tencent.open.PKDialog {*;}
-keep class com.tencent.open.PKDialog$*
-keep class com.tencent.open.PKDialog$* {*;}
-keep class com.umeng.socialize.impl.ImageImpl {*;}
-keep class com.sina.** {*;}
-dontwarn com.sina.**
-keep class  com.alipay.share.sdk.** {
   *;
}

-keepnames class * implements android.os.Parcelable {
    public static final ** CREATOR;
}

-keep class com.linkedin.** { *; }
-keep class com.android.dingtalk.share.ddsharemodule.** { *; }
-keepattributes Signature

5. 签名打包

(1).build—>generate

在这里插入图片描述

(2).选择apk—>next

在这里插入图片描述

(3). 选择要打包的moudle和创建key签名

在这里插入图片描述
在这里插入图片描述
点击ok
在这里插入图片描述
点击next

在这里插入图片描述

练习手册:

题目一:

(1)把友盟分享+推送+统计完成3遍
(2)进行多渠道打包

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
UniApp接入友盟推送(UMeng Push)的步骤如下: 1. **初始化配置**: 首先,在项目中引入友盟的SDK。在`main.js`或全局配置文件中,添加友盟推送的配置,包括APPID和服务器URL。 ```javascript import { uniPush } from '@dcloudio/uni-push' uniPush.init({ appKey: 'YOUR_APP_KEY', // 替换为你的友盟AppKey channel: '', // 渠道标识,可选 onNotification: function (notification) {}, // 接收通知回调 openMiniProgram: false, // 是否打开小程序通知,默认false }) ``` 2. **注册设备**: 在用户登录后,需要获取并注册用户的设备标识以便接收推送消息。 ```javascript uniPush.registerDevice(function(res) { console.log('设备注册成功,token:', res.data.token) }, function(err) { console.error('设备注册失败:', err) }) ``` 3. **设置推送通知**: 友盟提供了丰富的通知设置,包括通知类型、标题、内容等,可以通过`setNotificationConfig`方法进行配置。 4. **发送推送**: 当需要向特定用户或者所有用户发送推送时,调用`sendNotification`方法,传入接收者列表和消息内容。 5. **监听事件**: 可以监听友盟推送的事件,如打开通知、点击通知等,通过`addEventListener`方法。 ```javascript uniPush.addEventListener('registrationSuccess', function (event) { console.log('注册成功', event.detail) }) ``` 6. **测试推送**: 在友盟后台创建测试推送,确保在模拟器或真机上正确显示和接收。 **相关问题--:** 1. 如何在UniApp中关闭友盟推送? 2. 如何查看友盟推送的统计分析? 3. 推送通知失败如何处理错误信息?

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值