mirror of
https://github.com/logto-io/logto.git
synced 2025-01-06 20:40:08 -05:00
refactor(console): update android sdk integration guide
This commit is contained in:
parent
ab4e649199
commit
3587b20021
3 changed files with 87 additions and 215 deletions
|
@ -2,26 +2,30 @@ import UriInputField from '@mdx/components/UriInputField';
|
||||||
import Step from '@mdx/components/Step';
|
import Step from '@mdx/components/Step';
|
||||||
import Tabs from '@mdx/components/Tabs';
|
import Tabs from '@mdx/components/Tabs';
|
||||||
import TabItem from '@mdx/components/TabItem';
|
import TabItem from '@mdx/components/TabItem';
|
||||||
|
import Alert from '@/components/Alert';
|
||||||
|
|
||||||
<Step
|
<Step
|
||||||
title="Install SDK"
|
title="Integrate Logto Android SDK"
|
||||||
subtitle="Install Logto Android SDK with Gradle"
|
subtitle="Add Logto SDK as a dependency"
|
||||||
index={0}
|
index={0}
|
||||||
activeIndex={props.activeStepIndex}
|
activeIndex={props.activeStepIndex}
|
||||||
onButtonClick={() => props.onNext(1)}
|
onButtonClick={() => props.onNext(1)}
|
||||||
>
|
>
|
||||||
|
|
||||||
### Prerequisite
|
<Alert>
|
||||||
* Minimal Android SDK: Level 24
|
The minimum supported Android API is level 24
|
||||||
|
</Alert>
|
||||||
|
|
||||||
Add the `mavenCentral()` repository to your Gradle project build file:
|
Add the `mavenCentral()` repository to your Gradle project build file:
|
||||||
|
|
||||||
```kotlin
|
```kotlin
|
||||||
repositories {
|
repositories {
|
||||||
mavenCentral()
|
mavenCentral()
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
Add the Logto Android SDK to your dependencies:
|
Add Logto Android SDK to your dependencies:
|
||||||
|
|
||||||
<Tabs>
|
<Tabs>
|
||||||
|
|
||||||
<TabItem value="kotlin" label="Kotlin">
|
<TabItem value="kotlin" label="Kotlin">
|
||||||
|
@ -49,35 +53,13 @@ dependencies {
|
||||||
</Step>
|
</Step>
|
||||||
|
|
||||||
<Step
|
<Step
|
||||||
title="Configure"
|
title="Init LogtoClient"
|
||||||
subtitle="Configure your application and LogtoClient"
|
subtitle="1 step"
|
||||||
index={1}
|
index={1}
|
||||||
activeIndex={props.activeStepIndex}
|
activeIndex={props.activeStepIndex}
|
||||||
onButtonClick={() => props.onNext(2)}
|
onButtonClick={() => props.onNext(2)}
|
||||||
>
|
>
|
||||||
|
|
||||||
### Configure Redirect URI
|
|
||||||
|
|
||||||
The `Redirect URI` indicates the endpoint that the application used to receive authorization results, which is implemented by the Logto Android SDK internally.
|
|
||||||
|
|
||||||
### Configure Redirect URI in Admin Console
|
|
||||||
|
|
||||||
Add the following value to Redirect URIs input field
|
|
||||||
|
|
||||||
```bash
|
|
||||||
$(LOGTO_REDIRECT_SCHEME)://$(YOUR_APP_PACKAGE)/callback
|
|
||||||
```
|
|
||||||
|
|
||||||
Notes:
|
|
||||||
- `LOGTO_REDIRECT_SCHEME` should be a custom scheme in the reverse domain format.
|
|
||||||
- Replace `$(LOGTO_REDIRECT_SCHEME)` with your own settings.
|
|
||||||
|
|
||||||
e.g. `io.logto.android://io.logto.sample/callback`
|
|
||||||
|
|
||||||
<UriInputField appId={props.appId} isSingle={!props.isCompact} name="redirectUris" title="Redirect URI" />
|
|
||||||
|
|
||||||
### Configure Logto Android SDK
|
|
||||||
|
|
||||||
<Tabs>
|
<Tabs>
|
||||||
|
|
||||||
<TabItem value="kotlin" label="Kotlin">
|
<TabItem value="kotlin" label="Kotlin">
|
||||||
|
@ -105,8 +87,9 @@ class MainActivity : AppCompatActivity() {
|
||||||
|
|
||||||
<TabItem value="java" label="Java">
|
<TabItem value="java" label="Java">
|
||||||
|
|
||||||
```java
|
<pre>
|
||||||
import io.logto.sdk.android.LogtoClient;
|
<code className="language-java">
|
||||||
|
{`import io.logto.sdk.android.LogtoClient;
|
||||||
import io.logto.sdk.android.type.LogtoConfig;
|
import io.logto.sdk.android.type.LogtoConfig;
|
||||||
|
|
||||||
public class MainActivity extends AppCompatActivity {
|
public class MainActivity extends AppCompatActivity {
|
||||||
|
@ -118,8 +101,8 @@ public class MainActivity extends AppCompatActivity {
|
||||||
setContentView(R.layout.activity_main);
|
setContentView(R.layout.activity_main);
|
||||||
|
|
||||||
LogtoConfig logtoConfig = new LogtoConfig(
|
LogtoConfig logtoConfig = new LogtoConfig(
|
||||||
"<your-logto-endpoint>",
|
"${props.endpoint}",
|
||||||
"<your-app-id>",
|
"${props.appId}",
|
||||||
null,
|
null,
|
||||||
null,
|
null,
|
||||||
true
|
true
|
||||||
|
@ -127,40 +110,39 @@ public class MainActivity extends AppCompatActivity {
|
||||||
|
|
||||||
logtoClient = new LogtoClient(logtoConfig, getApplication());
|
logtoClient = new LogtoClient(logtoConfig, getApplication());
|
||||||
}
|
}
|
||||||
}
|
}`}
|
||||||
```
|
</code>
|
||||||
|
</pre>
|
||||||
|
|
||||||
</TabItem>
|
</TabItem>
|
||||||
|
|
||||||
</Tabs>
|
</Tabs>
|
||||||
|
|
||||||
Notes:
|
|
||||||
|
|
||||||
- `<your-logto-endpoint>` is the logto service running in your machine. If you start logto service in `http://localhost:300` then `<your-logto-endpoint` will be `http://localhost:300`
|
|
||||||
- `<your-app-id>` is the Application ID of your application, which is created in the Admin Console.
|
|
||||||
|
|
||||||
</Step>
|
</Step>
|
||||||
|
|
||||||
<Step
|
<Step
|
||||||
title="Sign In"
|
title="Sign In"
|
||||||
subtitle="Sign In to your application by Logto and do some extra works"
|
subtitle="2 steps"
|
||||||
index={2}
|
index={2}
|
||||||
activeIndex={props.activeStepIndex}
|
activeIndex={props.activeStepIndex}
|
||||||
onButtonClick={() => props.onNext(3)}
|
onButtonClick={() => props.onNext(3)}
|
||||||
>
|
>
|
||||||
|
|
||||||
### Perform a signing-in action
|
### Configure Redirect URI
|
||||||
|
|
||||||
|
First, let’s configure your redirect URI. E.g. `io.logto.android://io.logto.sample/callback`
|
||||||
|
|
||||||
|
<UriInputField appId={props.appId} isSingle={!props.isCompact} name="redirectUris" title="Redirect URI" />
|
||||||
|
|
||||||
|
Go back to your IDE/editor, use the following code to implement sign-in:
|
||||||
|
|
||||||
<Tabs>
|
<Tabs>
|
||||||
|
|
||||||
<TabItem value="kotlin" label="Kotlin">
|
<TabItem value="kotlin" label="Kotlin">
|
||||||
|
|
||||||
```kotlin
|
```kotlin
|
||||||
logtoClient.signInWithBrowser(
|
logtoClient.signIn(this, "<your-redirect-uri>") { logtoException: LogtoException? ->
|
||||||
this,
|
// User signed in successfully if `logtoException` is null.
|
||||||
"io.logto.android://io.logto.sample/callback",
|
|
||||||
) { logtoException: LogtoException? ->
|
|
||||||
// custom logic
|
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -169,54 +151,8 @@ logtoClient.signInWithBrowser(
|
||||||
<TabItem value="java" label="Java">
|
<TabItem value="java" label="Java">
|
||||||
|
|
||||||
```java
|
```java
|
||||||
logtoClient.signInWithBrowser(
|
logtoClient.signIn(this, "<your-redirect-uri>", logtoException -> {
|
||||||
this,
|
// User signed in successfully if `logtoException` is null.
|
||||||
"io.logto.android://io.logto.sample/callback",
|
|
||||||
logtoException -> {
|
|
||||||
// custom logic
|
|
||||||
}
|
|
||||||
);
|
|
||||||
```
|
|
||||||
|
|
||||||
</TabItem>
|
|
||||||
|
|
||||||
</Tabs>
|
|
||||||
|
|
||||||
### Implement your business logic after signing-in.
|
|
||||||
|
|
||||||
<Tabs>
|
|
||||||
|
|
||||||
<TabItem value="kotlin" label="Kotlin">
|
|
||||||
|
|
||||||
```kotlin
|
|
||||||
logtoClient.getAccessToken { logtoException: LogtoException?, result: AccessToken? ->
|
|
||||||
// custom logic
|
|
||||||
}
|
|
||||||
|
|
||||||
logtoClient.getIdTokenClaims { logtoException: LogtoException?, result: IdTokenCliams? ->
|
|
||||||
// custom logic
|
|
||||||
}
|
|
||||||
|
|
||||||
logtoClient.fetchUserInfo { logtoException: LogtoException?, userInfoResponse: UserInfoResponse? ->
|
|
||||||
// custom logic
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
</TabItem>
|
|
||||||
|
|
||||||
<TabItem value="java" label="Java">
|
|
||||||
|
|
||||||
```java
|
|
||||||
logtoClient.getAccessToken((logtoException, accessToken) -> {
|
|
||||||
// custom logic
|
|
||||||
});
|
|
||||||
|
|
||||||
logtoClient.getIdTokenClaims((logtoException, idTokenClaims) -> {
|
|
||||||
// custom logic
|
|
||||||
});
|
|
||||||
|
|
||||||
logtoClient.fetchUserInfo((logtoException, userInfoResponse) -> {
|
|
||||||
// custom logic
|
|
||||||
});
|
});
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -224,16 +160,19 @@ logtoClient.fetchUserInfo((logtoException, userInfoResponse) -> {
|
||||||
|
|
||||||
</Tabs>
|
</Tabs>
|
||||||
|
|
||||||
|
After signing in successfully, `logtoClient.isAuthenticated` will be `true`.
|
||||||
|
|
||||||
</Step>
|
</Step>
|
||||||
|
|
||||||
<Step
|
<Step
|
||||||
title="Sign Out"
|
title="Sign Out"
|
||||||
|
subtitle="1 step"
|
||||||
index={3}
|
index={3}
|
||||||
activeIndex={props.activeStepIndex}
|
activeIndex={props.activeStepIndex}
|
||||||
onButtonClick={() => props.onNext(4)}
|
onButtonClick={() => props.onNext(4)}
|
||||||
>
|
>
|
||||||
|
|
||||||
### Perform a signing-out action
|
Calling `.signOut(completion)` will always clear local credentials even if errors occurred.
|
||||||
|
|
||||||
<Tabs>
|
<Tabs>
|
||||||
|
|
||||||
|
@ -241,7 +180,7 @@ logtoClient.fetchUserInfo((logtoException, userInfoResponse) -> {
|
||||||
|
|
||||||
```kotlin
|
```kotlin
|
||||||
logtoClient.signOut { logtoException: LogtoException? ->
|
logtoClient.signOut { logtoException: LogtoException? ->
|
||||||
// custom logic
|
// Local credentials are cleared regardless of whether `logtoException` is null.
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -251,7 +190,7 @@ logtoClient.signOut { logtoException: LogtoException? ->
|
||||||
|
|
||||||
```java
|
```java
|
||||||
logtoClient.signOut(logtoException -> {
|
logtoClient.signOut(logtoException -> {
|
||||||
// custom logic
|
// Local credentials are cleared regardless of whether `logtoException` is null.
|
||||||
});
|
});
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -259,15 +198,11 @@ logtoClient.signOut(logtoException -> {
|
||||||
|
|
||||||
</Tabs>
|
</Tabs>
|
||||||
|
|
||||||
Notes:
|
|
||||||
|
|
||||||
- `signOut` will always clear local credentials even if errors occurred.
|
|
||||||
|
|
||||||
</Step>
|
</Step>
|
||||||
|
|
||||||
<Step
|
<Step
|
||||||
title="Further Readings"
|
title="Further readings"
|
||||||
subtitle="3 steps"
|
subtitle="4 articles"
|
||||||
index={4}
|
index={4}
|
||||||
activeIndex={props.activeStepIndex}
|
activeIndex={props.activeStepIndex}
|
||||||
buttonText="admin_console.general.done"
|
buttonText="admin_console.general.done"
|
||||||
|
@ -275,8 +210,9 @@ Notes:
|
||||||
onButtonClick={props.onComplete}
|
onButtonClick={props.onComplete}
|
||||||
>
|
>
|
||||||
|
|
||||||
- Fetch User Info
|
- [Customize sign-in experience](https://docs.logto.io/docs/recipes/customize-sie)
|
||||||
- Configure Social Sign-In
|
- [Enable SMS or email passcode sign-in](https://docs.logto.io/docs/tutorials/get-started/enable-passcode-sign-in)
|
||||||
- Access Protected API Resources
|
- [Enable social sign-in](https://docs.logto.io/docs/tutorials/get-started/enable-social-sign-in)
|
||||||
|
- [Protect your API](https://docs.logto.io/docs/recipes/protect-your-api)
|
||||||
|
|
||||||
</Step>
|
</Step>
|
||||||
|
|
|
@ -2,19 +2,22 @@ import UriInputField from '@mdx/components/UriInputField';
|
||||||
import Step from '@mdx/components/Step';
|
import Step from '@mdx/components/Step';
|
||||||
import Tabs from '@mdx/components/Tabs';
|
import Tabs from '@mdx/components/Tabs';
|
||||||
import TabItem from '@mdx/components/TabItem';
|
import TabItem from '@mdx/components/TabItem';
|
||||||
|
import Alert from '@/components/Alert';
|
||||||
|
|
||||||
<Step
|
<Step
|
||||||
title="安装 SDK"
|
title="在 Android 应用中集成 Logto Android SDK"
|
||||||
subtitle="从 Gradle 安装 Logto Android SDK"
|
subtitle="将 Logto SDK 添加至依赖"
|
||||||
index={0}
|
index={0}
|
||||||
activeIndex={props.activeStepIndex}
|
activeIndex={props.activeStepIndex}
|
||||||
onButtonClick={() => props.onNext(1)}
|
onButtonClick={() => props.onNext(1)}
|
||||||
>
|
>
|
||||||
|
|
||||||
### 前提条件
|
<Alert>
|
||||||
* 最小 Android SDK 版本: Level 24
|
Logto Andorid SDK 支持的最小 Android API 级别为 24
|
||||||
|
</Alert>
|
||||||
|
|
||||||
将 `mavenCentral()` 添加到构建脚本中:
|
将 `mavenCentral()` 添加到构建脚本中:
|
||||||
|
|
||||||
```kotlin
|
```kotlin
|
||||||
repositories {
|
repositories {
|
||||||
mavenCentral()
|
mavenCentral()
|
||||||
|
@ -22,6 +25,7 @@ repositories {
|
||||||
```
|
```
|
||||||
|
|
||||||
添加 Logto Android SDK 依赖:
|
添加 Logto Android SDK 依赖:
|
||||||
|
|
||||||
<Tabs>
|
<Tabs>
|
||||||
|
|
||||||
<TabItem value="kotlin" label="Kotlin">
|
<TabItem value="kotlin" label="Kotlin">
|
||||||
|
@ -49,35 +53,13 @@ dependencies {
|
||||||
</Step>
|
</Step>
|
||||||
|
|
||||||
<Step
|
<Step
|
||||||
title="配置"
|
title="初始化 LogtoClient"
|
||||||
subtitle="Configure your application and LogtoClient"
|
subtitle="共 1 步"
|
||||||
index={1}
|
index={1}
|
||||||
activeIndex={props.activeStepIndex}
|
activeIndex={props.activeStepIndex}
|
||||||
onButtonClick={() => props.onNext(2)}
|
onButtonClick={() => props.onNext(2)}
|
||||||
>
|
>
|
||||||
|
|
||||||
### 配置 Redirect URI
|
|
||||||
|
|
||||||
Redirect URI 指定了应用用来接受授权结果的端口,Logto Android SDK 内部实现了该重定向的功能
|
|
||||||
|
|
||||||
### 在管理员控制台中配置 Redirect URI
|
|
||||||
|
|
||||||
将以下值添加到下面的 Redirect URI 输入框中:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
$(LOGTO_REDIRECT_SCHEME)://$(YOUR_APP_PACKAGE)/callback
|
|
||||||
```
|
|
||||||
|
|
||||||
注意:
|
|
||||||
- `LOGTO_REDIRECT_SCHEME` 应为自定义的反向域名格式的一串字符。
|
|
||||||
- 将上述的 `$(LOGTO_REDIRECT_SCHEME)` 替换成你定义的值。
|
|
||||||
|
|
||||||
例: `io.logto.android://io.logto.sample/callback`
|
|
||||||
|
|
||||||
<UriInputField appId={props.appId} isSingle={!props.isCompact} name="redirectUris" title="Redirect URI" />
|
|
||||||
|
|
||||||
### 配置 Logto Android SDK
|
|
||||||
|
|
||||||
<Tabs>
|
<Tabs>
|
||||||
|
|
||||||
<TabItem value="kotlin" label="Kotlin">
|
<TabItem value="kotlin" label="Kotlin">
|
||||||
|
@ -105,8 +87,9 @@ class MainActivity : AppCompatActivity() {
|
||||||
|
|
||||||
<TabItem value="java" label="Java">
|
<TabItem value="java" label="Java">
|
||||||
|
|
||||||
```java
|
<pre>
|
||||||
import io.logto.sdk.android.LogtoClient;
|
<code className="language-java">
|
||||||
|
{`import io.logto.sdk.android.LogtoClient;
|
||||||
import io.logto.sdk.android.type.LogtoConfig;
|
import io.logto.sdk.android.type.LogtoConfig;
|
||||||
|
|
||||||
public class MainActivity extends AppCompatActivity {
|
public class MainActivity extends AppCompatActivity {
|
||||||
|
@ -118,8 +101,8 @@ public class MainActivity extends AppCompatActivity {
|
||||||
setContentView(R.layout.activity_main);
|
setContentView(R.layout.activity_main);
|
||||||
|
|
||||||
LogtoConfig logtoConfig = new LogtoConfig(
|
LogtoConfig logtoConfig = new LogtoConfig(
|
||||||
"<your-logto-endpoint>",
|
"${props.endpoint}",
|
||||||
"<your-app-id>",
|
"${props.appId}",
|
||||||
null,
|
null,
|
||||||
null,
|
null,
|
||||||
true
|
true
|
||||||
|
@ -127,40 +110,39 @@ public class MainActivity extends AppCompatActivity {
|
||||||
|
|
||||||
logtoClient = new LogtoClient(logtoConfig, getApplication());
|
logtoClient = new LogtoClient(logtoConfig, getApplication());
|
||||||
}
|
}
|
||||||
}
|
}`}
|
||||||
```
|
</code>
|
||||||
|
</pre>
|
||||||
|
|
||||||
</TabItem>
|
</TabItem>
|
||||||
|
|
||||||
</Tabs>
|
</Tabs>
|
||||||
|
|
||||||
Notes:
|
|
||||||
|
|
||||||
- `<your-logto-endpoint>` 是你运行 Logto 服务所在的地址. 若你的 Logto 服务运行在 `http://localhost:300`,则 `<your-logto-endpoint` 为 `http://localhost:300`
|
|
||||||
- `<your-app-id>` 是你为自己的应用在管理员控制台中所创建的客户端ID.
|
|
||||||
|
|
||||||
</Step>
|
</Step>
|
||||||
|
|
||||||
<Step
|
<Step
|
||||||
title="登录"
|
title="登录"
|
||||||
subtitle="Sign In to your application by Logto and do some extra works"
|
subtitle="共 2 步"
|
||||||
index={2}
|
index={2}
|
||||||
activeIndex={props.activeStepIndex}
|
activeIndex={props.activeStepIndex}
|
||||||
onButtonClick={() => props.onNext(3)}
|
onButtonClick={() => props.onNext(3)}
|
||||||
>
|
>
|
||||||
|
|
||||||
### 执行登录
|
### 配置 Redirect URI
|
||||||
|
|
||||||
|
首先,我们来添加 Redirect URI。例如 `io.logto.android://io.logto.sample/callback`
|
||||||
|
|
||||||
|
<UriInputField appId={props.appId} isSingle={!props.isCompact} name="redirectUris" title="Redirect URI" />
|
||||||
|
|
||||||
|
返回你的 IDE 或编辑器,使用如下代码实现登录:
|
||||||
|
|
||||||
<Tabs>
|
<Tabs>
|
||||||
|
|
||||||
<TabItem value="kotlin" label="Kotlin">
|
<TabItem value="kotlin" label="Kotlin">
|
||||||
|
|
||||||
```kotlin
|
```kotlin
|
||||||
logtoClient.signInWithBrowser(
|
logtoClient.signIn(this, "<your-redirect-uri>") { logtoException: LogtoException? ->
|
||||||
this,
|
// 当 `logtoException` 为 null 时,则登录成功。
|
||||||
"io.logto.android://io.logto.sample/callback",
|
|
||||||
) { logtoException: LogtoException? ->
|
|
||||||
// 后续处理逻辑
|
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -169,54 +151,8 @@ logtoClient.signInWithBrowser(
|
||||||
<TabItem value="java" label="Java">
|
<TabItem value="java" label="Java">
|
||||||
|
|
||||||
```java
|
```java
|
||||||
logtoClient.signInWithBrowser(
|
logtoClient.signIn(this, "<your-redirect-uri>", logtoException -> {
|
||||||
this,
|
// 当 `logtoException` 为 null 时,则登录成功。
|
||||||
"io.logto.android://io.logto.sample/callback",
|
|
||||||
logtoException -> {
|
|
||||||
// 后续处理逻辑
|
|
||||||
}
|
|
||||||
);
|
|
||||||
```
|
|
||||||
|
|
||||||
</TabItem>
|
|
||||||
|
|
||||||
</Tabs>
|
|
||||||
|
|
||||||
### 登录成功后,你可以使用 SDK 提供的一些 API 来实现自己的业务逻辑
|
|
||||||
|
|
||||||
<Tabs>
|
|
||||||
|
|
||||||
<TabItem value="kotlin" label="Kotlin">
|
|
||||||
|
|
||||||
```kotlin
|
|
||||||
logtoClient.getAccessToken { logtoException: LogtoException?, result: AccessToken? ->
|
|
||||||
// 后续处理逻辑
|
|
||||||
}
|
|
||||||
|
|
||||||
logtoClient.getIdTokenClaims { logtoException: LogtoException?, result: IdTokenClaims? ->
|
|
||||||
// 后续处理逻辑
|
|
||||||
}
|
|
||||||
|
|
||||||
logtoClient.fetchUserInfo { logtoException: LogtoException?, userInfoResponse: UserInfoResponse? ->
|
|
||||||
// 后续处理逻辑
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
</TabItem>
|
|
||||||
|
|
||||||
<TabItem value="java" label="Java">
|
|
||||||
|
|
||||||
```java
|
|
||||||
logtoClient.getAccessToken((logtoException, accessToken) -> {
|
|
||||||
// 后续处理逻辑
|
|
||||||
});
|
|
||||||
|
|
||||||
logtoClient.getIdTokenClaims((logtoException, idTokenClaims) -> {
|
|
||||||
// 后续处理逻辑
|
|
||||||
});
|
|
||||||
|
|
||||||
logtoClient.fetchUserInfo((logtoException, userInfoResponse) -> {
|
|
||||||
// 后续处理逻辑
|
|
||||||
});
|
});
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -224,16 +160,19 @@ logtoClient.fetchUserInfo((logtoException, userInfoResponse) -> {
|
||||||
|
|
||||||
</Tabs>
|
</Tabs>
|
||||||
|
|
||||||
|
当成功登录后,`logtoClient.isAuthenticated` 的值将为 `true`。
|
||||||
|
|
||||||
</Step>
|
</Step>
|
||||||
|
|
||||||
<Step
|
<Step
|
||||||
title="登出"
|
title="退出登录"
|
||||||
|
subtitle="共 1 步"
|
||||||
index={3}
|
index={3}
|
||||||
activeIndex={props.activeStepIndex}
|
activeIndex={props.activeStepIndex}
|
||||||
onButtonClick={() => props.onNext(4)}
|
onButtonClick={() => props.onNext(4)}
|
||||||
>
|
>
|
||||||
|
|
||||||
### 执行登出
|
调用 `.signOut(completion)` 操作会清除本地存储的用户相关凭据,即使在退出登录过程中发生了异常。
|
||||||
|
|
||||||
<Tabs>
|
<Tabs>
|
||||||
|
|
||||||
|
@ -241,7 +180,7 @@ logtoClient.fetchUserInfo((logtoException, userInfoResponse) -> {
|
||||||
|
|
||||||
```kotlin
|
```kotlin
|
||||||
logtoClient.signOut { logtoException: LogtoException? ->
|
logtoClient.signOut { logtoException: LogtoException? ->
|
||||||
// 后续处理逻辑
|
// 无论是否存在 `logtoException`,本地存储的用户相关凭据都已清除。
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -251,7 +190,7 @@ logtoClient.signOut { logtoException: LogtoException? ->
|
||||||
|
|
||||||
```java
|
```java
|
||||||
logtoClient.signOut(logtoException -> {
|
logtoClient.signOut(logtoException -> {
|
||||||
// 后续处理逻辑
|
// 无论是否存在 `logtoException`,本地存储的用户相关凭据都已清除。
|
||||||
});
|
});
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -259,15 +198,11 @@ logtoClient.signOut(logtoException -> {
|
||||||
|
|
||||||
</Tabs>
|
</Tabs>
|
||||||
|
|
||||||
注意:
|
|
||||||
|
|
||||||
- 登出操作会清除本地存储的用户相关凭据,即使在登出过程中发生了异常。
|
|
||||||
|
|
||||||
</Step>
|
</Step>
|
||||||
|
|
||||||
<Step
|
<Step
|
||||||
title="延伸阅读"
|
title="延展阅读"
|
||||||
subtitle="3 steps"
|
subtitle="共 4 篇"
|
||||||
index={4}
|
index={4}
|
||||||
activeIndex={props.activeStepIndex}
|
activeIndex={props.activeStepIndex}
|
||||||
buttonText="admin_console.general.done"
|
buttonText="admin_console.general.done"
|
||||||
|
@ -275,8 +210,9 @@ logtoClient.signOut(logtoException -> {
|
||||||
onButtonClick={props.onComplete}
|
onButtonClick={props.onComplete}
|
||||||
>
|
>
|
||||||
|
|
||||||
- 获取用户信息
|
- [自定义登录体验](https://docs.logto.io/zh-cn/docs/recipes/customize-sie)
|
||||||
- 配置社会化登录
|
- [启用短信或邮件验证码登录](https://docs.logto.io/zh-cn/docs/tutorials/get-started/enable-passcode-sign-in)
|
||||||
- 访问受保护的 API 资源
|
- [启用社交登录](https://docs.logto.io/zh-cn/docs/tutorials/get-started/enable-social-sign-in)
|
||||||
|
- [保护你的 API](https://docs.logto.io/zh-cn/docs/recipes/protect-your-api)
|
||||||
|
|
||||||
</Step>
|
</Step>
|
||||||
|
|
|
@ -113,7 +113,7 @@ const translation = {
|
||||||
subtitle:
|
subtitle:
|
||||||
'Now follow the steps below to finish your app settings. Please select the SDK type to continue.',
|
'Now follow the steps below to finish your app settings. Please select the SDK type to continue.',
|
||||||
description_by_sdk:
|
description_by_sdk:
|
||||||
'This quick start guide demonstrates how to integrate Logto to {{sdk}} application',
|
'This quick start guide demonstrates how to integrate Logto into {{sdk}} app',
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
application_details: {
|
application_details: {
|
||||||
|
|
Loading…
Reference in a new issue