分发应用

您可以在下文中找到有关在 Google Play 企业版商店中分发应用的实用信息。

安装应用

您可以通过政策在设备上安装 Google Play 商店中的 Android 应用。 如需使用此功能,您需要知道要安装的应用的软件包名称。您可以通过以下两种方式查找应用的软件包名称:

  1. 应用的软件包名称位于 Google Play 商店页面的网址中。例如,Google Chrome 应用页面的网址为

    https://play.google.com/store/apps/details?id=com.android.chrome
    ,其软件包名称为 com.android.chrome

  2. 您可以在 EMM 控制台中嵌入 Google Play 企业版 iframe,以便客户浏览 Google Play 商店。客户在 iframe 中选择应用时,EMM 控制台会收到软件包名称。

然后,您可以在设备的政策中添加该应用:

"applications":[
   {
      "installType":"FORCE_INSTALLED",
      "packageName":"com.android.chrome",
   },
],

当您将政策应用于设备时,应用要么安装在设备上,要么添加到设备上的 Google Play 企业版商店中。

分发应用以进行封闭式测试

在 Play 管理中心内,应用开发者可以创建一个封闭式版本(封闭式轨道),让一组测试人员测试其应用的预发布版本。这称为封闭式测试。支持封闭式轨道分发可让组织测试第三方应用以及他们在内部开发的任何专用应用。

在 Play 管理中心内设置封闭式测试时,应用开发者最多可以将 100 个组织 (enterprises) 设为目标组织。您可以使用 Android Management API 检索针对企业的封闭式轨道,并按照政策将这些封闭式轨道分发给设备。

符合封闭式测试条件的应用

在设置封闭式测试之前,应用开发者必须确保其应用满足以下要求:

  • 应用的正式版发布到 Google Play(对于专用应用,则为 Google Play 企业版)
  • 在 Play 管理中心内,系统会在应用的定价和分发范围页面中启用 Google Play 企业版高级功能
  • 该应用的任何封闭版本都符合版本代码要求

将企业添加到封闭式测试中

设置封闭式测试时,应用开发者可以通过添加组织 ID 来向组织授予对封闭式测试的访问权限。您的客户可以按照以下说明找到其组织 ID:

  1. 使用管理员帐号登录 Google Play 企业版
  2. 点击管理员设置
  3. 复制组织信息框中的组织 ID 字符串,并将其发送给开发者。

对于专用应用,开发者还需要在 Play 管理中心的定价和分发范围页面中添加每个参与计划的企业的组织 ID。有关说明,请参阅通过 Play 管理中心发布专用应用

向用户分发封闭式轨道

如需检索对于指定应用可供企业使用的轨道列表,请调用 enterprises.applications。对于给定应用,响应中包含的 appTrackInfo[] 列表包含以下内容:

  • trackId:轨道的唯一标识符,取自 Play 管理中心内显示应用轨道信息的页面网址中的 releaseTrackId
  • trackAlias:轨道的直观易懂的名称,可在 Play 管理中心内修改。

如需在用户设备上安装封闭式轨道,请在其设备政策中指定 accessibleTrackIds

"applications":[
   {
      "installType":"AVAILABLE",
      "packageName":"com.google.android.gm",
      "accessibleTrackIds":[
          "123456",
          "789101"
       ]
   },
],

如果政策包含来自同一应用的多个轨道(如上例所示),此政策会安装版本代码最高的轨道。

在某些情况下,例如以下情况,系统会自动从 enterprises.applications 调用中移除 trackId:

  • 轨道的 APK 已提升到其他轨道或正式版。
  • 正式版更新为高于轨道的版本。
  • 开发者停止了轨道。

Google Play 企业版 iframe

借助 Google Play 企业版 iframe,您可以直接在 EMM 控制台中嵌入 Google Play 企业版,以为客户提供统一的移动管理体验。

Managed-play-iframe
图 1. Google Play 企业版 iframe

iframe 包含一个标题栏和一个可展开的侧边菜单。用户可以从该菜单导航到不同的页面:

  • 搜索应用:让 IT 管理员可以搜索和浏览 Google Play 应用、查看应用详细信息以及选择应用。
  • 专用应用:让 IT 管理员可以为其企业发布和管理专用应用。
  • Web 应用:让 IT 管理员将网站快捷方式作为应用发布和分发。
  • 整理应用:让 IT 管理员可以配置在用户设备上的 Play 商店应用中整理应用的方式。

功能

本部分介绍了 Google Play 企业版 iframe 中提供的功能。 如需了解如何嵌入 iframe 并实现这些功能,请参阅将 iframe 添加到您的控制台


将 iframe 添加到控制台

第 1 步:生成 Web 令牌

调用 enterprises.webTokens.create 以生成用于识别企业的 Web 令牌。响应中包含令牌的 value

  • parentFrameUrl 设置为托管 iframe 的父框架的网址。
  • 使用 iframeFeature 指定要在 iframe 中启用的功能PLAY_SEARCHPRIVATE_APPSWEB_APPSSTORE_BUILDER(整理应用)。如果未设置 iframeFeature,则 iframe 会默认启用所有功能

第 2 步:呈现 iframe

以下示例展示了如何呈现 Google Play 企业版 iframe:

<script src="https://apis.google.com/js/api.js"></script>
<div id="container"></div>
<script>
  gapi.load('gapi.iframes', function() {
    var options = {
      'url': 'https://play.google.com/work/embedded/search?token=web_token&mode=SELECT',
      'where': document.getElementById('container'),
      'attributes': { style: 'width: 600px; height:1000px', scrolling: 'yes'}
    }

    var iframe = gapi.iframes.getContext().openChild(options);
  });
</script>

此代码会在容器 div 内生成一个 iframe。如上所示,可以使用“属性”选项设置要应用于 iframe 代码的属性。

网址参数

下表列出了 iframe 的所有可用参数,这些参数可作为网址参数添加到网址中,例如:

'url': 'https://play.google.com/work/embedded/search?token=web_token&mode=SELECT&showsearchbox=TRUE',
参数 网页 必需 说明
token 不适用 第 1 步返回的令牌。
iframehomepage 不适用 呈现 iframe 时显示的初始网页。可能的值包括 PLAY_SEARCHWEB_APPSPRIVATE_APPSSTORE_BUILDER(整理应用)。如果未指定,则按以下优先顺序确定显示哪个页面:1. PLAY_SEARCH、2. PRIVATE_APPS、3. WEB_APPS、4. STORE_BUILDER.
locale 不适用 格式正确的 BCP 47 语言标记,用于对 iframe 中的内容进行本地化。如果未指定,则默认值为 en_US
mode 搜索应用 SELECT:允许 IT 管理员选择应用。
APPROVE(默认):让 IT 管理员选择、批准和取消批准应用。此模式已废弃,请改用 SELECT。仅当 Web 令牌中的 PlaySearch.ApproveApps 设置为 true 时,“APPROVE”模式才有效。
showsearchbox 搜索应用 TRUE(默认):显示搜索框并从 iframe 中发起搜索查询。
FALSE: 则不会显示搜索框。
search 搜索应用 搜索字符串。如果指定,则 iframe 会将 IT 管理员定向到包含指定字符串的搜索结果。

第 3 步:处理 iframe 事件

您还应在集成过程中处理以下事件。

事件说明
onproductselect 用户选择或批准应用。此操作会返回一个对象,其中包含:
{
    "packageName": The package name of the app, e.g. "com.google.android.gm",
    "productId": The product ID of the app, e.g. "app:com.google.android.gm",
    "action": The type of action performed on the document. Possible values are:
    "approved", "unapproved" or "selected." If you implement the iframe in SELECT
    mode, the only possible value is "selected".
}
    
以下示例展示了如何监听 onproductselect
iframe.register('onproductselect', function(event) {
  console.log(event);
}, gapi.iframes.CROSS_ORIGIN_IFRAMES_FILTER);


将您自己的应用上传到 Google Play 商店

如果您或您的客户开发了 Android 应用,您可以使用 Google Play 管理中心将应用上传到 Play 商店。

如果您不希望在 Play 商店中公开发布应用,可以使用 Google Play 管理中心将应用限制为仅限单个企业使用。另一种方法是使用 Google Play Custom App Publishing API 以编程方式发布专用应用。专用应用仅供相应企业使用。它们仍然可以通过政策安装,但对企业以外的用户不可见。