立即上架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上架
苹果应用商店是iOS设备用户获取应用程序的主要途径。在苹果应用商店上架应用程序,需要遵循一些规则和流程。本文将为读者介绍苹果应用商店上架的原理和详细步骤。一、上架前准备1. 注册苹果开发者账号:苹果开发者账号是上架应用程序的必要条件。开发者需要在苹果开发者
2023-04-17
苹果商城上架app需要多少钱
苹果商城上架app需要的费用主要包括两个方面:苹果开发者账号费用和应用审核费用。1. 苹果开发者账号费用苹果开发者账号是上架app的必备条件,开发者需要先注册一个苹果开发者账号。苹果开发者账号分为两种类型:个人账号和企业账号。个人账号适合个人开发者、独立开
2023-04-17
腾讯app上架检测收费
腾讯app上架检测收费是指开发者在将应用程序提交到腾讯应用宝、微信小程序等平台上架前,需要支付一定的费用进行检测和审核。这个费用是由腾讯公司收取的,也是腾讯公司为保证应用内容的合法性、安全性以及用户体验而进行的一项服务。腾讯app上架检测收费的原理是,开发
2023-04-17
如何评价苹果商店上架的view
View是iOS开发中最基础的UI组件,是用户界面中的一个基本元素,通常用来展示和交互。苹果商店上架的View是指在iOS应用程序中使用的视图组件,可以通过苹果商店进行下载和安装。下面将详细介绍View的原理和使用方法。1. View的原理View是iOS
2023-04-17
企业签名app打包无需上架
企业签名App打包无需上架,是指企业可以自己打包App并在内部分发,而不需要将App提交到App Store进行审核和上架。这种方法适用于企业内部使用的App,例如内部员工使用的工具类App,或是企业客户使用的定制化App等。原理:在iOS系统中,每个Ap
2023-04-17
为什么没有新的外卖app上架
外卖APP是近年来飞速发展的一种互联网服务模式,其便捷、快速、实惠的特点深受消费者的欢迎。然而,近期没有新的外卖APP上架的原因主要有以下几个方面。首先,外卖APP市场已经相对饱和。目前,外卖APP市场中已经有了一些巨头企业,如饿了么、美团、百度外卖等,它
2023-04-17
没有资质的理财类app上架ios市场
随着移动互联网的发展,理财类APP越来越受到人们的关注和青睐。然而,苹果公司对于理财类APP的上架有着非常严格的要求,其中就包括必须具备资质才能上架。本文将从苹果公司的要求、理财类APP存在的问题以及如何获得资质等方面介绍没有资质的理财类APP上架ios市
2023-04-17
安卓上架价格
在安卓应用市场上架应用程序,需要支付一定的费用。这些费用通常由应用市场的运营商收取,用于应用市场的维护和管理。不同的应用市场收费标准可能会有所不同,下面我们来详细介绍一下安卓应用上架的价格原理。一、谷歌 Play 商店谷歌 Play 商店是安卓应用市场中最
2023-04-17
ios app上架 演示视频
iOS App上架是一个非常重要的步骤,它能够让你的应用程序在App Store上被用户所发现,并且能够被下载安装。在App Store上架一个应用程序需要满足一些要求,其中一个非常重要的要求就是提交一个演示视频。这篇文章将会介绍iOS App上架演示视频
2023-04-17
app苹果商店上架公告
在移动应用市场中,苹果商店(App Store)是最受欢迎的应用商店之一。苹果商店是苹果公司为iOS设备用户提供的一个应用下载平台。苹果商店上架是指将开发者开发的应用程序上传到苹果商店并通过审核后,使其能够被用户下载和使用的过程。本文将对苹果商店上架的原理
2023-04-17
app在苹果上架的费用
在苹果上架应用程序(App)是一个相对简单的过程,但是需要支付一些费用。苹果公司规定,每年需要支付一定的开发者费用,才能够在苹果应用商店(App Store)上架自己的应用程序。开发者费用苹果公司为开发者提供了两种不同的开发者费用计划。若开发者仅想要在苹果
2023-04-17
app架构图在什么软件上好制作
App架构图是描述应用程序架构的一种图形化表示方式。它可以帮助开发人员和其他利益相关者更好地理解应用程序的结构和组件之间的关系,从而更好地维护和开发应用程序。在制作App架构图方面,有许多软件可供选择,以下是几种常用的软件及其原理和详细介绍。1. Visi
2023-04-14