第一次写博客,目的在于总结一下最近做第三方登录踩过的坑,陈述的观点不一定都是正确的,但是我想能为遇到类似问题的小伙伴提供一些思路和启迪,不足之处还请谅解!
虽然现在有友盟这样集成登录的平台,但是有的情况下却不一定适用,而且,如果原生方式的登录能够成功,那么,集成登录的方式自然水到渠成。第三方登录的开发一般都需要经历以下过程:去官网注册开发者账号,登录账号创建应用获取一些key,将key配置到自己的项目进行开发。这里的key在各个平台略有差异,但实质都是类似的。下面我们就来一一感受。
以下为开发者必备的几个链接:
line开发者官网
line登录官方demo
line android sdk
1、注册账号
line有点奇怪,到目前为止我都没有通过开发者官网找到注册账号的入口,我是使用line app来进行注册的。如果使用line app出现网络问题,请使用vpn。
2、创建应用
有了账号之后,可以去创建一个Channel,这个Channel我理解为一个应用。这个过程没有什么坑,如实填写就好,最终会获得一个Channel ID,这个在后续开发中会用到。
接着,需要进入Technical configuration,填写一些配置信息。Android需要填写三项,包名和签名必填。
这里出现了我在开发过程中遇到的最大的坑。由于我在做line登录之前已经做了微信登录,微信后台也要需要填写签名,微信提供了获取签名的app,非常方便。于是乎,这里的签名我就使用了做微信登录时获取到的,然而事实证明,二者是南辕北辙的。如果这里的签名错了,在其他条件都正常的情况下,网页授权登录的方式可以成功,但是调用line app进行授权登录是一定会失败的。
这里提供两种方法获取SHA1:
第一,使用命令行keytool -list -v -keystore + keystore的路径,eg:
keytool -list -v -keystore "D:\Users\cyq7on.android\debug.keystore"。
第二个方法完全来自于一位网友:
PS:为了避免注册时弄错签名,建议直接用打包出来的apk查看签名,具体如下:
1) 将apk修改后缀为 .rar文件后解压;
2) 进入解压后的META-INF目录,该目录下会存在文件CERT.RSA
3) 在该目录下打开cmd,输入命令 :keytool -printcert -file CERT.RSA
这里将会显示出MD5和SHA1签名。
可以在评论区找到这位网友
3、配置工程,进行开发
准备工作终于完成,现在可以进入正式开发了。
建好工程之后,将line-android-sdk中的jar包拷进libs文件夹,将.so文件拷进jniLibs文件夹,如果没有jniLibs文件夹,可在main目录下新建一个,工程结构如下:
除此之外,AndroidManifest里面还需要进行配置:
<!-- LINE SDK Settings -->
<activity
android:name="jp.line.android.sdk.activity.LineAuthCompleteActivity"
android:configChanges="keyboard|orientation"
android:exported="true"
android:screenOrientation="sensor" >
<intent-filter>
<action android:name="android.intent.action.VIEW" />
<category android:name="android.intent.category.DEFAULT" />
<category android:name="android.intent.category.BROWSABLE" />
<data android:scheme="line.Channel ID" />
</intent-filter>
</activity>
<activity
android:name="jp.line.android.sdk.activity.WebLoginActivity"
android:configChanges="keyboard|orientation"
android:exported="false"
android:screenOrientation="sensor" >
</activity>
<meta-data
android:name="jp.line.sdk.ChannelId"
android:value="Channel ID" />
<meta-data
android:name="jp.line.sdk.AuthScheme"
android:value="line.Channel ID" />
Channel ID替换为自己的就可以了。
登录的核心代码:
LineAuthManager authManager = LineSdkContextManager.getSdkContext().getAuthManager();
authManager.login(this).addFutureListener(
new LineLoginFutureListener() {
@Override
public void loginComplete(LineLoginFuture future) {
switch (future.getProgress()) {
case SUCCESS:
displayCroutonOnMainThread("Logged in!", Style.INFO);
logger.info("Login success!");
break;
case CANCELED:
displayCroutonOnMainThread("Don't cancel login!", Style.ALERT);
logger.info("Login canceled!");
break;
default:
displayCroutonOnMainThread("An error occurred. Please try again.", Style.ALERT);
logger.info("Login error!");
break;
}
}
});
上述代码来源于官方demo,这里注意一下displayCroutonOnMainThread方法,顾名思义,我们可以看出,loginComplete方法其实是回调在子线程的。这里我有一点疑惑,我故意在子线程里操作了UI,结果程序没有崩溃,希望有大神可以指点一二。
使用authManager.login方法,如果手机安装了line app则会调用app进行授权登录,反之则使用网页授权登录。而另一个方法,loginByAccount则无论手机是否安装line app,都会使用网页授权登录的方式。此外,要登出也有一个方法,authManager.logout()。
如果登录出现错误,可以使用如下代码获取错误信息:
public void loginComplete(LineLoginFuture future) {
logger.info("Login error! " + future.getCause().getMessage());
}
如果你能成功登录自己的账号,换一个其他账号却失败,那么最有可能是配置问题。解决方法有二:
第一,在Channel的Basic information中将应用的状态由DEVELOPING改为PUBLISHED;
第二,在Channel的Roles中添加需要测试的用户。
line登录踩过的坑大致就是这些了,有问题欢迎指教和探讨!