美文网首页
Line登录踩过坑

Line登录踩过坑

作者: cyq7on | 来源:发表于2016-12-04 12:05 被阅读1652次

第一次写博客,目的在于总结一下最近做第三方登录踩过的坑,陈述的观点不一定都是正确的,但是我想能为遇到类似问题的小伙伴提供一些思路和启迪,不足之处还请谅解!
虽然现在有友盟这样集成登录的平台,但是有的情况下却不一定适用,而且,如果原生方式的登录能够成功,那么,集成登录的方式自然水到渠成。第三方登录的开发一般都需要经历以下过程:去官网注册开发者账号,登录账号创建应用获取一些key,将key配置到自己的项目进行开发。这里的key在各个平台略有差异,但实质都是类似的。下面我们就来一一感受。
以下为开发者必备的几个链接:
line开发者官网
line登录官方demo
line android sdk

1、注册账号

line有点奇怪,到目前为止我都没有通过开发者官网找到注册账号的入口,我是使用line app来进行注册的。如果使用line app出现网络问题,请使用vpn。

2、创建应用

有了账号之后,可以去创建一个Channel,这个Channel我理解为一个应用。这个过程没有什么坑,如实填写就好,最终会获得一个Channel ID,这个在后续开发中会用到。


Channel的基本信息

接着,需要进入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登录踩过的坑大致就是这些了,有问题欢迎指教和探讨!

相关文章

  • Line登录踩过坑

    第一次写博客,目的在于总结一下最近做第三方登录踩过的坑,陈述的观点不一定都是正确的,但是我想能为遇到类似问题的小伙...

  • echarts-doc

    【echarts3】 折线图我踩过的那些坑 (tooltip 设置,line 单个点/散点不显示问题) toolt...

  • iOS第三方登录总结(一)Facebook

    由于当前项目需要有FB 、Line 、Twitter、Apple 三方登录我一一介绍他们的集成步骤和踩的坑首先是F...

  • 交互设计师所要避免的几个坑

    前言 工作中难免会踩到几个坑,即使现在不踩以后还会踩,只有踩过才会深刻记住,踩过说明爱过!但是踩过的坑必须把坑填满...

  • 关于登录设计的全面梳理

    登录、注册这样的老话题对于产品经理来讲,可谓是陈词滥调了,不过又有哪个产品经理在从业之初,没有挖过登录的坑、踩过登...

  • vue踩过的坑

    vue踩过的坑

  • D1094:踩坑的价值最大化

    是人就会踩坑,不踩坑理论上就不属于人类,踩坑是人之常情,能回头站在坑边反思,才是对踩过的的坑价值最大化的体现,要不...

  • iOS-项目中TouchID的坑

    最近项目中,增加了利用TouchID验证登录的问题,以前也没有接触过,还是处于探索中完成需求吧,这里把踩过的坑谈一...

  • PHP中的数据类型

    一说到数据类型,这个坑就太多了,多到有哪些坑,有多少坑,不知道自己还会踩哪些坑,以及踩过的坑还会不会再踩,我对...

  • 投资避坑指南

    2022年9月14日(第224天) 经常反思踩过的坑,犯过的错,了解别人踩过的坑,犯过的错,思考如何避免自己下次踩...

网友评论

      本文标题:Line登录踩过坑

      本文链接:https://www.haomeiwen.com/subject/fxdhmttx.html