跳转应用市场详情页market

关于作者:CSDN内容合伙人、技术专家, 从零开始做日活千万级APP。
专注于分享各领域原创系列文章 ,擅长java后端、移动开发、商业变现、人工智能等,希望大家多多支持。
未经允许不得转载

目录

  • 一、导读
  • 二、概览
  • 三、跳转到各大厂商应用商店应用详情页
    • 3.1 vivo
    • 3.2 oppo
    • 3.3 小米
    • 3.4 华为
    • 3.5 通用的方式
    • 3.6 总结一下
  • 四、 推荐阅读

在这里插入图片描述

一、导读

我们继续总结学习基础知识,温故知新。

本文描述了以下两方面内容:
获取当前手机上安装的应用商店包名跟指定页面。
跳转到各大厂商应用商店应用详情页。

Android 应用中跳转到应用市场评分。

二、概览

在国内基本上每个手机厂商都会有自己的手机应用市场,建立自己的生态,为此,app内可以增加引导用户去应用市场评价,
目标是持续增加应用市场的好评数,支持运营人员可配置跳转到某个应用市场去评论。

三、跳转到各大厂商应用商店应用详情页

3.1 vivo

接入评论调起 vivo 应用商店能力后,可以引导你的用户前往你的 app 在 vivo 应用商店的详情页,进行评论和评分。


    /**
     * th_name=need_comment 这个很关键,是用于切换tab的
     * @param context
     * @param pkgname 待下载资源包名
     */
    public static void gotovivomarket(Context context, String pkgname) {
        String url = "market://details?id=" + pkgname + "&th_name=need_comment";

        Uri uri = Uri.parse(url);

        Intent intent= new Intent(Intent.ACTION_VIEW,uri);

        intent.setPackage("com.bbk.appstore");

        context.startActivity(intent);

    }

网页调起应用详情页方法如下:

location.href = 'market://details?id=pkg&th_name=need_comment';

vivo文档

3.2 oppo

oppo中有两个应用市场包名,如下:
com.oppo.market //Q (10)之前的软件商店包名
com.heytap.market // Q (10)之后的软件商店包名

如果是跳转详情页,请查看后面的方式。

如果是要直接调起评论页面,需要软件商店的版本号(versionCode) >= 84000。

应用评论调起能力接入指南
oppo文档

自更新客户端接入
oppo文档

oppo没有直接跳转评论的方法,但可以调用oppo提供的应用评论的一个能力。

3.3 小米

如何在app内部跳转到应用商店的应用详情页和评论页
为了方便开发者在应用内部让用户点击按钮跳转到应用商店的应用详情页和评论页,我们提供以下方式支持跳转,请提供给开发进行查看:

1、跳转到应用的详情页:

  market://details?id=pkgName

2、跳转到应用的评论页:

  market://comments?id=pkgName

action: android.intent.action.VIEW

category: android.intent.category.BROWSABLE

当然,并不是所有系统版本都支持跳转, 跳转前请务必判断activity是否存在。

小米文档

3.4 华为

华为的跳转方式会比较多一些,总结一下:

  • 跳转到AG应用详情页,应用内拉起跳转到应用详情页,应用用户进行评分评论等操作。

  • market拉起所有本地商店并跳转详情页

  • 链接到web AG的应用详情页

  • 图章链接到AG的应用详情页

我们贴出来华为特有的代码:


    /**
     * 华为特有的方式:
     * appmarket:// + 包名
     *
     * @param context
     * @param pkgname 应用包名,例如华为浏览器:com.huawei.browser
     */
    public void toHWMarketByPkgname(Context context, String pkgname) {
        String text1 = "appmarket://details?id=" + pkgname;
        Uri uri = Uri.parse(text1);
        Intent intent = new Intent(Intent.ACTION_VIEW, uri);
        context.startActivity(intent);
    }

    /**
     * 华为特有的方式:
     * market:// + 华为商店 + APPID
     *
     * @param context
     * @param appId 应用的APPID:例如华为浏览器:C100170981
     */
    public void toHWMarketByAppId(Context context, String appId) {
        String text1 = "market://com.huawei.appmarket.applink?appId=" + appId;
        Uri uri = Uri.parse(text1);
        Intent intent = new Intent(Intent.ACTION_VIEW, uri);
        context.startActivity(intent);
    }


    // ====================== 通过intent 应用商店 action 跳转到AG应用详情页 ==========================
    /**
     * 应用内通过Intent跳转到应用详情页,应用用户进行评分评论等操作
     * @param context
     * @param marketPkg 应用市场包名,例如华为:com.huawei.appmarket
     * @param appId 应用的APPID:例如华为浏览器:C100170981
     * @param action 如华为:com.huawei.appmarket.appmarket.intent.action.AppDetail.withid
     * @return
     */
    public static boolean toMarketByActionAndAppId(Context context, String appId, String marketPkg, String action) {

        Intent intent = new Intent(action);
        intent.setPackage(marketPkg);
        intent.putExtra("appId", appId);
        context.startActivity(intent);
        return false;
    }

    /**
     * 应用内通过Intent跳转到应用详情页,应用用户进行评分评论等操作
     * @param context
     * @param pkgname 应用包名,例如华为浏览器:com.huawei.browser
     * @param marketPkg 应用市场包名,例如
     *                  华为:com.huawei.appmarket
     *
     * @param action 如:"com.huawei.appmarket.intent.action.AppDetail"
     * @return
     */
    public static boolean toMarketByActionAndPkgname(Context context, String pkgname, String marketPkg, String action) {

        Intent intent = new Intent(action);
        intent.setPackage(marketPkg);
        intent.putExtra("APP_PACKAGENAME", pkgname);
        context.startActivity(intent);
        return false;
    }

华为文档

华为没有直接跳转评论的方法。

3.5 通用的方式

这里我们列出两种通用方式:

  • 通过系统隐式意图 , market拉起所有本地商店并跳转详情页

    /**
     * 传入包名,拉起设备上所有的应用商店,让用户自行选择打开方式,即引导用户选择使用哪个应用市场拉起。
     * 选择好打开的应用商店后可以直接跳转到应用的详情页。
     * 
     * 使用方法:通过传入scheme 为market:// 的链接,Android支持的标准的market协议,可拉起Android设备上的所有应用商店。
     *
     * market://details?id=pkgName   // 支持所有商店
     *
     * @param context
     * @param pkgname 应用包名,例如华为浏览器:com.huawei.browser
     * @param marketPkg 应用市场包名,例如
     *      *                  华为:com.huawei.appmarket
     *      *                  vivo:com.bbk.appstore
     *      *                  小米:com.xiaomi.market
     *      *                  魅族:com.meizu.mstore
     *      *
     *      *                  oppo:com.oppo.market //Q之前的软件商店包名
     *      *                  oppo:com.heytap.market //Q之后的软件商店包名
     * @return 此方式很多市场都跳转不过去。 需要验证
     */
    public static boolean toMarketNormal(Context context, String pkgname, String marketPkg) {
        Uri uri = Uri.parse("market://details?id=" + pkgname);

        Intent intent = new Intent("android.intent.action.VIEW", uri);
        intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
        if (marketPkg != null) {
            intent.setPackage(marketPkg);
        }
        try {
            context.startActivity(intent);
            return true;
        } catch (Exception unused) {
            return false;
        }
    }
  • 通过应用市场的搜索方法 , market拉起所有本地商店并跳转详情页

    /**
     * 打开配置了search的页面
     * @param context
     * @param pkgname 应用包名,例如华为浏览器:com.huawei.browser
     * @param marketPkg
     * @return
     */
    public static boolean toMarketBySearch(Context context, String pkgname, String marketPkg) {

        try {
            Intent i = new Intent(Intent.ACTION_VIEW);
            i.setData(Uri.parse("market://search?q="+context.getPackageName()));
            context.startActivity(i);
            return true;
        } catch (Exception e) {
            Toast.makeText(context, "手机没有安装Android应用市场", Toast.LENGTH_SHORT).show();
            return false;
        }
    }

上面这两个方法很简单易用,几行代码就可以实现调用应用市场,唯一的缺点就是如果手机安装多个应用市场,
他所呈现的弹窗是系统自带风格,有时候我们需要自己定制自己的统一弹窗风格,这时候就需要通过其他方案来实现

  • 获取当前手机上安装的应用商店包名跟指定页面
    主要的思路就是找出当前已经安装的android商店。弹出面板让由用户自己去选择。
    首先需要获取当前已经安装的包名集合,
    然后获取手机上已安装的app,过滤剩下应用市场的相关信息定义为appinfo类,appInfo里有这些属性:包名、应用名、icon、版本号。
    这些属性在后面做一个弹窗之类的功能时候用到,系统自带的弹出选择面板会出现的我们都要显示出来。

    /**
     * 获取当前手机上安装的应用商店包名跟指定页面
     * 后面在跳转时根据 marketPkg 进行调整
     * @param context
     * @return
     */
    public static HashMap<String, String> getInstalledMarketPackageName(Context context) {
        HashMap<String, String> hashMap = new HashMap<>();
        Intent intent = new Intent();
        intent.setAction("android.intent.action.VIEW");
        intent.addCategory("android.intent.category.DEFAULT");
        intent.setData(Uri.parse("market://details?id="));

        List<ResolveInfo> queryIntentActivities = context.getPackageManager().queryIntentActivities(intent, 0);
        if (queryIntentActivities != null && queryIntentActivities.size() != 0) {
            int size = queryIntentActivities.size();
            for (int i = 0; i < size; i++) {
                CharSequence charSequence = "";
                String pkgName = "";
                String cls = "";
                try {
                    ActivityInfo activityInfo = queryIntentActivities.get(i).activityInfo;
                    pkgName = activityInfo.packageName;
                    try {
                        charSequence = activityInfo.loadLabel(context.getPackageManager());
                        cls = activityInfo.name;
                        try {
                            context.getResources().getString(context.getPackageManager().getPackageInfo(pkgName, 0).applicationInfo.labelRes);
                        } catch (Exception unused) {
                        }
                    } catch (Exception unused2) {
                        charSequence = "";
                    }
                } catch (Exception unused3) {
                    charSequence = "";
                }
                if (!TextUtils.isEmpty(pkgName)) {
                    hashMap.put(charSequence.toString(), pkgName);

                    Log.d("20230913", charSequence.toString() +", pkgname = " + pkgName +", cls = " + cls);
                }
            }
        }
        return hashMap;
    }

3.6 总结一下

将各大应用市场的跳转方式进行聚合在一块,我们直接上代码:
实际使用过程中大家需要调试一下,跳转详情页跟评论页面是有些许区别的。


    /**
     *
     * @param context
     * @param pkgName
     */
    public static void openAppMarket(Context context, String pkgName) {
        String uriString = "";
        String marketPkg = "";
        try {
            String lowerCase = Build.BRAND.toLowerCase(Locale.ROOT);
            if (lowerCase.equals("xiaomi") || lowerCase.equals("redmi")) {
                uriString = "mimarket://details?id=";
                marketPkg = "com.xiaomi.market";
            }

            if (lowerCase.equals("huawei") || lowerCase.equals("honor")) {
                uriString = "appmarket://details?id=";
                marketPkg = "com.huawei.appmarket";

            }

            if (lowerCase.equals("vivo")) {
                uriString = "vivoMarket://details?id=";
                marketPkg = "com.bbk.appstore";

            }
//            if (lowerCase.equals("flyme")) {
//                str2 = "mstore://details?packagename=";
//                marketPkg = "";
//
//            }
//            if (lowerCase.equals("samsung")) {
//                str2 = "samsungapps://ProductDetail/";
//                marketPkg = "";
//
//            }
            if (lowerCase.equals("oppo") || lowerCase.equals("oneplus") || lowerCase.equals("realme")) {
                uriString = "oppomarket://details?packagename=";
                if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q) {
                    marketPkg = "com.heytap.market";
                } else {
                    marketPkg = "com.oppo.market";
                }
            }

            if(TextUtils.isEmpty(uriString)) {
                uriString = "market://details?id=";
            }


            Intent intent = new Intent("android.intent.action.VIEW", Uri.parse(uriString + pkgName));
            intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);

            if (marketPkg != null) {
                intent.setPackage(marketPkg);
            }
            try {
                context.startActivity(intent);
//                return true;
            } catch (Exception unused) {
//                return false;
            }
        } catch (Exception e) {
            e.printStackTrace();
            Log.e("LuckyDogUtils", "手机无应用商店");
        }
    }
    
    public static boolean toHuaWeiMarketDetails(Context context, String pkgname) {
        try {
            Intent intent = new Intent("com.huawei.appmarket.intent.action.AppDetail");
            intent.setPackage("com.huawei.appmarket");
            intent.putExtra("APP_PACKAGENAME", pkgname);
            context.startActivity(intent);
            return true;
        } catch (Exception e) {
        }
        return false;
    }

    public static boolean toXiaomiMarketDetails(Context context, String pkgname) {
        try {
            Intent intent = new Intent("android.intent.action.VIEW", Uri.parse("mimarket://comments?id=" + pkgname));
            intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
            intent.addCategory("android.intent.category.BROWSABLE");

            intent.setPackage("com.xiaomi.market");
            context.startActivity(intent);
            return true;
        } catch (Exception e) {
        }
        return false;
    }

四、 推荐阅读

Java 专栏

SQL 专栏

数据结构与算法

Android学习专栏

未经允许不得转载

ddd

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/186760.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

思科模拟器操作命令

模式 思科模拟器常见的模式有 用户模式 能够操作的命令比较少 特权模式特权模式下面可以操作的比较多 全局模式 接口模式 用户模式进入特权模式: 命令enable 特权模式进行全局模式命令: configure terminal 退出命令 exit命令&#xff1a;返回上一层&#xff0c;即一步一步…

Windows核心编程 进程间通信

目录 进程间通信概述 发送消息 WM_COPYDATA DLL共享段 文件映射 文件相关API CreateFile ReadFile WriteFile CloseHandle SetFilePointerEx 设置文件指针 获取文件大小 GetFileSize 结构体 LARGE_INTEGER 文件映射用于读写文件数据 文件映射用于进程间通信(带文…

百度搜索框中的下拉提示关键词提取

效果图 代码有点多&#xff0c;绑定资源了 导出excel如下 贴心养眼背景图鼠标点击小爱心

pat实现基于邻接矩阵表示的深度优先遍历

void DFS(Graph G, int v) {visited[v] 1;printf("%c ", G.vexs[v]);for (int i 0; i < G.vexnum; i) {if (!visited[i] && G.arcs[v][i]) DFS(G, i);} }

C# 读写FDX-B(ISO11784/85)动物标签源码

本示例使用的发卡器&#xff1a;EM4305 EM4469 ISO11784/85协议125K低频FXD-B动物标签读写发卡器-淘宝网 (taobao.com) using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using S…

API 设计:使用 Node.js 和 Express.js 的综合教程

API&#xff08;应用程序编程接口&#xff09;设计涉及创建一个高效而强大的接口&#xff0c;允许不同的软件应用程序相互交互。 说明 本教程将指导您使用 Node.js 和 Express.js 作为核心技术来规划、设计和构建 API。但是&#xff0c;这些原则可以应用于任何语言或框架。我们…

APP软件外包开发需要注意的问题

在进行APP软件开发时&#xff0c;有一些关键问题需要特别注意&#xff0c;以确保项目的成功和用户满意度。以下是一些需要注意的问题&#xff0c;希望对大家有所帮助。北京木奇移动技术有限公司&#xff0c;专业的软件外包开发公司&#xff0c;欢迎交流合作。 清晰的需求定义&a…

详解STUN与TR111

STUN协议定义了三类测试过程来检测NAT类型&#xff1a; Test1&#xff1a;STUN Client通过端口{IP-C1:Port-C1}向STUN Server{IP-S1:Port-S1}发送一个Binding Request&#xff08;没有设置任何属性&#xff09;。STUN Server收到该请求后&#xff0c;通过端口{IP-S1:Port-S1}把…

统计二叉树中的伪回文路径 : 用位运用来加速??

题目描述 这是 LeetCode 上的 「1457. 二叉树中的伪回文路径」 &#xff0c;难度为 「中等」。 Tag : 「DFS」、「位运算」 给你一棵二叉树&#xff0c;每个节点的值为 1 到 9 。 我们称二叉树中的一条路径是 「伪回文」的&#xff0c;当它满足&#xff1a;路径经过的所有节点值…

一个正整数转为2进制和8进制,1的个数相同的第23个数是什么?

package cn.com;import java.lang.*;//默认加载public class C2 {//10进制转8进制static int HtoO(int n){int cnt 0;while(n!0){cntn%8;n/8;}return cnt;}//10进制转2进制static int HtoB(int n){int cnt 0;while(n!0){cntn%2;n/2;}return cnt;}public static void main(Str…

Windows服务设置多个服务依赖项避免服务启动失败找不到数据库

添加多个服务依赖项建议通过命令行的方式添加&#xff1a; winr键打开命令行 cmd 命令行添加命令如下&#xff1a; sc config "thinvent-auth" depend "MySQL57"/"RabbitMQ"/"Redis" sc config "服务A" depend "服务…

C#,《小白学程序》第十四课:随机数(Random)第一,几种随机数的计算方法与代码

1 文本格式 /// <summary> /// 《小白学程序》第十四课&#xff1a;随机数&#xff08;Random&#xff09;第一&#xff0c;几种随机数的计算方法与代码 /// 本课初步接触一下随机数。 /// </summary> /// <param name"sender"></param> ///…

LiveVIS视图库1400-如何切换数据库?默认使用的数据库是什么?如何切换到Mysql/MariaDB?

LiveVIS视图库1400-如何切换数据库&#xff1f;默认使用的数据库是什么&#xff1f;如何切换到Mysql/MariaDB? 1、切换成Mysql/Mariadb数据库1.1 连接数据库1.2 创建数据库实例1.3 配置.ini文件1.4 重启完成切换 1、切换成Mysql/Mariadb数据库 LiveVIS 默认使用 sqlite3 文件…

重新开启GPT Plus充值通道——基于前端开发者工具

chatGPT PLUS充值通道的关闭 由于chatGPT用户激增&#xff0c;近日&#xff0c;OpenAI的CEO Sam Altman宣布需要暂停新用户对ChatGPT Plus的订阅。在X上&#xff0c;他表达了对于确保用户体验的承诺&#xff0c;同时也提到了用户可以通过应用程序内的通知功能来了解服务恢复的…

笔记本电脑可以投屏到电视吗?Win、Mac、Linux分别怎么投屏?

如果你的电视是安卓电视&#xff0c;那么答案是&#xff1a;完全可以&#xff01; 不管你的笔记本电脑是Windows系统、macOS系统还是Linux系统&#xff0c;你都可以借助AirDroid Cast的电脑客户端或网页版&#xff0c;将电脑屏幕投屏到安卓智能电视上。 首先&#xff0c;你需要…

Unity技美35——再URP管线环境下,配置post后期效果插件(post processing)

前两年在我的unity文章第10篇写过&#xff0c;后效滤镜的使用&#xff0c;那时候大部分项目用的还是unity的基础管线&#xff0c;stander管线。 但是现在随着unity的发展&#xff0c;大部分项目都用了URO管线&#xff0c;甚至很多PC端用的都是高效果的HDRP管线&#xff0c;这就…

网络数据结构skb_buff原理

skb_buff基本原理 内核中sk_buff结构体在各层协议之间传输不是用拷贝sk_buff结构体&#xff0c;而是通过增加协议头和移动指针来操作的。如果是从L4传输到L2&#xff0c;则是通过往sk_buff结构体中增加该层协议头来操作&#xff1b;如果是从L4到L2&#xff0c;则是通过移动sk_…

井盖位移传感器怎么监测井盖安全

井盖在城市基础设施建设中扮演着不可或缺的角色&#xff0c;虽然看似并不起眼但确实是城市规划中一个重要的组成部分。在城市规划建设之初都需要首先考虑排水系统的设计&#xff0c;而井盖作为排水系统的一个重要组成部分&#xff0c;一旦出现问题便会造成交通中断或者环境受影…

【洛谷 P1636】Einstein学画画 题解(图论+欧拉通路)

Einstein学画画 题目描述 Einstein 学起了画画。 此人比较懒~~&#xff0c;他希望用最少的笔画画出一张画…… 给定一个无向图&#xff0c;包含 n n n 个顶点&#xff08;编号 1 ∼ n 1 \sim n 1∼n&#xff09;&#xff0c; m m m 条边&#xff0c;求最少用多少笔可以画…

C#,《小白学程序》第十七课:随机数(Random)第四,移动平均值(Moving Average)的计算方法与代码

1 文本格式 /// <summary> /// 《小白学程序》第十七课&#xff1a;随机数&#xff08;Random&#xff09;第四&#xff0c;移动平均值的计算方法与代码 /// 继续学习数据统计&#xff0c;移动平均值的计算方法 /// 移动平均值就是一定步长内数值的平均值&#xff0c;用…