由于项目中需要使用LINE进行一键登录,所以记录下步骤,其实小伙伴直接看官网也可以,介绍的蛮详细的,先看下效果图吧。
将库导入项目
在模块级build.gradle文件中添加LINE SDK依赖项。
repositories {
...
jcenter()
}
dependencies {
...
implementation 'com.linecorp:linesdk:5.0.1'
...
}
添加Android编译选项
启用Java 1.8支持。在与build.gradle上述相同的文件中,添加:
android {
...
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
...
}
设置Android清单文件
要指定您的应用程序需要Internet访问,请INTERNET向您的AndroidManifest.xml文件添加权限。
注意:
确保进行登录调用的活动的启动模式未设置为,singleInstance因为这可能会阻止活动接收onActivityResult回调。
将您的应用链接到您的频道
将您的应用程序链接到LINE登录频道,在LINE Developers Console
https://developers.line.biz/console/上您的频道设置的LINE Login选项卡上启用移动应用程序,然后填写这些字段。
- 软件包名称:必填。应用程序的软件包名称,用于启动Google Play商店。
- 软件包签名:可选。您可以通过在新行中输入每个签名来设置多个签名。
- Android URL方案:可选。用于启动您的应用程序的自定义URL方案。
注意:SHAI是可以填写多个的,进行换行就可以了。
官网中提供了LINE SDK内置的登录按钮,但大部分开发中,我们都是有自己的一套UI,所以我就只介绍自定义登录按钮的流程了。
开始登录活动
当用户点击登录按钮时,您的应用程序会调用getLoginIntent()以获取登录意图并启动登录活动。上下文和通道ID必须传递到此方法中。如果设备上安装了LINE,则会打开LINE进行登录,而无需询问用户的LINE凭据。如果未安装LINE,则将用户重定向到浏览器中的LINE登录屏幕,以输入其LINE凭据(电子邮件地址和密码)。
1.设置单击监听器,以在单击按钮时进行监听。
2.在onClick回调中,调用中的getLoginIntent()方法LineLoginApi以获取登录意图以启动登录活动。
3.通过调用startActivityForResult()并传递登录意图和请求代码作为参数来启动身份验证过程。请求代码是用于标识请求的整数。
以下是一个示例,说明当用户点击登录按钮时如何启动活动以登录用户。
private static final int REQUEST_CODE = 1;
...
final TextView loginButton = (TextView) findViewById(R.id.login_button);
loginButton.setOnClickListener(new View.OnClickListener() {
public void onClick(View view) {
try{
// App-to-app login
Intent loginIntent = LineLoginApi.getLoginIntent(
view.getContext(),
Constants.CHANNEL_ID,
new LineAuthenticationParams.Builder()
.scopes(Arrays.asList(Scope.PROFILE))
// .nonce("") // nonce can be used to improve security
.build());
startActivityForResult(loginIntent, REQUEST_CODE);
}
catch(Exception e) {
Log.e("ERROR", e.toString());
}
}
});
注意:
如果您不想使用应用程序对应用程序登录,而是让用户通过浏览器中的“ LINE登录”屏幕登录,请使用该getLoginIntentWithoutLineAppAuth()方法。
处理登录结果
用户登录后,登录结果将以活动的onActivityResult()
方法返回。您的应用程序必须重写此方法以处理登录结果。
使用对象的getResponseCode()
方法LineLoginResult
确定登录是否成功。如果getResponseCode()
返回SUCCESS
,则登录成功。任何其他值表示失败。请参阅处理错误以确定发生的错误的类型。
以下示例显示了您的应用如何处理登录结果的示例。
public void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if (requestCode != REQUEST_CODE) {
Log.e("ERROR", "Unsupported Request");
return;
}
LineLoginResult result = LineLoginApi.getLoginResultFromIntent(data);
switch (result.getResponseCode()) {
case SUCCESS:
// Login successful
String accessToken = result.getLineCredential().getAccessToken().getTokenString();
Intent transitionIntent = new Intent(this, PostLoginActivity.class);
transitionIntent.putExtra("line_profile", result.getLineProfile());
transitionIntent.putExtra("line_credential", result.getLineCredential());
startActivity(transitionIntent);
break;
case CANCEL:
// Login canceled by user
Log.e("ERROR", "LINE Login Canceled by user.");
break;
default:
// Login canceled due to other error
Log.e("ERROR", "Login FAILED!");
Log.e("ERROR", result.getErrorData().toString());
}
}
获取访问令牌
登录结果包含一个LineCredential()
对象,该对象包含用户的访问令牌。如上面的示例所示,您可以使用以下代码检索访问令牌。
String accessToken = result.getLineCredential().getAccessToken().getTokenString();
登录后立即获取用户资料
LINE SDK在登录时自动获取用户的配置文件信息。用户的配置文件信息由显示名称,用户ID,状态消息和配置文件媒体URL组成。通过调用对象中的getLineProfile()
方法来访问此信息LineLoginResult
。上面示例中的以下代码片段演示了如何从登录结果中获取用户的个人资料信息并将其传递给意图。
transitionIntent.putExtra("display_name", result.getLineProfile().getDisplayName());
transitionIntent.putExtra("status_message", result.getLineProfile().getStatusMessage());
transitionIntent.putExtra("user_id", result.getLineProfile().getUserId());
transitionIntent.putExtra("picture_url", result.getLineProfile().getPictureUrl().toString());
用户ID仅对于单个提供者是唯一的。相同的LINE用户对于不同的提供者将具有不同的用户ID。避免使用用户ID来识别不同提供商之间的用户。