【まとめ共有】もう迷わない、よく使われるフロントエンドとバックエンドの認証方法10選

青灯夜游
リリース: 2022-08-23 20:08:53
転載
8361 人が閲覧しました

フロントエンド認証に関して、トークン、Cookie、セッション、JWT、シングル サインオン、スキャン コード ログイン、およびワンクリック ログインは何を意味しますか?それぞれの機能は何ですか?普段はどうやってやってるの?そして、どうやって保管しますか?では、どうやって安全に保管するのでしょうか?次の記事では、混乱しないように、フロントエンドとバックエンドですべての認証スキームを処理する方法を説明します。

面接中、面接官がフロントエンド認証に関して、トークン、Cookie、セッション、JWT、シングル サインオン とは何ですか?と質問したことを今でも覚えています。効果は何ですか?普段はどうやってやってるの?そして、どうやって保管しますか?では、it の安全をどのように確保するのでしょうか?

一連の質問の後、私はとても不安で圧倒され、話すことができませんでした...

実際には、次のような認証方法がたくさんあります。一般的に使用される 10 個の認証方法をまとめました。あなたのシステムにはどれが最適ですか?どれが一番安全ですか? それでは、次の内容からゆっくりと答えを見つけていきましょう ~

この記事を通じて何を学ぶことができますか?

【まとめ共有】もう迷わない、よく使われるフロントエンドとバックエンドの認証方法10選認証方法を紹介する前に、まず次のことを理解する必要があります:

認証、認可、認証、権限制御とは

そしてそれらを次のように扱います。基礎があれば、それらの間の関係を最初から最後まで完全に理解できます~

認定とは何ですか?

認証 (識別)

とは、宣言者の固有の識別情報に基づいて宣言者の身元を確認することを指します。 この言葉の意味は次のとおりです。

あなたは自分であることを証明するために ID カードを使用する必要があります

例: 当社の一般的な認証テクノロジー:

ID カード
  • ユーザー名とパスワード
  • ユーザーの携帯電話: 携帯電話のテキスト メッセージ、携帯電話の QR コード スキャン、ジェスチャー パスワード
  • ユーザーの電子メール アドレス
  • ユーザーの生物学的特徴: 指紋、音声、目の虹彩
  • ユーザーのビッグ データ識別
認可とは何ですか?

承認

: 情報セキュリティの分野では、 リソース所有者 を委任し、 実行者 に実行を与えることを指します。または は、リソースに対する関連操作を容易にするために、リソース操作権限の範囲を指定します。 実生活の分野では、たとえば:

銀行カード (銀行から配布)、アクセス カード (不動産管理事務所から配布)、鍵 (家主から配布)、これらはすべて、実際の実装方法で承認されています。

インターネット分野では、たとえば次のようになります。

Web サーバーのセッション メカニズム、Web ブラウザの Cookie メカニズム、および認可トークン (トークン) の発行はすべて認可メカニズムです。

認証とは何ですか?

Authentication(認証)

情報セキュリティの分野では、宣言者によって宣言されたアイデンティティ権の信頼性を

識別および確認することを指します。 。 認可から始めると認証が理解しやすくなります。認可と認証は、上流と下流の 2 つの関係が一致しています。最初に認可、次に認証

実生活の分野: アクセス コントロール カードはアクセス カード ID を渡す必要があり、銀行カードは銀行カード ID を渡す必要があります。

インターネット フィールド: session/cookie/token の合法性と有効性を確認します

Authentication は、前と次の間のリンクです。アップストリームは承認された出力を受け入れます。 、その信頼性を検証し、次にアクセス許可を取得します。これにより、アクセス許可制御の次のステップの準備が整います。

権限制御とは何ですか?

権限制御(アクセス/権限制御) 実行可能な操作を権限リストとして定義し、操作の許可/禁止を決定します

権限制御の場合, これは 2 つの部分で理解できます。1 つはアクセス許可、もう 1 つはコントロールです。許可は抽象的な論理概念ですが、制御は具体的な実装方法です。

実生活の分野:

アクセス コントロール カード権限の実装を例に挙げます。アクセス コントロール カードには、社内のすべてのドアを開ける権限があります。アクセス コントロール カードは、管理者ロールの権限を持っているので、社内のすべてのドアを開けることができます。

インターネット分野: Web バックエンド サービスを使用して、インターフェイス アクセスを制御し、アクセス要求を許可または拒否します。

認証、認可、認証と権限制御の関係は何ですか?

これを見ると、Authentication

Authorization

AuthenticationPermission Control これら 4 つのリンクを理解できるはずです。は、 上流と下流の順序で発生する 関係です。;

これら 4 つのリンクは同時に発生する場合があることに注意してください。 。たとえば、次のシナリオでは:

  • #アクセス カードを使用してドアを開けます: 認証、認可、認証、権限制御の 4 つのリンクが一度に完了し、瞬時に同時に行われます
  • ユーザーの Web サイトへのログイン: ユーザーがユーザー名とパスワードを使用してログインすると、認証と許可が同時に完了しますが、アイテムの選択や支払いなど、その後のアクセス要求では認証と許可の制御が行われます。
誰もが考えるべき小さな質問です:

認証と認証の間にはどのような関係がありますか?皆さんもコメント エリアで議論してください。

これらの関係は理解できたので、フロントエンド認証について話しましょう。そしてそれらの違いは何でしょうか?

1. HTTP 基本認証


HTTP では、

基本アクセス認証) はクライアント (通常は Web を指します) を許可します。ブラウザ) リクエストを行う際、ユーザー名とパスワードを入力することによってユーザーの身元が確認されます。

#ほとんどすべてのオンライン Web サイトはこの認証スキームを使用していないため、誰でもこのスキームを理解できます

1.1 認証フローチャート

【まとめ共有】もう迷わない、よく使われるフロントエンドとバックエンドの認証方法10選

1.2 認証ステップの分析

    クライアント (ブラウザなど):
  • サーバーから

    制限付きリスト データまたはリソース を要求します。たとえば、フィールドは次のとおりです

     GET /list/ HTTP/1.1
     Host: www.baidu.com
     Authorization: Basic aHR0cHdhdGNoOmY=
    ログイン後にコピー
  • Server
  • : こんにちは、クライアントです。このリソースはセキュリティ ゾーン

    baidu.com にあります。これは制限されたリソースであり、基本認証が必要です。 クライアントに 401 を返します。ステータスコード (未承認) と指定された認証ドメイン www-Authenticate: Basic realm=”baidu.com”

    requiresauthentication;

    ここで、Basic

    は検証モードであり、

    realm="baidu.com" は、クライアントが他のドメインのユーザー名とパスワードではなく、このセキュリティ ドメインのユーザー名とパスワードを入力する必要があることを示します

     HTTP/1.1 401 Unauthorized
     www-Authenticate: Basic realm= "baidu.com"
    ログイン後にコピー
  • クライアント:
  • サーバー、ユーザー名とパスワードを提示しましたので、ご覧ください; (注: クライアントがブラウザーの場合、この時点でポップアップ ウィンドウが自動的に表示され、ユーザーが入力したことを知らせます)ユーザー名とパスワード);

    ユーザー名とパスワードを入力すると、クライアントはユーザー名とパスワードを Base64 暗号化でサーバーに送信します。

    送信形式は次のとおりです (基本的な内容は :

    ユーザー名:ase64 形式のパスワード

    ):

     GET /list/ HTTP/1.1 
     Authorization: Basic Ksid2FuZzp3YW5n==
    ログイン後にコピー
    ##サーバー:
  • こんにちは、クライアントです。確認しました。
  • あなたのユーザー名とパスワードは、 Authorization

    フィールドは正しいです。これが必要なリソースです。

     HTTP/1.1 200 OK
     ...
    ログイン後にコピー

  • 1.3 利点

シンプルで、基本的にすべての一般的なブラウザでサポートされています#1.4 欠点

安全でない:

  • HTTP 送信に基づいているため、ほとんど危険です。インターネット上では裸であり、エンコードに Base64 を使用しますが、このエンコードは簡単にデコードできます。

    認証コンテンツを元のユーザー名とパスワードにデコードできない場合でも、それは安全ではありません。悪意のあるユーザーが認証コンテンツを取得し、それを使用してサーバーを継続的に共有してリクエストを開始する可能性があります。リプレイ攻撃と呼ばれます。

    • アクティブにログアウトできません
    • :
  • HTTP プロトコルには基本認証をクリアするメカニズムが提供されていないため、タブまたはブラウザが閉じられるか、ユーザーが履歴をクリアしない限り、ブラウザ内の情報。

    • #1.5 使用シナリオ
内部ネットワーク、またはそれほど高度なセキュリティ要件を持たないネットワーク。

2. Session-Cookie 認証

Session-Cookie

認証はサーバーとブラウザーの Session (セッション) を使用します ( Client) フロントエンドおよびバックエンドの通信認証モードを実装するための Cookie。

この文を理解する前に、
Cookie

Session とは何ですか?を簡単に理解しましょう。

2.1 Cookie とは

ご存知のとおり、

HTTP はステートレス プロトコルです (トランザクション用のメモリ容量はありません)処理、クライアントとサーバー間のセッションが完了するたびに、サーバーはセッション情報を保存しません); したがって、サーバーが異なるクライアントを区別するには、状態をアクティブに維持する必要があります。これは、前後の 2 つのリクエストが同じブラウザからのものであるかどうかをサーバーに通知するために使用されます。この状態は、Cookie

を通じて実現できます。 ######### 特徴: ######
  • Cookie はクライアント側に保存され、自由に改ざんされる可能性があります。安全ではありません。
  • サイズ制限があり、最大は 4kbです。
  • 数量制限です。一般に、ブラウザで保存できる Cookie は 20 個までであり、ブラウザで許可される Cookie は通常 300 個までです。
  • Android と IOS は Cookie を十分にサポートしていません
  • Cookie はサポートされていませんクロスドメインですが、ファーストレベル ドメイン名とセカンド レベル ドメイン名はサポートされていません。レベル ドメイン名は共有使用が許可されています (ドメインに応じて)

2.2 内容is Session

Session の抽象概念 is session は、ステートレス プロトコル通信プロセス中に中断/継続操作を実現するためのユーザーとサーバー間の対話を抽象化したものです。

## 具体的には、サーバーによって生成されたセッション構造であり、メモリ、データベース、ファイルなど、さまざまな方法で保存できます。大規模な Web サイトには通常、ユーザー セッションを保存するための専用のセッション サーバー クラスターがあります。

##原則プロセス:

  • クライアント:

    ユーザーが初めてサーバーにリクエストを送信します;

  • サーバー:

    データを受信し、ユーザー固有のセッション/セッション ID を自動的に作成してユーザーを識別し、ユーザーの現在のセッション プロセスを追跡します。

    クライアント:
  • ブラウザはセッション情報を取得するための応答を受信し、次のリクエストでセッション/セッション ID を取得します。
  • #サーバー:
  • 抽出後、サーバーはローカルに保存されたセッション ID と比較して、特定のユーザーのセッションを見つけ、セッション ステータスを取得します。
  • Atこの時点で、クライアントとサーバー間の通信はステートフル通信になります。

  • 特徴:

セッションはサーバーに保存されます。 ;

はサーバー独自の暗号化プロトコルを通じて実行されます;
  • Cookie との違い:

セキュリティ:

Cookie はクライアント側に保存され、自由に改ざんできますが、セッションはサーバー側に保存され、偽造できないため、セッションのセキュリティが高くなります。
  • #さまざまな種類のアクセス値: Cookie は文字列データのみをサポートし、Session は任意のデータ型を保存できます;
  • 異なる有効期間: Cookie を設定できます 長期間維持するために、Session は通常、有効期限が短い;
  • ストレージ サイズが異なります: Cookie によって保存されるデータは 4K を超えることはできません;
  • ここの一部の学生は次のことを参照してください。 Session-Cookie
  • はクライアントの
Cookie

Session を格納するだけなのでしょうか? ビンゴ、まさにその通りです。以下を見てみましょう

2.3 セッション-Cookie認証のフローチャート

2.4 セッション Cookie 認証ステップの分析

【まとめ共有】もう迷わない、よく使われるフロントエンドとバックエンドの認証方法10選

## クライアント: ログイン情報のユーザー名/パスワードをサーバーに送信してログイン検証を要求します;

  • サーバー: ログイン情報を検証し、検証に合格しました その後、セッションが自動的に作成されます (セッションをメモリまたは Redis に保存します)、このセッション

    session_id
  • (一般的に
  • sid

    と呼ばれます) の一意の識別文字列セッション ID 認証情報を生成し、この一意の識別子を応答に設定しますheader Set-Cookie; 注: 署名を使用して sid を暗号化できます。サーバーは、対応する secret# に基づいて復号化します。 ## キー (オプションのステップ)

    クライアント: サーバーから受信 応答後、応答ヘッダーが解析され、

    sid
    はローカル Cookie に自動的に保存されます。ブラウザは、ドメイン名の下の Cookie 情報を次の HTTP リクエストのリクエスト ヘッダーに自動的に添付します。
  • #サーバー: クライアント リクエストを受信すると、リクエスト ヘッダー Cookie 内の sid を解析し、この

    sid
  • を使用してサーバーによって保存されたものを見つけます。
  • クライアントの

    を確認し、リクエストが合法かどうかを判断します。 ##2.5 Session-Cookie の利点

  • Cookie はシンプルで使いやすいです

セッション データはサーバー側に保存されるため、JWT よりも管理が便利です。つまり、ユーザーがログインしてアクティブにログアウトするときのみ、対応するセッションの追加や削除が必要で、管理に便利です。バックエンドの操作だけで済み、フロントエンドは何の意味もなく操作できます。

  • 2.6 セッション Cookie の欠点
    • Cookies に依存します。ユーザーがブラウザーで Cookies を無効にすると、GG Smecta になります。
    • 非常に安全ではありません。Cookie はブラウザー内のデータを公開し、データ盗難のリスクを高めます。リスク(CSRFなどによる攻撃を受けやすい);
    • セッションはサーバー側に保存されるため、サーバー側のオーバーヘッドが増加し、ユーザー数が多い場合、サーバーのパフォーマンスが大幅に低下します。

    モバイル端末のサポート性的に不親切;

    2.7 使用シナリオ
    • 一般的に媒体に適用可能および大規模な Web サイト (モバイル APP を除く) ;

    一般的なセッションはメモリ サーバー (Redis など) に集中的に保存する必要があるため、サーバーの予算が増加するため、予算が十分でない場合は、慎重に;

    2.8 フロントエンドで一般的に使用される推奨セッション ライブラリ
    • express を使用します:
    • express- session
    • koa を使用します:
    koa -session


    3. トークン認証


    Session-Cookie

    いくつかの欠点とセッションのメンテナンスがサーバーに大きな問題を引き起こすことがわかりました。保存する場所を見つけ、配布の問題を考慮し、さらには別の Redis クラスターを有効にする必要があります。もっと良い方法はありますか?

    その後

    トークンが誕生しました

    3.1 トークンとは

    Token はトークンです。クライアントがサーバーにアクセスすると、サーバーは検証に合格した後、トークンを発行します。その後、クライアントはトークンを持ってサーバーにアクセスできます。サーバーは、その有効性を検証するだけです。トークン。

    一文でまとめる;

    リソース インターフェイス (API) にアクセスするときに必要なリソース認証情報

    一般的なトークンの構成: uid (ユーザーの一意の ID) time (現在の時刻のタイムスタンプ)

    sign

    (署名、トークンの最初の数桁は 16 進数に圧縮されます)特定の長さの文字列)

    トークン認証フローチャート:

    【まとめ共有】もう迷わない、よく使われるフロントエンドとバックエンドの認証方法10選

    トークン認証ステップ分析:
    • ##クライアント:

      ユーザー名とパスワードを入力してログイン認証を要求します;
    • サーバー:

      受信後リクエストでは、ユーザー名とパスワードを検証します。検証が成功すると、サーバーはトークンを発行し、そのトークンをクライアントに送信します。
    • クライアント:

      受信後トークンは保存する必要があります。Web 側は通常、トークンを localStorage または Cookie に保存し、モバイル ネイティブ APP は通常、ローカル キャッシュに保存します。
    • クライアントリクエストを送信します:

      サーバーから API リソースをリクエストする場合、トークンは HTTP リクエスト ヘッダーの Authorization フィールドまたはその他のメソッドを通じてサーバーに送信されます;
    • サーバー:

      リクエストを受信し、クライアント リクエストに含まれるトークンを検証します。検証が成功した場合は、要求されたデータがクライアントに返されます。そうでない場合は、返却が拒否されます (401);

    トークンの利点:

    • # サーバーはステートレスであり、優れたスケーラビリティを備えています:
    • トークン メカニズムはセッションを保存する必要がありません。サーバー側 (セッション) 情報。トークン自体には、識別されるユーザーに関連する情報が含まれており、複数のサービス間でユーザー ステータスを共有するのに役立ちます。
    • APP モバイル デバイスをサポートします。
    • 優れたセキュリティ:
    • CSRF 攻撃を効果的に回避します (Cookie が必要ないため)
    • クロスプログラム呼び出しのサポート:
    • Cookie では相互接続が許可されないため、

    #トークンの欠点:

    • 調整:フロントエンドが必要およびバックエンドの連携;
    • 占有帯域幅: 通常の状況では、sid よりも大きく、より多くのトラフィックを消費し、より多くの帯域幅を占有します
    • パフォーマンスの問題: トークンの検証時に権限検証のためにデータベースやリモート サービスにアクセスする必要はありませんが、トークンの暗号化や復号化などの操作が必要となるため、より多くのパフォーマンスが消費されます。
    • 有効期間が短い: トークンの盗難を防ぐため、一般的にトークンの有効期間は短く設定されるため、リフレッシュトークン;

    3.2 リフレッシュ トークンとは何ですか? )

    ビジネス インターフェイスによる認証に使用されるトークン。これを アクセス トークン#と呼びます。 ##。

    セキュリティ上の理由から、

    アクセス トークンの有効期間は通常、盗難を避けるために短く設定されています。ただし、有効期間が短すぎると、アクセス トークン が頻繁に期限切れになります。期限切れになった後はどうすればよいですか?

    1 つの方法は次のとおりです:

    アクセス トークンを更新します そして、ユーザーが再度ログインして新しいトークンを取得できるようにします。これは非常に面倒です;

    另外一种办法是:再来一个 Token,一个专门生成 Access Token 的 Token,我们称为 Refresh Token

    • Access Token: 用来访问业务接口,由于有效期足够短,盗用风险小,也可以使请求方式更宽松灵活;
    • Refresh Token: 用来获取 Access Token,有效期可以长一些,通过独立服务和严格的请求方式增加安全性;由于不常验证,也可以如前面的 Session 一样处理;

    Refresh Token 的认证流程图:

    【まとめ共有】もう迷わない、よく使われるフロントエンドとバックエンドの認証方法10選

    Refresh Token 认证步骤解析:

    • 客户端: 输入用户名和密码请求登录校验;

    • 服务端: 收到请求,验证用户名与密码;验证成功后,服务端会签发一个 Access TokenRefresh Token 并返回给客户端;

    • 客户端:Access TokenRefresh Token 存储在本地;

    • 客户端发送请求: 请求数据时,携带 Access Token 传输给服务端;

    • 服务端:

      • 验证 Access Token 有效:正常返回数据
      • 验证 Access Token 过期:拒绝请求
    • 客户端 ( Access Token 已过期) 则重新传输 Refresh Token 给服务端;

    • 服务端 ( Access Token 已过期) 验证 Refresh Token ,验证成功后返回新的 Access Token 给客户端;

    • 客户端: 重新携带新的 Access Token 请求接口;

    3.3 Token 和 Session-Cookie 的区别

    Session-CookieToken 有很多类似的地方,但是 Token 更像是 Session-Cookie 的升级改良版。

    • 存储地不同: Session 一般是存储在服务端;Token 是无状态的,一般由前端存储;
    • 安全性不同: Session 和 Token 并不矛盾,作为身份认证 Token 安全性比 Session 好,因为每一个请求都有签名还能防止监听以及重放攻击;
    • 支持性不同: Session-Cookie 认证需要靠浏览器的 Cookie 机制实现,如果遇到原生 NativeAPP 时这种机制就不起作用了,或是浏览器的 Cookie 存储功能被禁用,也是无法使用该认证机制实现鉴权的;而 Token 验证机制丰富了客户端类型。

    如果你的用户数据可能需要和第三方共享,或者允许第三方调用 API 接口,用 Token 。如果永远只是自己的网站,自己的 App,用什么就无所谓了。

    4. JWT(JSON Web Token)鉴权


    通过第三节,我们知道了 Token 的使用方式以及组成,我们不难发现,服务端验证客户端发送过来的 Token 时,还需要查询数据库获取用户基本信息,然后验证 Token 是否有效;

    这样每次请求验证都要查询数据库,增加了查库带来的延迟等性能消耗;

    那么这时候业界常用的 JWT 就应运而生了!!!

    4.1 什么是 JWT

    JWTAuth0 提出的通过 对 JSON 进行加密签名来实现授权验证的方案;

    就是登录成功后将相关用户信息组成 JSON 对象,然后对这个对象进行某种方式的加密,返回给客户端; 客户端在下次请求时带上这个 Token; 服务端再收到请求时校验 token 合法性,其实也就是在校验请求的合法性。

    4.2 JWT 的组成

    JWT 由三部分组成: Header 头部Payload 负载Signature 签名

    它是一个很长的字符串,中间用点(.)分隔成三个部分。列如 :

 eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c
ログイン後にコピー

Header 头部:

在 Header 中通常包含了两部分:

  • typ:代表 Token 的类型,这里使用的是 JWT 类型;
  • alg:使用的 Hash 算法,例如 HMAC SHA256 或 RSA.
 {
   "alg": "HS256",
   "typ": "JWT"
 }
ログイン後にコピー

Payload 负载:

它包含一些声明 Claim (实体的描述,通常是一个 User 信息,还包括一些其他的元数据) ,用来存放实际需要传递的数据,JWT 规定了7个官方字段:

  • iss (issuer):签发人
  • exp (expiration time):过期时间
  • sub (subject):主题
  • aud (audience):受众
  • nbf (Not Before):生效时间
  • iat (Issued At):签发时间
  • jti (JWT ID):编号

除了官方字段,你还可以在这个部分定义私有字段,下面就是一个例子。

 {
   "sub": "1234567890",
   "name": "John Doe",
   "admin": true
 }
ログイン後にコピー

Signature 签名

Signature 部分是对前两部分的签名,防止数据篡改。

首先,需要指定一个密钥(secret)。这个密钥只有服务器才知道,不能泄露给用户。然后,使用 Header 里面指定的签名算法(默认是 HMAC SHA256),按照下面的公式产生签名。

 HMACSHA256(
   base64UrlEncode(header) + "." +
   base64UrlEncode(payload),
   secret)
ログイン後にコピー

4.3 JWT 的使用方式

客户端收到服务器返回的 JWT,可以储存在 Cookie 里面,也可以储存在 localStorage。

此后,客户端每次与服务器通信,都要带上这个 JWT。你可以把它放在 Cookie 里面自动发送,但是这样不能跨域,所以更好的做法是放在 HTTP 请求的头信息Authorization字段里面。

 Authorization: Bearer <token></token>
ログイン後にコピー

4.4 JWT 的认证流程图

其实 JWT 的认证流程与 Token 的认证流程差不多,只是不需要再单独去查询数据库查找用户用户;简要概括如下:

【まとめ共有】もう迷わない、よく使われるフロントエンドとバックエンドの認証方法10選

4.5 JWT 的优点

  • 不需要在服务端保存会话信息(RESTful API 的原则之一就是无状态),所以易于应用的扩展,即信息不保存在服务端,不会存在 Session 扩展不方便的情况;
  • JWT 中的 Payload 负载可以存储常用信息,用于信息交换,有效地使用 JWT,可以降低服务端查询数据库的次数

4.6 JWT 的缺点

  • 加密问题: JWT 默认是不加密,但也是可以加密的。生成原始 Token 以后,可以用密钥再加密一次。
  • 到期问题: 由于服务器不保存 Session 状态,因此无法在使用过程中废止某个 Token,或者更改 Token 的权限。也就是说,一旦 JWT 签发了,在到期之前就会始终有效,除非服务器部署额外的逻辑。

4.7 前端常用的 JWT 库推荐

5. 单点登录(Single Sign On)


前面我们已经知道了,在同域下的客户端/服务端认证系统中,通过客户端携带凭证,可以维持一段时间内的登录状态。

但随着企业的发展,一个大型系统里可能包含 n 多子系统,用户在操作不同的系统时,需要多次登录,很麻烦,那么单点登录(SSO) 就可以很好的解决这个问题的,在多个应用系统中,只需要登录一次,就可以访问其他相互信任的应用系统。

  • 例如登录天猫,淘宝也会自动登录;
  • 登录百度贴吧,百度网盘也会自动登录;

5.1 同域下的 SSO(主域名相同)

当百度网站存在两个相同主域名下的贴吧子系统 tieba.baidu.com 和网盘子系统 pan.baidu.com 时,以下为他们实现 SSO 的步骤:

  • 客户端: 用户访问某个子系统时(例如 tieba.baidu.com),如果没有登录,则跳转至 SSO 认证中心提供的登录页面进行登录;

  • 服务端: 登录认证后,服务端把登录用户的信息存储于 Session 中,并且附加在响应头的 Set-Cookie 字段中,设置 Cookie 的 Domain 为 .baidu.com

  • 客户端:再次发送请求时,携带主域名 Domain 下的 Cookie 给服务器,此时服务端就可以通过该 Cookie 来验证登录状态了;

其实我们不难发现,这就是我们上面讲的 Session-Cookie 认证 登录方式; 但如果是不同域呢?毕竟不同域之间 Cookie 是不共享的,那怎么办?

5.2 跨域下的 SSO(主域名不同)

当社の一般的なショッピング Web サイトである Tmall (tmall.com) と Taobao (taobao.com) では、一方のシステムにログインするだけで済み、もう一方のシステムはシステムを開いた後、デフォルトでログインします。私たちはこれをしますか?毛織物?

次に、CAS (Central Authentication Service) 中央認証サービス があるので、最初に CAS;

のプロセスについて説明します。シングル サインオンでの CAS 認証のフローチャート:

【まとめ共有】もう迷わない、よく使われるフロントエンドとバックエンドの認証方法10選

#シングル サインオンでの CAS 認証手順の詳細な説明:

  • クライアント:

    システム A へのアクセスを開始しました;

  • システム A:

    ユーザーがログインしていないことがわかりました、CAS 認証サービス (sso.com) にリダイレクトされます。同時に、URL アドレス パラメーターには、ログイン成功後にシステム A に戻るページ リンクが含まれています (sso.com/login?redir…)

  • CAS 認証サービス:

    リクエスト Cookie にログイン チケット証明書 (TGC) が含まれていないことが判明したため、CAS 認証サービスはユーザーが次のとおりであると判断します。 not logged in 状態で、ユーザー ページを CAS にリダイレクトします。ログイン インターフェイス、ユーザーは CAS ログイン ページにログインします。

  • クライアント:

    CAS システム認証のユーザー名とパスワードを入力します;

  • CAS 認証サービス:

    ユーザー情報を確認し、TGC を自分のセッションを作成し、Set-Cookie の形式でドメインを と記述します sso.com のドメイン下に、同時に 認可トークン ST (サービスチケット) が生成されます、システム A のアドレスにリダイレクトされます。リダイレクトされたアドレスには、生成された ST が含まれます (リダイレクト アドレス :www.taabao.com?token=ST-345678)

  • # システム A:
  • ST を使用して CAS 認証サービスにリクエストを送信します。CAS 認証サービスはチケット (ST) の有効性を検証します。検証が成功すると、システム A はユーザーがログインしたことを認識します。 CAS (ST は Cookie またはローカルに保存できます)、システム A サーバーはチケット (ST) を使用してユーザーの証明書を作成します。部分セッションと呼ばれるセッションは、保護されたリソースを返します。

  • この時点で、クライアントはシステム A と正常に通信できます~

    クライアント:
  • システム B へのアクセスを開始しました;

  • システム B:
  • ユーザーがログインしていないことがわかり、SSO 認証サービスにリダイレクトされ、自分のアドレスをパラメータとして渡し、Cookie の値をsso.com ドメインは、5 番目のステップで生成された TGC です;

  • CAS 認証サービス:
  • CAS 認証サービス センターは、ユーザーがログインしていることを検出し、ジャンプします。システム B のアドレスに戻り、チケット (ST) を添付します;

  • システム B:
  • チケット (ST) を取得し、CAS 認証サービスに移動しますチケットの有効性を確認します (ST)。検証が成功すると、クライアントはシステム B と対話することもできます~

  • (追記: ボートを 2 台持つのは少し面倒な気がします~)

シングル サインオン時の注意点:

図のプロセスに示すように、
    CAS 認証サービス
  • 発行中

    認可トークン ST が直接リダイレクトされた後、実際には盗まれやすくなります。その後、システム A またはシステム B で CAS への認証を成功させる必要があります (図のステップ 14 および 14)。ステップ 11)、別の新しい検証トークンを生成し、保存するためにクライアントに返します。

    CAS は通常、次の 4 つのインターフェイスを提供します:
  • /login
      : ログイン インターフェイス。中央認証サービスへのログインに使用されます。
    • /logout
    • : ログアウト インターフェイス。中央認証サービスからのログアウトに使用されます。
    • /validate
    • : ユーザーが中央認証サービスにログインしたかどうかを確認するために使用されます。
    • /serviceValidate
    • : 各サービスがユーザーがログインしたかどうかを確認できるようにするために使用されます。中央認証サービスへ
    CAS によって生成されたチケット:
  • TGT (Ticket Grangting Ticket)
      : TGT は
    • ユーザー ## に対して CAS によって発行されたログイン チケット#。TGT を使用すると、ユーザーは CAS に正常にログインしたことを証明できます。 TGC: チケット認可 Cookie: CAS サーバーは TGT を生成し、それを独自のセッションに置きます。TGC は、このセッションの一意の識別子 (SessionId) であり、ブラウザ上に配置されます。 Cookie の形式で、CAS サーバーがユーザーを識別するために使用する資格情報です。
    • ST (サービス チケット) : ST は、ユーザーがサービスにアクセスするために CAS によって発行されるチケットです。
    6. OAuth 2.0

実際にWebサイトを閲覧するとき、ログインするとき、入力するだけでなく、現在の Web サイトのアカウントとパスワードに加えて、サードパーティの QQ または WeChat を通じてログインできることもわかりました。そのため、これを行う方法として、OAuth

について説明する必要があります。

OAuth 协议又有 1.0 和 2.0 两个版本,2.0 版整个授权验证流程更简单更安全,也是目前最主要的用户身份验证和授权方式。

6.1 什么是 OAuth 2.0?

OAuth 是一个开放标准,允许用户授权第三方网站 (CSDN、思否等) 访问他们存储在另外的服务提供者上的信息,而不需要将用户名和密码提供给第三方网站;

常见的提供 OAuth 认证服务的厂商: 支付宝、QQ、微信、微博

简单说,OAuth 就是一种授权机制。数据的所有者告诉系统,同意授权第三方应用进入系统,获取这些数据。系统从而产生一个短期的进入令牌(Token),用来代替密码,供第三方应用使用。

令牌与密码的差异:

令牌(Token)密码(Password) 的作用是一样的,都可以进入系统,但是有三点差异。

  • 令牌是短期的,到期会自动失效: 用户自己无法修改。密码一般长期有效,用户不修改,就不会发生变化。

  • 令牌可以被数据所有者撤销,会立即失效。

  • 令牌有权限范围(scope): 对于网络服务来说,只读令牌就比读写令牌更安全。密码一般是完整权限。

OAuth 2.0 对于如何颁发令牌的细节,规定得非常详细。具体来说,一共分成四种授权模式 (Authorization Grant) ,适用于不同的互联网场景。

无论哪个模式都拥有三个必要角色:客户端授权服务器资源服务器,有的还有用户(资源拥有者),下面简单介绍下四种授权模式。

6.2 授权码模式

授权码(Authorization Code Grant) 方式,指的是第三方应用先申请一个授权码,然后再用该码获取令牌。

这种方式是最常用的流程,安全性也最高,它适用于那些有后端服务的 Web 应用。授权码通过前端传送,令牌则是储存在后端,而且所有与资源服务器的通信都在后端完成。这样的前后端分离,可以避免令牌泄漏。

一句话概括:客户端换取授权码,客户端使用授权码换token,客户端使用token访问资源

授权码模式的步骤详解

  • 客户端:

    打开网站 A,点击登录按钮,请求 A 服务,A 服务重定向 (重定向地址如下) 至授权服务器 (如QQ、微信授权服务)。

     https://qq.com/oauth/authorize?
       response_type=code&
       client_id=CLIENT_ID&
       redirect_uri=CALLBACK_URL&
       scope=read
    ログイン後にコピー

    上面 URL 中,response_type 参数表示要求返回授权码(code),client_id 参数让 B 知道是谁在请求,redirect_uri 参数是 B 接受或拒绝请求后的跳转网址,scope 参数表示要求的授权范围(这里是只读)

【まとめ共有】もう迷わない、よく使われるフロントエンドとバックエンドの認証方法10選

  • 授权服务器:

    授权服务网站 会要求用户登录,然后询问是否同意给予 A 网站授权。用户表示同意,这时授权服务网站 就会跳回 redirect_uri 参数指定的网址。跳转时,会传回一个授权码,就像下面这样。

    https://a.com/callback?code=AUTHORIZATION_CODE
    ログイン後にコピー

    上面 URL 中,code 参数就是授权码。

【まとめ共有】もう迷わない、よく使われるフロントエンドとバックエンドの認証方法10選

  • 网站 A 服务器:

    拿到授权码以后,就可以向 授权服务器 (qq.com) 请求令牌,请求地址如下:

     https://qq.com/oauth/token?
      client_id=CLIENT_ID&
      client_secret=CLIENT_SECRET&
      grant_type=authorization_code&
      code=AUTHORIZATION_CODE&
      redirect_uri=CALLBACK_URL
    ログイン後にコピー

    上面 URL 中,client_id 参数和 client_secret 参数用来让授权服务器 确认 A 的身份(client_secret 参数是保密的,因此只能在后端发请求),grant_type参数的值是AUTHORIZATION_CODE,表示采用的授权方式是授权码,code 参数是上一步拿到的授权码,redirect_uri 参数是令牌颁发后的回调网址。

1【まとめ共有】もう迷わない、よく使われるフロントエンドとバックエンドの認証方法10選

  • 授权服务器:

    收到请求以后,验证通过,就会颁发令牌。具体做法是向 redirect_uri 指定的网址,发送一段 JSON 数据。

     {    
       "access_token":"ACCESS_TOKEN",
       "token_type":"bearer",
       "expires_in":2592000,
       "refresh_token":"REFRESH_TOKEN",
       "scope":"read",
       "uid":100101,
       "info":{...}
     }
    ログイン後にコピー

    上面 JSON 数据中,access_token 字段就是令牌,A 网站在后端拿到了,然后返回给客户端即可。

【まとめ共有】もう迷わない、よく使われるフロントエンドとバックエンドの認証方法10選

6.3 隐藏式模式(Implicit Grant)

有些 Web 应用是纯前端应用,没有后端。这时就不能用上面的方式了,必须将令牌储存在前端。OAuth2.0 就规定了第二种方式,允许直接向前端颁发令牌。这种方式没有授权码这个中间步骤,所以称为(授权码)"隐藏式"(implicit)。

一句话概括:客户端让用户登录授权服务器换token,客户端使用token访问资源

隐藏式模式的步骤详解

  • 客户端:

    打开网站 A,A 网站提供一个链接,要求用户跳转到 授权服务器,授权用户数据给 A 网站使用。如下链接:

     https://qq.com/oauth/authorize?
       response_type=token&
       client_id=CLIENT_ID&
       redirect_uri=CALLBACK_URL&
       scope=read
    ログイン後にコピー

    上面 URL 中,response_type参数为token,表示要求直接返回令牌。

  • 授权服务器:

    用户跳转到授权服务器,登录后同意给予 A 网站授权。这时,授权服务器就会跳回redirect_uri 参数指定的跳转网址,并且把令牌作为 URL 参数,传给 A 网站。

     https://a.com/callback#token=ACCESS_TOKEN
    ログイン後にコピー

    上面 URL 中,token参数就是令牌,A 网站因此直接在前端拿到令牌。

1【まとめ共有】もう迷わない、よく使われるフロントエンドとバックエンドの認証方法10選

注意:

  • 令牌的位置是 URL 锚点(fragment),而不是查询字符串(querystring),这是因为 OAuth 2.0 允许跳转网址是 HTTP 协议,因此存在"中间人攻击"的风险,而浏览器跳转时,锚点不会发到服务器,就减少了泄漏令牌的风险。

  • 这种方式把令牌直接传给前端,是很不安全的。因此,只能用于一些安全要求不高的场景,并且令牌的有效期必须非常短,通常就是会话期间(session)有效,浏览器关掉,令牌就失效了。

6.4 用户名密码式模式(Password Credentials Grant)

如果你高度信任某个应用,OAuth 2.0 也允许用户把用户名和密码,直接告诉该应用。该应用就使用你的密码,申请令牌,这种方式称为"密码式"(password)。

一句话概括:用户在客户端提交账号密码换token,客户端使用token访问资源。

密码式模式的步骤详解

  • 客户端:

    A 网站要求用户提供 授权服务器(qq.com) 的用户名和密码。拿到以后,A 就直接向 授权服务器 请求令牌。

     https://oauth.b.com/token?
       grant_type=password&
       username=USERNAME&
       password=PASSWORD&
       client_id=CLIENT_ID
    ログイン後にコピー

    上面 URL 中,grant_type参数是授权方式,这里的password表示"密码式",usernamepassword授权服务器 的用户名和密码。

  • 授权服务器:

    授权服务器 验证身份通过后,直接给出令牌。

    注意,这时不需要跳转,而是把令牌放在 JSON 数据里面,作为 HTTP 回应,A 网站因此拿到令牌。

这种方式需要用户给出自己的用户名/密码,显然风险很大,因此只适用于其他授权方式都无法采用的情况,而且必须是用户高度信任的应用。

6.5 客户端模式(Client Credentials Grant)

客户端模式指客户端以自己的名义,而不是以用户的名义,向授权服务器 进行认证。

主要适用于没有前端的命令行应用。

一句话概括:客户端使用自己的标识换token,客户端使用token访问资源

客户端模式的步骤详解

  • 客户端:

    客户端向授权服务器 进行身份认证,并要求一个访问令牌。请求链接地址:

     https://oauth.b.com/token?
       grant_type=client_credentials&
       client_id=CLIENT_ID&
       client_secret=CLIENT_SECRET
    ログイン後にコピー

    上面 URL 中,grant_type参数等于client_credentials表示采用凭证式,client_idclient_secret用来让授权服务器 确认 A 的身份。

  • 授权服务器:

    授权服务器 验证通过以后,直接返回令牌。

注意:这种方式给出的令牌,是针对第三方应用的,而不是针对用户的,即有可能多个用户共享同一个令牌。

6.5 授权模式选型

按授权需要的多端情况:

模式 需要前端 需要后端 需要用户响应 需要客户端密钥
授权码模式 Authorization Code
隐式授权模式 Implicit Grant
密码授权模式 Password Grant
客户端授权模式 Client Credentials

クライアントの種類とアクセス トークンの所有者に応じて分類:

1【まとめ共有】もう迷わない、よく使われるフロントエンドとバックエンドの認証方法10選

上記は主に単純です。 OAuth2.0 の基本的なロジックについて説明しています。さらに詳しく知りたい場合は、公式ドキュメント OAuth または RFC 6749 をご覧ください。また、OAuth 2.0 の概念と認可プロセスの概要 比較

7. フェデレーション ログインと信頼されたログイン


##7.1 共同ログインとは

共同ログインとは、複数のログイン サービスを指します。同時に、認証情報の検証も行うと同時に、検証にサードパーティの認証情報を使用するログイン サービスとしても理解できます。

平たく言えば: 2 つの Web サイト A と B の場合、Web サイト A にログインするときに Web サイト B のアカウントとパスワードを使用します (共同ログイン)。または、ログインするときに Web サイト A を使用します。アカウントのパスワードも共同ログインです。

この概念は、実際には、前述の OAuth2.0 の

ユーザー名パスワード モード認証方法に似ています。

最も古典的なのは、APP に埋め込まれた H5 の使用シナリオです。ユーザーが APP から埋め込まれた H5 に入ると、APP にログインしているユーザーがログインせずに H5 の制限されたリソースにアクセスできるようになります。ユーザーはアクセスするにはログインする必要があります。

ここには主に 2 つのアイデアがあります。1 つは、埋め込まれた H5 ページにネイティブにジャンプするときに、URL パラメーターにログイン トークンを添付することです。もう 1 つは、ネイティブ クライアントとの定式化を通じて H5 をアクティブに埋め込むことです。アプリケーション内のログインステータスを取得します。

7.2 トラスト ログインとは

トラスト ログインとは、ユーザーの積極的な参加を必要としないすべてのログインを指します。プライベート デバイスとユーザー間のバインディング関係の確立などでは、資格情報はプライベート デバイスの情報であり、現時点ではユーザーは追加の資格情報を提供する必要はありません。信頼できるログインとは、サードパーティの比較的成熟したユーザー ライブラリを使用して資格情報を確認し、現在アクセスしている Web サイトにログインすることも指します。

わかりやすく言うと: Web サイト A にログインしている場合、ログインせずに Web サイト B に直接ジャンプできます。これが trust login です。

現在、より一般的なサードパーティの信頼できるログイン アカウントは、QQ Taobao アカウント、Alipay アカウント、Weibo アカウントなどです。

OAuth を使用することでトラスト ログインが実現できるため、OAuth 2.0 が実際にトラスト ログインの典型であることを理解するのは難しくありません。

8. 固有のログイン


—プロダクト マネージャーが次のリクエストを行ったとします:

ユーザーは 1 つのログインにのみログインできることを認識したいと考えていますデバイス. ユーザーは繰り返しログインすることを禁止されています;

- 優秀なプログラマーとして、もちろん彼を満足させます。 !

8.1 ユニークログインとは

ユニークログインとは、複数の人が同時に同じアカウントにログインすることを禁止することを指します。後者のログイン動作により、前者がオフラインになります。

簡単に言うと、

: アカウント A がコンピュータ A にログインした後、アカウント A はコンピュータ B を使用して再度ログインします。コンピュータ A がページを要求すると、「ログインの再起動」というプロンプトが表示されます。

#8.2 独自のログイン フローチャート

1【まとめ共有】もう迷わない、よく使われるフロントエンドとバックエンドの認証方法10選

##8.3 固有のログイン手順の詳細説明

クライアント A でのユーザー操作:

アカウント要求の入力 ログインインターフェイス;
  • バックエンドは対応するトークンを生成してクライアント A に返し、ログイン ステータスをサーバーに保存します;
  • クライアント Aトークンを保存し、各リクエストはヘッダーに対応するトークンを運びます;
  • ユーザーはクライアント B を操作します:

ユーザーが突然クライアント B でログイン操作を開始すると、その手順はクライアント A での操作とほぼ同じであることがわかります。

バックエンドが新しいトークンを生成するときに、最初にログイン ステータスを確認する必要があるだけです。次に、対応する新しいトークンを生成します;

#9. QR コードをスキャンしてログインします

##9.1 QR コードログインとは


##

スキャン QR コード ログインは通常、モバイル APP にあります。多くの PC Web サイトでは QR コード ログインの機能が提供されています。Web ページでアカウント番号とパスワードを入力する必要はありません。モバイル APP (など) を許可するだけで済みます。 (WeChat、淘宝、QQ など) など) ログインしているユーザーは、QR コード をアクティブにスキャンし、ログインを確認します。PC 上の同じアプリケーションにすばやくログインする方法は、次のとおりです。 QR コードをスキャンしてログインします。

9.2 QR コードとは

QR コード QR コード、一般的な QR コード QR コードとも呼ばれます。 QR の正式名は Quick Response で、近年モバイル デバイスで非常に人気のあるエンコード方式で、従来のバーコードよりも多くの情報を保存し、より多くのデータ型を表現できます。

上記のことから、QR コードをスキャンしてログインするには 3 つの端末 (

PC 端末モバイル端末サーバー端末#) が必要であることが簡単にわかります。 ##) 協力によってのみログインを成功させることができます;

9.3 QR コードをスキャンしてログインするための認証フローチャート

1【まとめ共有】もう迷わない、よく使われるフロントエンドとバックエンドの認証方法10選##9.4 QR コードを読み取ってログインする手順の詳細説明 (読み取る段階、確認する段階、確認する段階)

スキャンする段階:

PC 側:
  • Web サイトを開きます (たとえば、 taobao.com) または APP (WeChat など) を使用して QR コードをスキャンしてログインすると、PC のデバイス情報が伝達され、QR コードを取得するリクエストがサーバーに送信されます。

    #サーバー:

  • サーバーはリクエストを受信すると、QR コード ID として UUID がランダムに生成され、その UUID が
  • に関連付けられます。 PC側のデバイス情報

    を取得してRedisサーバーに保存し、PC側に戻すと同時に有効期限を設定後、ユーザーはQRコードを更新してログインし、再度取得する必要があります。

    PC側:

  • QRコードIDを受信後、QRコードIDを
  • QRコード形式に変換します

    表示してモバイル端末がコードをスキャンするのを待ちます。このとき、PC はログインが成功するまで QR コードの状態を確認するためのポーリングを開始します。 モバイル端末がスキャンされない場合、QR コードは一定期間後に自動的に期限切れになります。

    スキャンされたコードと保留中の確認:

モバイル バージョン:

    携帯電話でログインした
  • に対応するAPP (WeChatやTaobaoなど)を開き、スキャンを開始してPCに表示されたQRコードを識別します;

    その後携帯電話でQRコードを読み取ると、自動的にQRコードIDを取得し、携帯端末のログイン情報伝票(トークン)とQRコードIDをパラメータとしてサーバーに送信します。このとき、携帯電話はログインしている必要があります。 (スキャンログインを使用する場合は、ログイン状態を共有できるように携帯端末アプリケーションがログイン状態であることが前提となります)。

    サーバー:

    携帯電話からリクエストを受信すると、
  • トークンとQRコードID
  • 関連付け、なぜそれを関連付ける必要があるのでしょうか? WeChatを利用する際にモバイル側でログアウトするとPC側もログアウトする必要があるため、この関連付けがその役割を果たします。その後、一時的なトークンが生成され、モバイル端末に返され、ワンタイム トークンが確認用のバウチャーとして使用されます。

    確認済みステージ:

モバイル版:

受信後確認情報を受信して​​確認ボタンをクリックすると、モバイル端末は前のステップで取得した
    一時トークン
  • を保持し、検証のためにサーバーに送信します。

    #server:

    サーバー側の認証が完了すると、QRコードのステータスが更新され、PC側に

    正式トークンが生成されます。 PC側はこのトークンを保持してサーバー側にアクセスします。

  • PC側:

    ポーリングによりQRコードの状態がログイン状態となり、生成されたTokenを取得し、ログインが完了します以降のアクセスは Token に基づいて完了します。

  • #10. ワンクリック ログイン (ネイティブ APP に適用)

10.1 アカウントとパスワードを使用したログイン

ご存知のとおり、最も伝統的なログイン方法は # を使用してログインすることです。 ##アカウントとパスワード、単純かつ粗雑ですが、通常は問題ありません;


欠点:
ただし、この方法には次の必要があります。ユーザーは自分自身を覚えておく必要があります。アカウント番号とパスワードには記憶コストがかかります。メモリのコストを削減するために、ユーザーは異なるプラットフォームで同じアカウント パスワードのセットを使用する可能性があります。セキュリティの観点から、特定のプラットフォームのアカウントパスワードが漏洩すると、ユーザーが利用している他のプラットフォームにも影響が及びます。

また、アカウントは個人情報とは関係がないため、同一ユーザーが複数の異なるアカウントを登録できることになり、悪意のある登録が行われる可能性があります。

携帯電話カードの実名制義務化が解決するまで!
  • 10.2 携帯電話番号認証コードログイン

    無線インターネットの発展と携帯電話カードの実名制の推進により、携帯電話番号はアカウントのパスワードと比較して、携帯電話番号はユーザーの身元をより確実に検証し、悪意のある登録を防ぐことができます。

    ただし、携帯電話番号を登録するには、携帯電話番号を入力し、SMS 認証コードが届くのを待ち、認証コードを入力して、クリックしてログインするという一連の面倒な操作が必要です。プロセス全体には少なくとも 20 秒かかり、テキスト メッセージを受信できない場合はログインする必要があるため、この種の問題は潜在的なユーザーの損失につながる可能性があります。

    セキュリティの観点からは、認証コードが漏洩するリスクもあります。誰かがあなたの携帯電話番号を知って認証コードを盗んだ場合、その人はあなたのアカウントにログインすることもできます。

    つまり、ワンクリックでログイン操作ができるのです。

    10.3 ワンクリック ログインとは

    考えてみましょう。なぜ確認コードが必要なのでしょうか。認証コードの役割は、その携帯電話番号が自分のものであることを確認することですが、テキスト メッセージを使用する以外に携帯電話番号を認証する方法はありますか?

    つまり、主人公はワンクリックでログインできます。

    SMS認証コードの役割は、現在の操作ページのユーザーと携帯電話番号を入力したユーザーが同一人物であることを証明することです。現在の携帯電話で使用しているカード番号。この番号を直接使用してログインできます。追加の操作は必要ありません。これは ワンクリック ログイン です。

    ワンクリックログインが可能かどうかは、運営者が関連サービスを開設しているかどうかで決まり、運営者が関連サービスを開設すると、運営者が提供するSDKにアクセスし、料金を支払って関連サービスを利用できるようになります。

    ワンクリック ログインのフローチャート:

    1【まとめ共有】もう迷わない、よく使われるフロントエンドとバックエンドの認証方法10選

    ワンクリック ログイン手順の詳細な説明:

    • SDK の初期化: SDK メソッドを呼び出し、プラットフォームによって構成された AppKey と AppSecret を渡します

    • 認証ページの取り消し: SDK を呼び出して認証インターフェイスを呼び出します。SDK はまずオペレータに携帯電話番号マスクを取得するリクエストを開始します。リクエストが成功すると、認証ページにジャンプします。認証ページには、ユーザー確認のための携帯電話番号マスクとオペレーター同意書が表示されます。

    • 承認に同意してログイン: ユーザーは、関連する契約に同意し、承認ページのログイン ボタンをクリックします。SDK は、次のトークンを要求します。リクエストが成功すると、トークンがクライアントに返されます。

    • 番号を取得します: 取得したトークンを自分のサーバーに送信すると、サーバーはトークンを持ってオペレーターのワンクリック ログイン インターフェイスに電話をかけると、通話が成功すると携帯電話番号が返されます。サーバーは携帯電話番号を使ってログインや登録を行い、操作結果をクライアントに返すことでワンクリックログインが完了します。

    ##3 つの主要通信事業者のオープン プラットフォーム:

    • ##モバイル インターネット機能のオープン プラットフォーム

    • Telecom-Tianyi アカウント オープン プラットフォーム

    • ##チャイナ ユニコム-WO オープン プラットフォーム
    • ※国内大手3社はそれぞれ独立したSDKを持っているため、互換作業は特に煩雑になります。ワンクリック ログイン ソリューションを使用したい場合は、番号認証サービスを提供するサードパーティを使用することをお勧めします。次のサプライヤーはすべて、携帯電話番号認証機能を備えています:

      Alibaba -番号認証サービス

      注:

    認証プロセス中、ユーザーは携帯電話ネットワークをオンにする必要があります。携帯電話端末にSIMカードが挿入されていない場合、または携帯電話ネットワークがオフになっている場合 ネットワークの場合は認証を完了できません。したがって、ワンクリック ログインが有効になっている場合でも、従来のログイン方法と互換性があり、失敗した場合でもユーザーがログイン プロセスを正常に完了できるようにする必要があります。

    概要

    上記の 10 個の認証方法を学習して理解した後、簡単にまとめてみましょう

    • HTTP 基本認証 内部ネットワーク、またはセキュリティ要件がそれほど高くないネットワークに適しています。
    • Session-Cookie 一般的な媒体に適しています。および大規模な Web サイト (モバイル APP を除く)。
    • TokenJWT は市場のほとんどのエンタープライズ Web サイトに適しており、JWT のパフォーマンスは Token よりも優れています。 ;
    • シングル サインオン 多くのサブシステムを備えた大規模な企業 Web サイトに適しています;
    • #OAuth 2.0 ユーザーを迅速に登録する必要がある Web サイトに適しています。
    • QR コードをスキャンしてログイン 3 つの端末の展開を完了した企業に適用;
    • ワンクリック ログイン ネイティブ APP に適用;
    この記事は、https://juejin.cn/post/7129298214959710244

    著者: Master Yi

    (学習ビデオ共有:

    Web フロントエンド )

関連ラベル:
ソース:juejin.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート