最近ブログのシステムを改善していたのですが、コメントするために一時的に名前とメールアドレスを入力する方法から、GitHub 認証を使用してログインしてコメントを投稿する方法に変更することを突然思いつきました。 ヒント: この記事は個人的なニーズを満たすもののみを対象としています。より詳細な使用方法を学習する必要がある場合は、公式の OAuth ドキュメントを参照してください。 OAuth アプリの作成まず、GitHub アカウントを取得し、GitHub 開発者にアクセスします。必要な情報を入力すると、次の手順で使用する Client_ID と Client Secret が自動的に生成されます。 コードを取得する//方法 非同期githubLogin() { ウィンドウズ.location.href = 「https://github.com/login/oauth/authorize?client_id = your_client_id&redirect_uri=your_redirect_uri」 } <a href="https://github.com/login/oauth/authorize?client_id = your_client_id&redirect_uri=your_redirect_uri">GitHub ログイン</a> ルート内の redirect_uri パラメータはオプションです。省略した場合、GitHub は OAuth アプリで設定したコールバック パスにリダイレクトします。指定する場合、入力する redirect_uri は、OAuth アプリで構成したコールバック パスのサブパスである必要があります。次のように: コールバック: http://xx.com/github ユーザーがリクエストを受け入れると、redirect_uri にジャンプし、ルート内のパラメータ コードを受け入れて次のステップに進むことができます。 リダイレクトURI?コード=xxx access_tokenを取得するaccess_token を取得するには、client_id、client_secret、および code が必要です。 /* /githubアクセストークン:https://github.com/login/oauth/access_token */ これ.$axios .get('/githubAccessToken',{ パラメータ: { client_id: クライアントID、 クライアントシークレット: クライアントシークレット、 コード: your_code } }) デフォルトでは、次のような応答が返されます。 access_token=xxxxx&token_type=bearer より便利な形式で応答を受け取りたい場合は、 Accept ヘッダーをカスタマイズできます。 受け入れる: "application/json" => {"access_token":xxxxx、"token_type":bearer} ユーザー情報を取得するaccess_token を取得したら、ユーザーの情報を要求できます。 /* /githubユーザー情報:https://api.github.com/user */ これ.$axios .get('/githubUserInfo', { ヘッダー: { 「コンテンツタイプ」: 「application/x-www-form-urlencoded」、 受け入れる: "application/json", 認証: `token ${access_token}` //必須} }) その後、ユーザー情報を取得できます。 Vue による GitHub のサードパーティ認証の実装に関するこの記事はこれで終わりです。Vue による GitHub のサードパーティ認証の実装に関するより関連性の高いコンテンツについては、123WORDPRESS.COM の過去の記事を検索するか、以下の関連記事を引き続き閲覧してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
<<: Docker x509 の安全でないレジストリ問題を解決する
問題の説明CSS を使用して上部の固定効果を実現したいと思います。 margin-top と pos...
//文法: @media mediatype and | not | only (メディア機能) ...
この記事の例では、画像デジタル時計を実現するためのJSの具体的なコードを参考までに共有しています。具...
目次1. ピニアとは何ですか? 2. Piniaは使いやすい3. ユーザーエクスペリエンス1. ピニ...
目次序文ターゲット最初のステップ:ステップ2:ステップ3:ステップ4:要約する序文現在主流のフレーム...
目次1. css() の基本的な使用法: 1.1 CSSプロパティを取得する1.2 CSSプロパティ...
最近、インターネットのベテランと「広告」について議論したのですが、彼から非常に興味深い意見を聞きまし...
目次概要node.js でマルチコア CPU を最大限に活用する方法Node で子プロセスを作成する...
交差点セレクター交差セレクターは、直接接続された 2 つのセレクターで構成されます。最初のセレクター...
MySQL データベースには増分バックアップ メカニズムはありませんが、マスター データベース内のす...
目次MySQL 削除構文エイリアスの問題mysql の delete ステートメントでエイリアスを使...
1. まず、Linux システムのバージョン内容について概要を説明します。 1. カーネルバージョン...
著者が MySQL を使用してユーザーを追加していたところ、ユーザー名が間違って記述されていることに...
この記事の例では、テーブル行データのスクロール効果を実現するためのjQueryの具体的なコードを参考...
クラスを見るとき、どのような情報を得たいですか?このクラスはどこで使用され、その機能は何ですか?この...