Authing DocsDocuments
Concept
workflow
Guides
Development Integration
Application integration
Concept
workflow
Guides
Development Integration
Application integration
Old Version
Guides
  • Quick start

  • Authenticate the user

    • Use account password authentication
    • Use SMS verification code authentication
    • Use social login authentication
    • Use scan code login authentication

    • Certify in Mini Program
    • Implement single sign-on (SSO)
    • Single sign-on on the mobile terminal
    • Multi-factor authentication (MFA)

      • MFA of one-time password (TOTP) based on timestamp algorithm
      • MFA based on SMS verification code
      • MFA based on email verification code
      • Access MFA through SDK
    • Extend the authentication process

    • Personalize the guard
  • Authority management for users

  • Authorization

  • Manage user accounts

  • Manage User Directory

  • Management Application

  • Become a source of federal authentication identity

  • Connect to an external identity provider (IdP)

  • Open up WeChat ecology
  • Migrate users to Authing

  • Management organization

  • Expandable capabilities

  • Audit Log

  • Configure security information

  • Configure user pool information

  • Deployment plan

  • Frequently Asked Questions FAQs

  1. Guides
  2. /
  3. Authenticate the user
  4. /
  5. Multi-factor authentication (MFA)
  6. /
  7. Access MFA through SDK

¶ Configure MFA through SDK

Update Time: 2025-05-14 08:32:28
Edit

¶ Overview

Authing can not only configure the MFA authentication process through the console, but you can also config the MFA authentication through the SDK.

This article will take Authing - Node/JavaScript SDK as an example to guide developers to complete SDK-based MFA custom development. This includes: binding MFA authenticator, unbinding MFA authenticator, user secondary authentication, etc.

¶ Prerequisites

  1. Register a new Authing Account
  2. Complete the creation of the user pool and application

¶ Multi-Factor Authentication (MFA) API

¶ Query the MFA information opened by the user

GET
https://core.authing.cn/api/v2/mfa/authenticator

Query the MFA information opened by the user

Return the MFA information opened by the user

Headers
x-authing-userpool-id
REQUIRED
string

User Pool ID

Authorization
REQUIRED
string

Bearer <User Token>

Query Parameters
authenticator_type
REQUIRED
string

Enter totp

200: OK
{
  "code": 200,
  "message": "Obtain MFA Authenticator Successfully",
  "data": [
    {
      "id": "5f8eea9b018e1407d2ce7975",
      "createdAt": "2020-10-20T13:48:11.288Z",
      "updatedAt": "2020-10-20T13:48:11.288Z",
      "userId": "5cce4a373ed9f9c9c0fd9596",
      "enable": false,
      "secret": "DMDCO7SNNVGU2VKJ",
      "authenticatorType": "totp",
      "recoveryCode": "10af-4f2f-f34f-f224-d21c-bd16"
    }
  ]
}

If MFA is not Enabled, return:
{
  "code": 200,
  "message": "Obtain MFA Authenticator Successfully",
  "data": []
}

¶ Request to bind MFA password

POST
https://core.authing.cn/api/v2/mfa/totp/associate

Obtain the MFA QR code and Secret information for display, and wait for the user to confirm the binding

After requesting this endpoint, the MFA secondary authentication will not take effect before the user confirms the binding. The endpoint returns MFA Secret, MFA Uri, MFA QR code Data Url, and recovery code.

Headers
x-authing-userpool-id
REQUIRED
string

User Pool ID

Authorization
REQUIRED
string

Bearer <User Token>

Body Paramter
authenticator_type
REQUIRED
string

Enter totp

200: OK
{
  "code": 200,
  "message": "Successfully obtained MFA key",
  "data": {
    "authenticator_type": "totp",
    "secret": "JAPDSOAZLV4BG3RA", // MFA Secret can be used to manually add MFA
    "qrcode_uri": "otpauth://totp/playground:getstarted%40{{$themeConfig.officeSiteDomain}}?secret=JAPDSOAZLV4BG3RA&period=30&digits=6&algorithm=SHA1&issuer=playground", // MFA Uri,can be used to manually add MFA
    // MFA QR Code Data Url,can be placed in <img> src to display QR Code.
    "qrcode_data_url": "",
    // Recovery Code
    "recovery_code": "8477-a1a6-662c-a750-bbb4-72a9"
  }
}

¶ Confirm binding MFA password

POST
https://core.authing.cn/api/v2/mfa/totp/associate/confirm

Confirm binding MFA

After requesting this endpoint, the user confirms the binding of MFA, and then logs in and asks to enter the MFA password for secondary verification.

Headers
x-authing-userpool-id
REQUIRED
string

User Pool ID

Authorization
REQUIRED
string

Bearer <User Token>

Body Paramter
authenticator_type
REQUIRED
string

Enter totp

totp
REQUIRED
string

MFA Password

200: OK

Bind Successfully

{ "code": 200, "message": "TOTP MFA Bind Successfully" }
400: Bad Request

Bind failed

{ "code": 400, "message": "Incorrent security code, please enter again" }

¶ Return MFA Token after first authentication

Call the login method in authing-js-sdk, refer to[Login](/sdk/sdk-for-javascript/README.md#Sign in). Or call [GraphQL Interface](/sdk/open-graphql.md#Sign in). You need store mfaToken for future use.

Call the SDK:

try {
  window.user = await window.authing.login({ email, password });
  alert(`Login successfully, information:${JSON.stringify(window.user)}`);
} catch (err) {
  if (err.message.code === 1635) {
    console.log(err.message.data.email);
    console.log(err.message.data.nickname);
    console.log(err.message.data.username);
    console.log(err.message.data.avatar);
    console.log(err.message.data.mfaToken);
    window.mfaToken = err.message.data.mfaToken;
  }
  alert(err.message.message);
}

The return information of calling the GraphQL interface:

{
  "errors": [
    {
      "message": {
        "code": 1635,
        "message": "Please enter Secondary Authentication Code",
        "data": {
          "mfaToken": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJkYXRhIjp7InVzZXJQb29sSWQiOiI1Y2NlNGFhODNlZDlmOTdiNGRmZDk1ZjAiLCJ1c2VySWQiOiI1ZjhlZTYyY2FmYzJmZmFkMzY0MzQ1YjciLCJhcm4iOiJhcm46Y246YXV0aGluZzo1Y2NlNGFhODNlZDlmOTdiNGRmZDk1ZjA6dXNlcjo1ZjhlZTYyY2FmYzJmZmFkMzY0MzQ1YjciLCJzdGFnZSI6MX0sImlhdCI6MTYwMzIwNjcwOCwiZXhwIjoxNjAzMjA3MDY4fQ.PR7LXqpyH--6sF4eAcOcK1yZBi14lRv_lr9qUtbTQM4",
          "nickname": null,
          "email": "q3@123.com",
          "username": null,
          "avatar": "https://usercontents.{{$themeConfig.officeSiteDomain}}/authing-avatar.png"
        }
      },
      "locations": [{ "line": 2, "column": 9 }],
      "path": ["login"],
      "extensions": { "code": "INTERNAL_SERVER_ERROR" }
    }
  ],
  "data": { "login": null }
}

¶ Login to verify MFA password

POST
https://core.authing.cn/api/v2/mfa/totp/verify

It is used to check whether the password for the second authentication is correct after the first authentication is successful during login.

For users who enable secondary authentication, an mfaToken will be returned after the first authentication is successful, and the mfaToken needs to be carried to request this endpoint to complete the secondary authentication

Headers
x-authing-userpool-id
REQUIRED
string

User Pool ID

Authorization
REQUIRED
string

Bearer <User Token>

Body Paramter
totp
REQUIRED
string

MFA Password

200: OK

登录成功

{
  "code": 200,
  "message": "二次验证成功",
  "data": {
    "id": "5f8ee62cafc2ffad364345b7",
    "createdAt": "2020-10-20T13:29:16.896Z",
    "updatedAt": "2020-10-20T14:54:07.301Z",
    "userPoolId": "5cce4aa83ed9f97b4dfd95f0",
    "isRoot": false,
    "oauth": null,
    "email": "q3@123.com",
    "phone": null,
    "username": null,
    "unionid": null,
    "openid": null,
    "nickname": null,
    "company": null,
    "photo": "https://usercontents.{{$themeConfig.officeSiteDomain}}/authing-avatar.png",
    "browser": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/86.0.4240.80 Safari/537.36",
    "device": null,
    "password": "76847018c664261747924735403ee0a5",
    "salt": "20k8b1318gie",
    "token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJkYXRhIjp7InVzZXJQb29sSWQiOiI1Y2NlNGFhODNlZDlmOTdiNGRmZDk1ZjAiLCJhcHBJZCI6bnVsbCwidXNlcklkIjoiNWY4ZWU2MmNhZmMyZmZhZDM2NDM0NWI3IiwiYXJuIjoiYXJuOmNuOmF1dGhpbmc6NWNjZTRhYTgzZWQ5Zjk3YjRkZmQ5NWYwOnVzZXI6NWY4ZWU2MmNhZmMyZmZhZDM2NDM0NWI3IiwiaWQiOiI1ZjhlZTYyY2FmYzJmZmFkMzY0MzQ1YjciLCJfaWQiOiI1ZjhlZTYyY2FmYzJmZmFkMzY0MzQ1YjciLCJwaG9uZSI6bnVsbCwiZW1haWwiOiJxM0AxMjMuY29tIiwidXNlcm5hbWUiOm51bGwsInVuaW9uaWQiOm51bGwsIm9wZW5pZCI6bnVsbH0sImlhdCI6MTYwMzIwNTY0NywiZXhwIjoxNjA0NTAxNjQ3fQ.U1NmmdOydZ-D_yzhQizpZ--Z5hgzSlZbWxKn3e7BYDQ",
    "tokenExpiredAt": "2020-11-04T14:54:07.287Z",
    "loginsCount": 24,
    "lastIp": "124.204.56.98",
    "name": null,
    "givenName": null,
    "familyName": null,
    "middleName": null,
    "profile": null,
    "preferredUsername": null,
    "website": null,
    "gender": "U",
    "birthdate": null,
    "zoneinfo": null,
    "locale": null,
    "address": null,
    "formatted": null,
    "streetAddress": null,
    "locality": null,
    "region": null,
    "postalCode": null,
    "city": null,
    "province": null,
    "country": null,
    "registerSource": ["basic:email"],
    "emailVerified": false,
    "phoneVerified": false,
    "lastLogin": "2020-10-20T14:54:07.298Z",
    "blocked": false,
    "isDeleted": false,
    "sendSmsCount": 0,
    "sendSmsLimitCount": 1000,
    "identities": []
  }
}
200: OK

口令错误

{ "code": 6001, "message": "安全码错误,请重新输入" }

¶ Use Recovery Code

POST
https://core.authing.cn/api/v2/mfa/totp/recovery

It is used to restore account access when the user loses the MFA password after a successful login.

If the user enables the secondary authentication and loses the MFA password, a recovery code is required to restore access to the account. Using the recovery code is equivalent to using the MFA password, and a new recovery code will be generated for the user. The user can unbind the MFA and re-bind the new MFA after logging in.

Headers
x-authing-userpool-id
REQUIRED
string

User Pool ID

Authorization
REQUIRED
string

Bearer <User Token>

Body Paramter
recoveryCode
REQUIRED
string

Recovery code, which is returned when Binding MFA password

200: OK
登录成功
{
    "code": 200,
    "message": "二次验证成功",
    "data": {
        "id": "5f8ee62cafc2ffad364345b7",
        "createdAt": "2020-10-20T13:29:16.896Z",
        "updatedAt": "2020-10-20T14:54:07.301Z",
        "userPoolId": "5cce4aa83ed9f97b4dfd95f0",
        "isRoot": false,
        "oauth": null,
        "email": "q3@123.com",
        "phone": null,
        "username": null,
        "unionid": null,
        "openid": null,
        "nickname": null,
        "company": null,
        "photo": "https://usercontents.{{$themeConfig.officeSiteDomain}}/authing-avatar.png",
        "browser": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/86.0.4240.80 Safari/537.36",
        "device": null,
        "password": "76847018c664261747924735403ee0a5",
        "salt": "20k8b1318gie",
        "token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJkYXRhIjp7InVzZXJQb29sSWQiOiI1Y2NlNGFhODNlZDlmOTdiNGRmZDk1ZjAiLCJhcHBJZCI6bnVsbCwidXNlcklkIjoiNWY4ZWU2MmNhZmMyZmZhZDM2NDM0NWI3IiwiYXJuIjoiYXJuOmNuOmF1dGhpbmc6NWNjZTRhYTgzZWQ5Zjk3YjRkZmQ5NWYwOnVzZXI6NWY4ZWU2MmNhZmMyZmZhZDM2NDM0NWI3IiwiaWQiOiI1ZjhlZTYyY2FmYzJmZmFkMzY0MzQ1YjciLCJfaWQiOiI1ZjhlZTYyY2FmYzJmZmFkMzY0MzQ1YjciLCJwaG9uZSI6bnVsbCwiZW1haWwiOiJxM0AxMjMuY29tIiwidXNlcm5hbWUiOm51bGwsInVuaW9uaWQiOm51bGwsIm9wZW5pZCI6bnVsbH0sImlhdCI6MTYwMzIwNTY0NywiZXhwIjoxNjA0NTAxNjQ3fQ.U1NmmdOydZ-D_yzhQizpZ--Z5hgzSlZbWxKn3e7BYDQ",
        "tokenExpiredAt": "2020-11-04T14:54:07.287Z",
        "loginsCount": 24,
        "lastIp": "124.204.56.98",
        "name": null,
        "givenName": null,
        "familyName": null,
        "middleName": null,
        "profile": null,
        "preferredUsername": null,
        "website": null,
        "gender": "U",
        "birthdate": null,
        "zoneinfo": null,
        "locale": null,
        "address": null,
        "formatted": null,
        "streetAddress": null,
        "locality": null,
        "region": null,
        "postalCode": null,
        "city": null,
        "province": null,
        "country": null,
        "registerSource": [
            "basic:email"
        ],
        "emailVerified": false,
        "phoneVerified": false,
        "lastLogin": "2020-10-20T14:54:07.298Z",
        "blocked": false,
        "isDeleted": false,
        "sendSmsCount": 0,
        "sendSmsLimitCount": 1000,
        "identities": []
    },
    "recoveryCode": "9225-be3f-4646-fa3a-7a32-a098"
}

口令错误
{"code":6002,"message":"恢复代码错误,请重新输入"}

¶ Operation

Open index.html

Or start a http Server in the project directory

$ npm install -g http-server
$ http-server

Go to 127.0.0.1:8080

You can refer to MFA demo provided by Authing MFA Demo (opens new window)

¶ Multi-Factor Authentication (MFA) SDK

¶ Request to bind MFA authenticator:

import { AuthenticationClient } from "authing-js-sdk";

const authenticationClient = new AuthenticationClient({
  appId: "AUTHING_APP_ID",
  appHost: "https://xxx.authing.cn"
});

await authenticationClient.mfa.assosicateMfaAuthenticator({
  authenticatorType: "totp"
});

¶ Verify MFA secondary password:

import { AuthenticationClient } from "authing-js-sdk";

const authenticationClient = new AuthenticationClient({
  appId: "AUTHING_APP_ID",
  appHost: "https://xxx.authing.cn"
});

await authenticationClient.mfa.verifyTotpMfa({
  totp: "112233",
  mfaToken: "xxx"
});

¶ Request an MFA authenticator

MfaAuthenticationClient().getMfaAuthenticators()

Request an MFA authenticator

¶ Sample

const authenticationClient = new AuthenticationClient({
  appId: "AUTHING_APP_ID",
  appHost: "https://xxx.authing.cn"
});

const authenticators = await authenticationClient.mfa.getMfaAuthenticators({
  type: "totp"
});

¶ Return Value

  • Promise<IMfaAuthenticators>

¶ Request MFA QR code and key

MfaAuthenticationClient().assosicateMfaAuthenticator()

Request MFA QR code and key

¶ Sample

const authenticationClient = new AuthenticationClient({
  appId: "AUTHING_APP_ID",
  appHost: "https://xxx.authing.cn"
});

const authenticators = await authenticationClient.mfa.assosicateMfaAuthenticator(
  { authenticatorType: "totp" }
);

¶ Return Value

  • Promise<IMfaAssociation>

¶ Disable MFA

MfaAuthenticationClient().deleteMfaAuthenticator()

Disable MFA

¶ Sample

const authenticationClient = new AuthenticationClient({
  appId: "AUTHING_APP_ID",
  appHost: "https://xxx.authing.cn"
});

const authenticators = await authenticationClient.mfa.deleteMfaAuthenticator();

¶ Return Value

  • Promise<IMfaDeleteAssociation>

¶ Confirm binding MFA

MfaAuthenticationClient().confirmAssosicateMfaAuthenticator()

Confirm binding MFA

¶ Sample

const authenticationClient = new AuthenticationClient({
  appId: "AUTHING_APP_ID",
  appHost: "https://xxx.authing.cn"
});

const authenticators = await authenticationClient.mfa.confirmAssosicateMfaAuthenticator(
  { authenticatorType: "totp", totp: "112233" }
);

¶ Return Value

  • Promise<IMfaConfirmAssociation>

¶ Verify the MFA password for the second verification

MfaAuthenticationClient().verifyTotpMfa()

Verify the MFA password for the second verification

¶ Sample

const authenticationClient = new AuthenticationClient({
  appId: "AUTHING_APP_ID",
  appHost: "https://xxx.authing.cn"
});

const authenticators = await authenticationClient.mfa.verifyTotpMfa({
  authenticatorType: "totp",
  totp: "112233"
});

¶ Return Value

  • Promise<User>

¶ Verify secondary verification MFA SMS verification code

MfaAuthenticationClient().verifyAppSmsMfa()

Verify secondary verification MFA SMS verification code

¶ Reference

  • options <Object>
  • options.phone <string> Phone number
  • options.code <string> SMS code
  • options.mfaToken <string> MfaToken returned by the login endpoint

¶ Sample

const authenticationClient = new AuthenticationClient({
  appId: "AUTHING_APP_ID",
  appHost: "https://xxx.authing.cn"
});

const authenticators = await authenticationClient.mfa.verifySmsMfa({
  mfaToken: "xxxxxx",
  phone: "188xxxx8888",
  code: "xxxx"
});

¶ Return Value

  • Promise<User>

¶ Verify secondary verification MFA email verification code

MfaAuthenticationClient().verifyAppEmailMfa()

Verify secondary verification MFA email verification code

¶ Reference

  • options <Object>
  • options.email <string> Email
  • options.code <string> SMS code
  • options.mfaToken <string> MfaToken returned by the login endpoint

¶ Sample

const authenticationClient = new AuthenticationClient({
  appId: "AUTHING_APP_ID",
  appHost: "https://xxx.authing.cn"
});

const authenticators = await authenticationClient.mfa.verifyAppEmailMfa({
  mfaToken: "xxxxxx",
  email: "example@{{$themeConfig.officeSiteDomain}}",
  code: "xxxx"
});

¶ Return Value

  • Promise<User>

¶ Check whether the phone number or email has been bound

MfaAuthenticationClient().phoneOrEmailBindable()

When the phone number or email MFA login is required, and the user has not bound the phone number or email, the user can first enter the phone number or email address, use this endpoint to first check whether the mobile phone or email address can be bound, and then perform MFA.

¶ Reference

  • options <Object>
  • [options.email] <string> Email to be checked
  • [options.phone] <string> Phone number to be checked
  • options.mfaToken <string> MfaToken returned by the login endpoint

¶ Sample

const authenticationClient = new AuthenticationClient({
  appId: "AUTHING_APP_ID",
  appHost: "https://xxx.authing.cn"
});

const authenticators = await authenticationClient.mfa.phoneOrEmailBindable({
  mfaToken: "xxxxxx",
  email: "example@{{$themeConfig.officeSiteDomain}}"
});

¶ Return Value

  • Promise<boolean>

¶ Verify the second verification MFA recovery code

MfaAuthenticationClient().verifyTotpRecoveryCode()

Verify the second verification MFA recovery code

¶ Sample

const authenticationClient = new AuthenticationClient({
  appId: "AUTHING_APP_ID",
  appHost: "https://xxx.authing.cn"
});

const authenticators = await authenticationClient.mfa.verifyTotpRecoveryCode({
  authenticatorType: "totp",
  totp: "112233"
});

¶ Return Value

  • Promise<User>
Prev: MFA based on email verification code Next: Extend the authentication process
  • Overview
  • Prerequisites
  • Multi-Factor Authentication (MFA) API
  • Operation
  • Multi-Factor Authentication (MFA) SDK
  • Request to bind MFA authenticator:
  • Verify MFA secondary password:
  • Request an MFA authenticator
  • Request MFA QR code and key
  • Disable MFA
  • Confirm binding MFA
  • Verify the MFA password for the second verification
  • Verify secondary verification MFA SMS verification code
  • Verify secondary verification MFA email verification code
  • Check whether the phone number or email has been bound
  • Verify the second verification MFA recovery code

User identity management

Integrated third-party login
Mobile phone number flash check (opens new window)
Universal login form component
Custom authentication process

Enterprise internal management

Single Sign On
Multi-factor Authentication
Authority Management

Developers

Development Document
Framework Integration
Blog (opens new window)
GitHub (opens new window)
Community User Center (opens new window)

Company

400 888 2106
sales@authing.cn
16 / F, Block B, NORTH STAR CENTURY CENTER, Beijing(Total)
room 406, 4th floor, zone B, building 1, No. 200, Tianfu Fifth Street, Chengdu(branch)

Beijing ICP No.19051205-1

© Beijing Steamory Technology Co.