Authing 知识库
🛠 开发资源🥂 集成案例🔭 常见问题🖥 控制台
1.0.0
1.0.0
  • 欢迎
  • Authing 概述
  • 快速开始
    • 第一个应用
    • 基础概念
    • 实现单点登录
    • 控制台概览
    • 部署模型
  • 进阶指南
    • 理解认证和授权
      • 用户名 - 密码认证
      • 邮箱 - 密码认证
      • 手机 - 验证码认证
      • JWT Token 释义及使用
      • 验证 JWT Token
    • 配置用户权限
    • 最佳开发实践
    • 接入小程序扫码登录
      • 接入私有化小程序
    • 接入社会化登录
    • 接入 OAuth 2.0
      • 创建 OAuth 应用
      • 使用 OAuth 授权
    • 接入 OpenID Connect
      • 创建 OIDC 应用
      • 使用 OIDC 授权
      • 理解 OIDC 流程
      • OIDC 常见问题
    • 配置 LDAP 服务
    • 使用 Authing 的 LDAP 用户目录
    • 接入 SAML
      • 创建 SAML Identity Provider 应用
      • 创建 SAML Service Provider 应用
      • 理解 SAML 流程
      • 同时使用 Authing 作为 SP 和 IdP
      • 使用 SAML Identity Provider
        • 在阿里云访问管理中使用
        • 在腾讯云访问管理中使用
        • 在 Auth0 中使用
      • 使用 SAML Service Provider
        • 与 Auth0 SAML IdP 对接
        • 与 SSOCircle SAML IdP 对接
    • 使用 Webhook
    • 错误代码
  • 开发资源
    • 开发资源
    • API(GraphQL)
    • Guard for Web
    • Guard VS 自定义 UI
    • SDK for Web
      • 读取/修改用户权限
      • 绑定社会化登录
      • 管理 MFA 口令
      • 自定义请求链接
    • SDK for 微信小程序
    • SDK for Java
    • SDK for Objective-C
    • SDK for Python
    • SDK for Go
    • SDK for PHP
    • 函数计算(FaaS)
  • 通信
    • 邮件
    • SMS
  • MFA
    • 配置 MFA 安全口令
    • 接入 MFA
  • 安全
    • 配置 Web 安全域
    • 配置用户池密码强度
    • 配置密码加密函数
  • 其他
    • 常见问题
    • 集成案例
      • 使用 Authing 补充 AWS 中国区 Cognito User Pool
    • 社交互联数据
      • Authing 与社交互联数据
    • 为 Authing 贡献 SDK
      • 了解 Authing 的模块
Powered by GitBook
On this page
  • 安装
  • maven
  • gradle
  • Android 注意
  • 快速上手
  • SDK 简介
  • 提供服务
  • 业务封装
  • 灵活调用
  • SDK 详细介绍
  • 用户服务
  • 授权服务
  • 验证服务
  • 用户管理服务
  • 错误处理

Was this helpful?

  1. 开发资源

SDK for Java

PreviousSDK for 微信小程序NextSDK for Objective-C

Last updated 5 years ago

Was this helpful?

Authing SDK for Java 编写于 JDK 1.8

Github 地址:。

安装

maven

<dependency>
	<groupId>cn.authing</groupId>
	<artifactId>java-core</artifactId>
	<version>0.5.0</version>
	<type>pom</type>
</dependency>

gradle

impelementation 'cn.authing:java-core:0.5.0'

Android 注意

如果用于 Android 开发,需要在 AndroidManifest 文件中加入 INTERNET 权限。

<uses-permission android:name="android.permission.INTERNET"/>

快速上手

// 初始化
Authing.init(cliendId, secret)

// 注册用户,异步调用
val registerParam: RegisterParam = RegisterParam.Builder(email, psd).nickname(nickname).build()
Authing.getUserService().register(registerParam).enqueue(object: Callback<RegisterResult>{
    override fun onSuccess(result: RegisterResult?) {
        TODO("not implemented") //To change body of created functions use File | Settings | File Templates.
    }

    override fun onFailure(error: ErrorInfo?) {
        TODO("not implemented") //To change body of created functions use File | Settings | File Templates.
    }
})

// 使用邮箱登陆,同步调用
val loginParam: LoginByEmailParam = LoginByEmailParam.Builder(email, psd).build()
val result: LoginResult? = Authing.getUserService().loginByEmail(loginParam).execute()

SDK 简介

提供服务

Authing SDK 提供了授权服务 (OAuthService)、用户服务 (UserService)、用户管理服务 (UserManageService) 和验证服务 (VerifyService),你可以直接通过 Authing.getXxxService 获取。

业务封装

每种服务中封装了相关的业务,规定了参数和返回值。 由于参数众多且参数可选,所以参数采用了 Builder 模式,且不能使用构造方法。例如:

// 使用手机号和验证码登陆的参数
LoginByPhoneParam.Builder(phone, code).build()

// 使用用户 ID 获取用户信息参数
UserInfoParam.Builder(userId).build()

返回值都是简单的 Bean,提供了 get 方法,没有业务逻辑,供业务层自行处理。

灵活调用

SDK 提供了同步和异步两种调用方式,适用不同的场景。 若需要等待返回结果处理后面的数据,比较适合同步调用,例如:

// 获取用户信息
val userInfoParam: UserInfoParam = UserInfoParam.Builder(userId).build()
val info: UserInfoResult = Authing.getUserService().getUserInfo(userInfoParam).execute()
// 获取用户昵称
info.nickname
// 获取用户头像
info.photo

如果是在 Android 的主线程中,则需使用异步调用(当然你也可以在子线程中使用同步调用),例如:

// 重置密码
val resetPsdParam = ResetPasswordParam.Builder(email, newPsd, code).build()
Authing.getUserService().resetPassword(resetPsdParam).enqueue(object :Callback<UserInfoResult>{
    override fun onSuccess(result: UserInfoResult?) {
        TODO("not implemented") //To change body of created functions use File | Settings | File Templates.
  }

    override fun onFailure(error: ErrorInfo?) {
        TODO("not implemented") //To change body of created functions use File | Settings | File Templates.
  }
})

SDK 详细介绍

用户服务

UserService service = Authing.getUserService();
// 注册
service.register(param).xxx();
// 邮箱登陆
service.loginByEmail(param).xxx();
// 手机验证码登陆
service.loginByPhone(param).xxx();
// LDAP 登陆
service.loginByLDAP(param).xxx();
// 获取用户信息
service.getUserInfo(aram).xxx();
// 更新用户信息
service.updateUserInfo(param).xxx();
// 重置密码
service.resetPassword(param).xxx();

授权服务

OAuthService service = Authing.getOAuthService();
// 解绑邮箱
service.unbindEmail(param).xxx();
// 刷新用户 token
service.refreshToken(param).xxx();
// 读取授权列表
service.readOAuthList(param).xxx();

验证服务

VerifyService service = Authing.getVerifyService();
// 发送验证邮箱的邮件
service.sendVerifyEmail(param).xxx();
// 发送手机验证码
service.sendPhoneVerifyCode(param).xxx();
// 发送重置密码邮件
service.sendResetPasswordEmail(param).xxx();
// 验证重置密码的验证码
service.verifyResetPasswordCode(param).xxx();

用户管理服务

UserManageService service = Authing.getUserManageService();
// 批量获取用户信息
service.getUserInfo(param).xxx();
// 获取用户列表
service.getUserList(param).xxx();
// 删除用户
service.removeUser(param).xxx();

错误处理

先从 中 ,然后调用初始化函数。初始化调用一次即可,在 Android 开发中,推荐放在 Application 中进行初始化。

完整的使用案例请参考:

同步调用不会返回错误,所以推荐使用异步调用。 在 onFailure 中会返回错误,你可以通过 error.getCode() 获取错误代码。了解更多报错的详情,请查看。

https://github.com/Authing/authing-java-sdk
Authing 控制台
获取 Client ID
https://github.com/Authing/authing-java-sdk/tree/master/testdemo
错误代码列表