立即上架APP

提供从软著申请,应用商店资质账号申请协助,到APP预审,APP截图优化,APP排名优化,APP审核加急,APP被拒修改,APP版本更新全业务流服务

覆盖苹果APPstore、谷歌play、华为、小米、魅族、OPPO、VIVO、百度、360、应用宝等30+目标商店

一门深耕APP生态服务,郑重承诺:app没上架成功,上架服务费全额退款!


魅族授权APP登录 开发者账号接入SDK

开发者账号接入SDK

SDK点击下载

一、接入应用注册

所有接入应用都需要在开放平台进行统一注册(可以到open.flyme.cn统一提交接入申请),在注册流程中,应用需要提供“接入应用信息”,开放平台会据此提供应用接入需要client_id和client_secret标识。

1、接入应用信息

在应用注册中需要提供应用接入应用的信息,其中包括

参数是否必填含义
redirect_uri必须成功授权后的回调地址,必须是注册appid时填写的主域名下的地址,建议设置为网站首页或网站的用户中心。注意需要将url进行URLEncode。
scope可选请求用户授权时向用户显示的可进行授权的列表。 可填写的值是API文档中列出的业务scope。这些scope对应于开放平台提供的扩展服务,通过不同scope,将可访问服务限制在应用申请的范围,实现对于不同服务的权限管理。一方面服务使用必须通过平台申请,另一方面用户在确认授权时能明确看到对应应用需要申请哪些扩展服务、获取哪些帐号隐私数据等。在保证服务使用的同时,提升用户隐私保护,提升了用户体验。 建议控制授权项的数量,只传入必要的接口名称,因为授权项越多,用户越可能拒绝进行任何授权。
其他 待补充

2、应用标识信息

开发者在开放平台应用管理配置页填写”接入应用信息“之后,开放平台会针对应用分配独立的应用标识信息。

参数含义
client_id申请应用接入之后,分配给应用的appId
client_secret申请应用接入之后,分配给应用的appKey,该参数用于应用进行AuthCode方式获取access_token,需要保存在接入应用的业务服务器。(对于无服务器应用,可使用implict_grant方式获取access_token)

 

 

 

 

3、选择授权方式

接入应用包含两种授权方式,两种方式都可以获得业务token。结合不同的应用场景,接入应用可选择使用不同的授权方式。

 

(1)AuthCode_Grant

该方式通过AuthCode的方式进行登陆、授权、获取token,主要特点如下:

1.限用于有服务器的接入应用;

2.需要业务服务器支持client_secret的获取;

3.在获取access_token的接口中可获得RefreshToken,在应用使用周期中可通过RefreshToken和client_secret刷新token。

4.授权流程为

  • 通过访问统一登陆授权页登陆,并获取auth_code
  • 通过业务服务器接口,传递auth_code获取应用的client_secret
  • 通过返回的client_secret和auth_code调用统一的access_token获取接口获取access_token和refreshToken

5.Token刷新流程,通过本地保存的refreshToken和应用的client_secret刷新access_token

6.SDK封装了获取AuthCode的逻辑,开发者可以直接使用,具体授权逻辑待补充。

(2)Implicit_Grant

1.不需要业务服务器支持,应用可以直接通过client_id获取access_token;

2.在获取access_token的接口中不可获得RefreshToken。

3.授权流程支持访问统一授权页登陆,授权,获得token。

4.开发者可使用SDK直接调用对应授权方式,具体授权逻辑待补充。

 

4、定制登陆模块界面

登陆模块界面包含登陆页面、注册界面、找回密码相关界面。需要定制化登陆模块界面的应用,需要遵循统一的登陆界面设计规范,包含必须的视觉元素,提供登陆模块界面设计样式PSD。

针对注册和找回密码界面,因为涉及多种不同的业务逻辑,仅支持界面主色等简单定制。

(1)登陆页面 

基础页面请参考通用登陆页面。

界面元素是否保持可定制不可定制
账户输入颜色、字体文案
密码输入颜色、字体文案
登陆按钮颜色、字体文案
注册按钮颜色、字体文案
找回密码按钮颜色、字体文案
总体设计界面主色 

 

 

 

 

 

 

(2)登陆界面和找回密码界面

基础页面请参考通用的注册和找回密码界面。

界面元素是否保持可定制不可定制
总体设计界面主色业务逻辑

 

 

二、魅族开放平台MzOpenSDK接入

1、接入方式

开放平台SDK采用aar的方式提供,接入应用可将MzOpenSDK.aar包添加到代码libs目录中,并关联SDK的引用。

说明:

SDK内部在AndroidManifest.xml中已声明了以下权限:

    <uses-permission android:name=”android.permission.INTERNET” />

    <uses-permission android:name=”android.permission.ACCESS_NETWORK_STATE” />

    <uses-permission android:name=”android.permission.GET_ACCOUNTS” />

    <uses-permission android:name=”android.permission.USE_CREDENTIALS” />

和登陆页Activity:

<activity

    android:name=”sdk.meizu.auth.ui.AuthActivity”

    android:launchMode=”singleTask”

    android:screenOrientation=”portrait”

    android:exported=”false”/>

2、授权登陆

登陆授权的核心管理类为MzAuthenticator,其具体实现包含在MzOpenSDK的aar包当中,开发者需要根据具体的业务需求,通过该类调用不同的授权登陆接口,获得应用授权的关键数据。

如上文所述,魅族开放平台支持两种方式的授权,其分别有不同的适用场景,开发者可以根据应用需要进行选择,并通过MzAuthenticator类分别调用。

(1)AuthCode_Grant

唤起登陆授权页并处理MzAuthCodeCallBack

MzAuthenticator mAuthenticator = new MzAuthenticator(this, CLIENT_ID, REDIRECT_URL);

mAuthenticator.requestCodeAuth(TestAuthInfo.SCOPE, new CodeCallback() {
@Override
public void onError(OAuthError error) throws RemoteException {
    String errorMsg = “OAuthError: ” + error.getError();
    Toast.makeText(TestAuthActivity.this, errorMsg, Toast.LENGTH_SHORT).show();
}

@Override
public void onGetCode(String code) throws RemoteException {
    String authCodeResult = “AuthCode:” + code;
    Toast.makeText(TestAuthActivity.this, authCodeResult, Toast.LENGTH_SHORT).show();
}
});

根据authCode去业务服务器请求client_secret

该接口需要业务服务器提供。

获取access_token

根据业务服务器返回的clientSecret和第一步中获取到的authCode,通过开放平台通用的token获取接口获取accessToken。在该授权方式中,返回数据包含

参数含义
access_token开放平台业务服务依赖的accessToken
refresh_token可缓存到本地用于刷新accessToken
expire_inaccessToken过期时间
其他 

Token过期处理

在该授权方式中,开放平台支持接入应用通过业务服务器返回的clientSecret和本地缓存的refreshToken刷新accessToken。

(2)Implicit_Grant

唤起登陆授权页并处理MzImplicitCallBack

MzAuthenticator mAuthenticator = new MzAuthenticator(this, CLIENT_ID, REDIRECT_URL);

mAuthenticator.requestImplictAuth(TestAuthInfo.SCOPE, new ImplictCallback() {
@Override
public void onError(OAuthError error) throws RemoteException {
    String errorMsg = “OAuthError: ” + error.getError();
    Toast.makeText(TestAuthActivity.this, errorMsg, Toast.LENGTH_SHORT).show();
    tvAuthResult.setText(errorMsg);
}

@Override
public void onGetToken(OAuthToken token) throws RemoteException {
    String oauthTokenResult = “OAuthToken:” + token.getAccessToken();
    Toast.makeText(TestAuthActivity.this, oauthTokenResult, Toast.LENGTH_SHORT).show();
    tvAuthResult.setText(oauthTokenResult);
}
});

获取access_token

该种授权方式通过步骤一,直接在回调方法中返回了应用需要accessToken。返回数据包含

参数含义
access_token开放平台业务服务依赖的accessToken
expire_inaccessToken过期时间
其他 

Token过期处理

该种授权方式在获取token接口中不包含refreshToken,不能直接刷新token。当token过期是重新执行步骤一进行登陆获取。

通过access_token获取用户信息

接口调用请求说明

http请求方式: GET

https://open-api.flyme.cn/v2/me?access_token=eyJ1IjoiMTQ2MjM1MCIsInQiOjE0MzgxNTAzMjU5MDEsInIiOiJ2dnlQTFN4c1BuQnJzdFEifQ

参数说明

参数是否必须说明
access_tokenopen api的授权token

返回说明

正确的json返回:

{“code”:”200″,”message”:””,”redirect”:””,”value”:{“icon”:”http://img.res.meizu.com/img/download/uc/14/62/35/00/00/1462350/w200h200“,

“nickname”:”test_nickname3″,”openId”:”8mUAF421px8wVt2O3eym3saKtCAkRU-71B3qQBccPFg”}

}

参数说明
code状态码
message消息内容
icon用户头像
nickname用户昵称
openId开放平台openId

错误时会返回错误码等信息

校验access_token相关信息

接口调用请求说明

http请求方式: GET

https://open-api.flyme.cn/v2/check?access_token=eyJ1IjoiMTQ2MjM1MCIsInQiOjE0MzgxNTAzMjU5MDEsInIiOiJ2dnlQTFN4c1BuQnJzdFEifQ

参数说明

参数是否必须说明
access_tokenopen api的授权token

返回说明

正确的json返回:

{“code”:”200″,”message”:””,”value”:{“scope”:[],

“open_id”:”8mUAF421px8wVt2O3eym3saKtCAkRU71B3qQBccPFg”,

“client_id”:”z5A8pb9zA5bN”,”expired_at”:1438273448915},”redirect”:””}

参数说明
code状态码
message消息内容
open_id开放平台openId
client_idclientId
expired_at过期时间的毫秒表示

错误时会返回错误码等信息

3、快速授权登陆

在Flyme系统平台中,如果当前系统登陆了系统帐号并且支持快速登陆。MzOpenSDK封装了应用快速登陆模块,可自动识别到当前系统登陆的Flyme帐号,并跳转到快速授权登陆页面提示用户可使用系统帐号快速登陆应用。在该登陆页用户也可以根据使用场景切换为非系统帐号登陆。

在此逻辑中,SDK封装了中间处理过程,对于开发者登陆授权接口


相关知识:
苹果上架首次审核时间
苹果上架首次审核指的是开发者将应用程序提交到苹果官方审核后,等待苹果审核通过并在App Store上架的过程。在这个过程中,苹果官方会对应用程序进行严格的审核,包括应用程序的功能、内容、安全性等多个方面的检查。若应用程序审核通过,则会上架到App Stor
2023-04-17
苹果上架app
苹果上架app是指将开发好的应用程序上传至苹果公司的App Store,供用户下载使用。苹果上架app需要遵守苹果公司的规定和审核标准,才能通过审核上架。下面将详细介绍苹果上架app的流程和注意事项。一、注册苹果开发者账号首先,需要注册苹果开发者账号。注册
2023-04-17
没有资质怎么上架app
在移动应用市场上架一个应用程序需要一些特定的资质和文件,例如开发者账号、证书、应用程序包等等。但是对于一些没有这些资质的人来说,他们仍然有一些方法可以将他们的应用程序上架到应用市场上。本文将介绍一些方法,帮助那些没有资质的人上架应用程序。方法一:使用第三方
2023-04-17
开源一个上架app
开源一个上架app,需要我们先明确一些概念。上架指的是将应用程序发布到应用商店,使得用户可以从应用商店下载安装。而开源则是指将应用程序的源代码公开,任何人都可以查看、使用、修改和分发。因此,开源一个上架app,意味着我们需要将应用程序的源代码公开,并且还需
2023-04-17
安卓上架安全评估报告
在安卓应用商店上架应用程序之前,需要进行安全评估,以确保应用程序不会对用户和终端设备造成任何损害。安全评估报告是安全评估的结果,它详细描述了应用程序的安全性,并提供了建议和措施来改善应用程序的安全性。安卓应用程序的安全评估主要包括以下几个方面:1. 安全漏
2023-04-17
华为市场app上架
华为市场是华为公司官方的应用商店,为华为手机和平板等设备用户提供了丰富的应用程序和游戏。如果您是一名开发者,想要将自己开发的应用程序上架到华为市场,那么本文将为您介绍华为市场上架的原理和详细步骤。一、华为市场上架原理1. 注册开发者账号要在华为市场上架应用
2023-04-17
个人上架的app
个人上架的app是指由个人开发者或团队开发的应用程序,通过各大应用商店上架并提供下载。这些应用程序可以是游戏、工具、社交媒体、生产力工具等各种类型的应用程序。本文将介绍个人上架app的原理和详细过程。一、原理个人上架的app原理基于移动应用程序的开发和发布
2023-04-17
ios上架app心得
在iOS上架应用程序是一个相对复杂的过程,需要遵循苹果公司的严格审核标准和规定。在这篇文章中,我将分享一些iOS上架应用程序的心得和经验,帮助您成功地将应用程序上架到App Store。1. 开发应用程序在开始上架应用程序之前,您需要先开发一个高质量的应用
2023-04-17
苹果appiosipa无需上架
在苹果应用商店上架一个应用程序是一个非常繁琐的过程,需要开发者遵循苹果的严格审核标准和政策规定。但是,有时候开发者可能会遇到一些问题,例如应用被拒绝或者需要快速推出应用等,这时候就需要使用一些无需上架的方法来安装应用程序。其中一个方法就是使用iOS IPA
2023-04-17
谷歌怎么上架自己的app
谷歌Play商店是Android系统的官方应用商店,是安卓用户下载应用程序和游戏的主要渠道。在这里,开发者可以发布他们的应用程序,以便用户可以通过搜索和浏览查找他们的应用程序。在这篇文章中,我将向您介绍如何在谷歌Play商店上架自己的应用程序。1. 创建谷
2023-04-17
app上架没分发
应用程序的上架和分发是移动应用程序开发中的两个重要环节。上架是指将应用程序提交到应用商店进行审核并发布,而分发是指将应用程序分发给终端用户。在应用程序上架后,应用商店会将应用程序推荐给用户,用户可以通过搜索或浏览应用商店来找到并下载应用程序。本文将详细介绍
2023-04-17
app不上架可以收会员费吗
可以,但需要通过一些其他的方式来收取会员费用。下面详细介绍一下原理和具体操作方法。首先,需要明确一点,即使你的应用程序不在应用商店上架,也可以通过其他方式获取用户。例如,你可以在自己的网站上宣传和推广应用程序,并引导用户前往应用程序的下载页面。当然,这需要
2023-04-14