360SDK快速接入
1.重要提醒
本文档面向安卓开发者。
本文档用于指导开发者快速接入360社交带支付SDK,本SDK为安卓应用提供登录、注册、社交、支付等功能。
SDK接入请以SDK包内相应版本文档为准。
1.1 必接API说明
技术接入中每一个小节标题上写明【必接】二字的,为必接API,不接则无法过审。未写明【必接】二字的可根据实际需求选择接入。
游戏若不需要支付功能,须先接入支付相关API,但不调用支付模块即可。其他功能亦是。
1.2 应用服务器
游戏必须使用自己搭建的应用服务器,不可使用DEMO服务器,url(http://sdbxapp.msdk.mobilem.360.cn) 仅限DEMO示范使用,禁止正式上线游戏把DEMO应用服务器当做正式应用服务器使用。
1.3 编译版本最低要求
android-20,4.4以上的版本
1.4 PrivateKey计算方法
必须把APPID、APPKEY、PRIVATEKEY三个值填写在AndroidManifest文件中,不能使用@string引用;禁止把App-Secret保存在手机客户端,AndroidManifest中存放的是Private Key,不是App-Secret。
Private Key的算法为:QHOPENSDK_PRIVATEKEY = MD5(appSecret + "#" + appKey),32位小写。
例:appSecret=446a0351fa4a7a85970e354d6fd9845e,
appKey=08158bf9f09b949790a63f10c181be52,
因此MD5(446a0351fa4a7a85970e354d6fd9845e#08158bf9f09b949790a63f10c181be52)
结果为QHOPENSDK_PRIVATEKEY=09024faa7aa4234803e337b774735176。
1.5 主Activity设置
游戏(无论横竖屏)必须在主Activity设置成@android:style/Theme.NoTitleBar.Fullscreen
1.6 Unity相关问题
暂不支持Unity、cocos等其他引擎,只支持eclipse。请将工程先导入eclipse再出apk包。
如有问题请尝试升级adt。
1.7 测试须知
1.自检工具(check tools)用来检验SDK接入是否正确。自检时请不要将代码混淆或者加固,请用未加固、未混淆的代码自检。
自检常见问题及解决方法:
自检结果显示:提取classes.dex失败。
(1) 不应把代码混淆或加固。
(2) 没有把assets下的文件拷贝到工程下。
(3) 编译版本未达到最低要求。
(4) 缺少文件,请对比demo检查是否缺少部分文件夹
(5) 使用Unity或者其他引擎出的apk包,请先将工程导入eclipse然后导出apk包。
提取smali文件失败。
(1) 不应把代码混淆或加固。
(2) 因工程方法太多,需要进行拆分造成的。把sdk放到第一个dex里面即可。
2.测试用例是用来帮助CP遍历测试SDK接入之后功能否正常使用,在SDK包的doc文件夹内。
1.8 附加信息
自检工具(1.3.6及以上版本自检工具在SDK压缩包内)及服务器代码示例下载地址:http://dev.360.cn/wiki/index/id/73
线上FAQ地址:http://dev.360.cn/wiki/index/id/74
接入中遇到问题先用自检工具自检,自检通过后依然查不出问题可咨询相关人员。
开发者平台相关问题联系
开平-包打听:2724990365
百晓生:22069053690
SDK接入相关问题联系
Sdk-包打听:2833717137
平台加固相关问题请加Q群
360加固宝客服:198501978
2.申请APPID、APPKEY和APPSECRET
企业开发者需要在360开放平台 http://dev.360.cn 申请APPID和APPKEY(一个应用只能申请一个appkey)。
申请指南:http://aw9rrsljhj.l7.yunpan.cn/lk/QztXxKvmXwhkZ
3.导入资源包
本SDK目前支持Android2.2及以上的系统版本,为兼容Android 4.0及以上的新手机,编译时请使用Android4.2 或以上的版本,360SDK开发环境的配置流程如下(参考下图demo开发环境配置,导入demo工程请以utf-8编码,Android4.2导入):
Demo工程主要的包和类介绍:
com.qihoo.gamecenter.sdk.demosp.activity下的类演示SDK各个接口的调用。游戏接入SDK联调时,请着重参考类:SdkUserBaseActivity:
LandscapeSdkUserActivity.java横屏状态下演示SDK各个接口的调用
PortraitSdkUserActivity.java竖屏状态下掩饰SDK各个接口的调用
SdkUserBaseActivity.java 是LandscapeSdkUserActivity和PortraitSdkUserActivity的基类,是SDK各个接口的调用实现.
com.qihoo.gamecenter.sdk.demosp.payment下是支付相关的基本数据结构和常量。
QihooPayInfo.java , 请求360SDK支付接口时的参数信息类。
com.qihoo.gamecenter.sdk.demosp.utils,demo里面定义的一些工具类。
QihooUserInfo,360用户信息数据。
Utils.java, 一些工具函数。
3.1 导入jar包
将SDK包内的libs目录下的文件(夹)放到应用工程的libs目录下。
3.2 添加assets目录下的文件
将assets目录下的文件(夹)复制到应用工程assets目录下。
4.配置应用工程的AndroidManifest.xml
具体配置参见SDK包内的demo-src目录下的demo源代码。
4.1 添加权限
<!--添加360SDK必需要的权限。 --> <uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="android.permission.SEND_SMS" /> <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> <uses-permission android:name="android.permission.READ_PHONE_STATE" /> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" /> <uses-permission android:name="android.permission.CHANGE_NETWORK_STATE" /> <uses-permission android:name="android.permission.CHANGE_WIFI_STATE" /> <uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW" /> <uses-permission android:name="android.permission.READ_CONTACTS"/> <uses-permission android:name="android.permission.WRITE_SMS"/> <!-- payment --> <uses-permission android:name="android.permission.GET_TASKS" /> <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" /> <uses-permission android:name="android.permission.RECEIVE_SMS" /> <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" /> <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" /> <uses-permission android:name="android.permission.RESTART_PACKAGES" /> <uses-permission android:name="android.webkit.permission.PLUGIN" /> <!-- float sdk --> <uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS" /> <uses-permission android:name="android.permission.VIBRATE" /> <!-- weixin --> <uses-permission android:name="android.permission.MODIFY_AUDIO_SETTINGS"/> <!-- qiku start --> <!-- 系统账户操作权限 --> <uses-permission android:name="android.permission.GET_ACCOUNTS" /> <uses-permission android:name="android.permission.MANAGE_ACCOUNTS" /> <uses-permission android:name="android.permission.AUTHENTICATE_ACCOUNTS" /> <uses-permission android:name="android.permission.USE_CREDENTIALS" /> <!-- 系统设置操作权限 --> <uses-permission android:name="android.permission.WRITE_SETTINGS" /> <uses-permission android:name="android.permission.READ_SETTINGS" /> <!-- 语音聊天模块权限(如果定制语音聊天模块,则添加该权限) --> <uses-permission android:name="android.permission.RECORD_AUDIO"/> <!-- QDAS打点SDK所需权限 --> <uses-permission android:name="android.permission.READ_LOGS" />
4.2 添加activity
注意:必须放入<application>元素区块内
<!-- 添加360SDK必需的activity:com.qihoo.gamecenter.sdk.activity.ContainerActivity --> <activity android:name="com.qihoo.gamecenter.sdk.activity.ContainerActivity" android:configChanges="fontScale|orientation|keyboardHidden|locale|navigation|screenSize|uiMode|layoutDirection" android:theme="@android:style/Theme.Translucent.NoTitleBar" android:exported="true"> <!-- 支付宝签约后自动跳转到sdk配置 --> <intent-filter> <action android:name="android.intent.action.MAIN" /> <action android:name="android.intent.action.VIEW" /> <category android:name="android.intent.category.DEFAULT" /> <category android:name="android.intent.category.BROWSABLE" /> <!-- android host的值必须为游戏的包名 --> <data android:host="游戏包名"/> <!-- android scheme的值不可修改--> <data android:scheme="qihooonlinepay" /> </intent-filter> </activity> <!-- 360SDK浮窗 浮窗相关配置在1.1.0以及以后的版本中删除了,如果以前接入过SDK的游戏配置中存在浮窗相关的配置,请手动删除 --> <!-- 个人中心activity --> <!-- activity android:name="com.qihoo.gamecenter.sdk.suspend.personal.PersonalActivity" android:configChanges="fontScale|orientation|keyboardHidden|locale|navigation|screenSize|uiMode" android:windowSoftInputMode="adjustPan" android:theme="@android:style/Theme.Translucent.NoTitleBar" android:screenOrientation="portrait" > <intent-filter> <action android:name="" /> </intent-filter> </activity --> <!-- receiver android:name="com.qihoo.gamecenter.sdk.suspend.local.QBootReceiver" android:permission="android.permission.RECEIVE_BOOT_COMPLETED" > <intent-filter> <action android:name="android.intent.action.BOOT_COMPLETED" /> </intent-filter> </receiver --> <!--service android:name="com.qihoo.gamecenter.sdk.suspend.remote.QRemoteService" android:exported="true" android:process=":QSuspendRemote" > <intent-filter> <action android:name="com.qihoo.gamecenter.sdk.suspend.service.action.remote" /> </intent-filter> </service --> <!-- service android:name="com.qihoo.gamecenter.sdk.suspend.local.QLocalService" android:exported="false" > <intent-filter> <action android:name="com.qihoo.gamecenter.sdk.suspend.local.QLocalService" /> </intent-filter> </service --> <!-- 360SDK浮窗 End --> <!-- payment activities begin --> <!--添加360SDK必需的activity:com.qihoopp.qcoinpay.QcoinActivity --> <activity android:name="com.qihoopp.qcoinpay.QcoinActivity" android:configChanges="fontScale|orientation|keyboardHidden|locale|navigation|screenSize|uiMode" android:theme="@android:style/Theme.Translucent.NoTitleBar" android:windowSoftInputMode="stateAlwaysHidden|adjustResize" > </activity> <!--alipay sdk begin --> <activity android:name="com.alipay.sdk.app.H5PayActivity" android:screenOrientation="portrait" > </activity> <!--alipay sdk end --> <!-- 微信支付界面--> <activity android:name="com.iapppay.pay.channel.weixinpay.WeixinWapPayActivity" android:configChanges="screenSize|orientation|keyboard|navigation|layoutDirection" android:theme="@android:style/Theme.Translucent" /> <activity android:name="com.junnet.heepay.ui.activity.WelcomeActivity" android:configChanges="keyboardHidden|orientation|screenSize" android:excludeFromRecents="true" android:screenOrientation="behind" android:theme="@android:style/Theme.Dialog" android:windowSoftInputMode="stateAlwaysHidden|adjustResize" /> <activity android:name="com.junnet.heepay.ui.activity.WechatPaymentActivity" android:configChanges="keyboardHidden|orientation|screenSize" android:excludeFromRecents="true" android:screenOrientation="behind" android:theme="@android:style/Theme.Dialog" android:windowSoftInputMode="stateAlwaysHidden|adjustResize" /> <activity android:name="com.ipaynow.plugin.activity.PayMethodActivity" android:configChanges="keyboardHidden|orientation|screenSize" android:exported="false" android:screenOrientation="behind" android:theme="@android:style/Theme.Dialog" /> <activity android:name="com.ipaynow.plugin.inner_plugin.wechat_plugin.activity.WeChatNotifyActivity" android:configChanges="keyboardHidden|orientation|screenSize" android:screenOrientation="behind" android:theme="@android:style/Theme.NoDisplay" /> <!-- 以下Activity是SDK插件化使用的代理Activity --> <activity android:name="com.qihoo.sdkplugging.host.HostProxyActivity" android:configChanges="fontScale|orientation|keyboardHidden|locale|navigation|screenSize|uiMode|layoutDirection" android:theme="@android:style/Theme.Translucent.NoTitleBar" android:label="360SDK" > <intent-filter> <action android:name="com.qihoo.sdkplugging.host.proxy.activity.VIEW" /> <category android:name="android.intent.category.DEFAULT" /> </intent-filter> </activity> <!-- payment activities end --> <!--如下是360游戏实时推送SDK必要声明,不可修改 --> <receiver android:name="com.qihoo.psdk.local.QBootReceiver" android:permission="android.permission.RECEIVE_BOOT_COMPLETED" > <intent-filter> <action android:name="android.intent.action.BOOT_COMPLETED" /> </intent-filter> <intent-filter> <action android:name="android.net.conn.CONNECTIVITY_CHANGE" /> </intent-filter> </receiver> <activity android:name="com.qihoo.psdk.app.QStatActivity" android:launchMode="singleInstance" android:theme="@android:style/Theme.Translucent.NoTitleBar" > </activity> <service android:name="com.qihoo.psdk.remote.QRemoteService" android:exported="true" android:process=":QRemote" > <intent-filter> <action android:name="com.qihoo.psdk.service.action.remote" /> </intent-filter> </service> <service android:name="com.qihoo.psdk.local.QLocalService" android:exported="true" android:process=":QLocal" > <intent-filter> <action android:name="com.qihoo.psdk.service.action.local" /> </intent-filter> </service> <!-- push sdk end --> <!--微信相关的activity,如需接入,请直接使用demo中的WXEntryActivity类的代码实现, 类的全名为:“应用包名.wxapi.WXEntryActivity”。 注意1: 除非游戏打算以后永远不会支持微信分享,否则建议游戏把这个actvity的配置加上。 此版本的SDK支持从服务端配置微信分享的appid。 Manifest中的QHOPENSDK_WEIXIN_APPID 字段可以先不配,后续申请到微信的appid可以在服务端配置。 注意2:不要修改此actitiy的android:name属性。 例如:如果游戏的包名为com.a.b.c,那么应该将demo中的WXEntryActivity.java放到 “${工程目录}/src/com/a/b/c/wxapi/WXEntryActivity.java”这个路径下。 并将此java文件中的第一行package声明修改为“package com.a.b.c.wxapi;” --> <activity android:name=".wxapi.WXEntryActivity" android:label="@string/demo_app_name" android:theme="@android:style/Theme.Translucent.NoTitleBar" android:exported="true" /> <!-- UpdateLib start --> <service android:name="com.qihoo.appstore.updatelib.CheckUpdateService" android:exported="false" /> <activity android:name="com.qihoo.updatesdk.lib.UpdateTipDialogActivity" android:configChanges="keyboardHidden|orientation|screenSize" android:exported="false" android:screenOrientation="portrait" android:theme="@android:style/Theme.Translucent.NoTitleBar"/> <!-- UpdateLib end --> <!-- gameunion plugin start --> <activity android:name="com.qihoo.gameunionforsdk.SimpleWebView" android:configChanges="fontScale|orientation|keyboardHidden|locale|navigation|screenSize|uiMode|layoutDirection" android:theme="@android:style/Theme.Translucent.NoTitleBar" /> <!-- gameunion plugin end -->
5.编码接入
详见技术接入其他章节
6.混淆编译
如果要混淆java代码,请不要混淆联编的jar包中的类。可以添加以下类到proguard配置,排除在混淆之外:
-keep class cn.pp.** { *; } -keep class com.alipay.** {*;} -keep class com.qihoo.** {*;} -keep class com.qihoo360.** { *; } -keep class com.qihoopp.** { *; } -keep class com.yeepay.safekeyboard.** { *; } -keep class com.amap.** {*;} -keep class com.aps.** {*;} -keep class com.iapppay.** {*;} -keep class com.ipaynow.** {*;} -keep class com.junnet.heepay.** {*;} -keep class com.tencent.mm.** {*;} -keep class com.coolcloud.uac.android.** {*;} -keep class tv.cjump.jni.** {*;} -keep class HttpUtils.** {*;} -keep class com.a.a.** {*;} -keep class com.emoji.** {*;} -keep class com.google.android.exoplayer.** {*;} -keep class com.ta.utdid2.** {*;} -keep class com.ut.device.** {*;} -keep class com.master.flame.danmaku.** {*;} -keep class tv.cjump.jni.** {*;} -keep class com.qihoo.sdkplugging.host.** {*;} -keep public class com.qihoo.gamecenter.sdk.matrix.PluggingHostProxy {*;}
关闭混淆警告可以使用-ignorewarnings参数,或者使用如下配置只关闭SDK类的混淆警告:
-dontwarn cn.pp.** -dontwarn com.alipay.android.app.** -dontwarn com.qihoo.** -dontwarn com.qihoo360.** -dontwarn com.qihoopp.** -dontwarn com.yeepay.safekeyboard.** -dontwarn com.amap.** -dontwarn org.apache.http.conn.ssl.SSLSocketFactory
7.测试
1. 请使用自测工具检查接入完整性;
2. 在 SDK 包中提供了测试用例,用于功能点测试。
8.提交
经过测试后的 app,请在360移动开放平台http://dev.360.cn/提交 apk 文件
9.审核
应用提交审核后,360平台会将审批结果以邮件形式进行反馈。
客服电话:010-58781044
客服邮箱:[email protected]
10.上线
应用通过审核后将在1个小时后发布上线。
更多建议: