---
title: "テレビを観るのと同じくらい簡単で、煩わしい認証を排除したOAuth 2.0 Device Flow"
description: "OAuth 2.0 Device Flowが、入力に制約のあるデバイスへの認証および認可をどのようにスムーズに行うかについてご覧ください。"
authors:
  - name: "Dan Arias"
    url: "https://auth0.com/blog/authors/dan-arias/"
date: "Jun 19, 2019"
category: "Announcements,Features,OAuth Device Flow"
tags: ["oauth", "authentication", "device-flow", "input-constrained", "input-constrained-devices", "auth0", "authorization", "authentication", "iot", "smart-devices", "smart-tv", "security", "identity"]
url: "https://auth0.com/blog/jp-oauth-device-flow-no-hassle-authentication-as-seen-on-tv/"
---

# テレビを観るのと同じくらい簡単で、煩わしい認証を排除したOAuth 2.0 Device Flow



スマートテレビに資格情報を入力する際、リモコンやオンスクリーンキーボードを使用することにうんざりしていませんか？本記事を読んでいるあなたは、この問題の対処に幾度となく取り組んできたと思いますが、それでも最終的には顧客に委ねざるを得ません。では、スマートフォンの画面を数回タップするだけで、ユーザーがログインできるようにサポートしてみてはいかがでしょうか？

![テレビのリモコンを使用して資格情報を入力している人物の画像](https://images.ctfassets.net/23aumh6u8s0i/40YgdeQssI4jVCDkuUFBhK/84a3c8111f80e7c8f1e0c45c0366f7ac/do-not-use-remote-controls-to-enter-credentials)

こんにちは。Auth0開発チームのDanです。ここでは、[**OAuth 2.0 Device Flow**](https://auth0.com/device-flow/)についてご紹介します。この認証を利用すれば、スマートテレビや入力に制限のあるデバイスに簡単に、迅速に、そして安全にログインできます。キーボードもブラウザも使用しません。

従来のログイン方式は面倒で、エラーも多発します。OAuth 2.0 Device Flowは軽快で、わずか数秒で認証でき、テレビはもちろん、ゲームコンソール、CLI、プリンタなどにも対応しています。

Auth0は、OAuth 2.0 Device Flowに完全に準拠した実装を提供することで、開発者がこうしたユーザーエクスペリエンスの悩みの種により簡単に取り組めるようにしました。入力に制限のあるデバイスとはどのようなものか、どのように認可付与が行われるのか、そしてどのようにAuth0がサポートしているのか、詳細を見ていきましょう。

## 入力に制限のあるインターネット接続デバイスとは

(1) ブラウザを持たないか、または (2) テキスト入力方式が実用的ではない、インターネット接続デバイスをお持ちではありませんか？

お持ちなら、それは入力に制限のあるデバイスです。どのようなタイプのデバイスを頭に思い浮かべましたか？私なら...

- 複合機
- フィットネストラッカ
- ストリーミングデバイス
- 電動歯ブラシ
- ゲームコンソール
- 冷蔵庫
- テディベア
- 車載インフォテインメントシステム
- スマートテレビ
- 頭に「スマート」と付く単語なら何でも

![スマートテレビ、プリンタ、ゲームコンソール、その他の典型的な入力に制限のあるデバイス](https://images.ctfassets.net/23aumh6u8s0i/2f4VYWXdICGOnMhmtm0u1G/d847718b30d453a63bd3f4d21c9d0e89/typical-input-constrained-devices)

モノのインターネット（IoT）の急激な台頭により、多くのデバイスはオンライン化されました。今日そして将来的にも、IoTデバイスで実行されるソフトウェアは、デバイスやプラットフォームを超えて顧客に豊かなユーザーエクスペリエンスを提供するために必要なデータを取得するため、御社のサービスAPIを呼び出す場合があります。しかしながら、そのようなユーザーエクスペリエンスは、デバイスに外部サービスを簡単に認可する方法が実装されていなければ、あまり豊かにも安全にもならない可能性があります。

<include src="JpTweetQuote" quoteText="入力に制限のあるデバイスに許可付与するのは難しいもの。では、入力に制限のあるインターネット接続デバイスとはどのようなものでしょうか？このブログ記事で詳しく解説します。"/>

競争市場でしのぎを削る企業として、ブラウザを使用しない認証を提供できないという理由で、御社のサービスを使用できるデバイスに制限をかけたくはありません。ただし、デバイスがブラウザやユーザーインターフェイスを提供しない場合でも、顧客には、テレビのリモコンの矢印を使用して資格情報を入力し、巨大なオンスクリーンキーボードからキーを選択させたくはないものです。例えば、顧客が入力に手間取っている間に、何者かが画面を録画していれば、顧客の資格情報が漏えいする可能性があります。

さらに、御社の管理外にあり、今後のアクセスのためにユーザーの資格情報を保存可能なシステム（御社のAPIにアクセスする専用のシステムやサードパーティクライアントを活用することもあるスマートディスプレイなど）にユーザー資格情報が入力されることがないようにしたいでしょう。

求められるのは、様々なデバイスで御社のAPIへのアクセスを制御することで、サードパーティアプリケーションを認可する方法です。OAuth 2.0 Device Flowは、それを確実に実現します。ブラウザを実装していないデバイスでも、標準的な委譲型認可プロトコルのセキュリティとユーザーエクスペリエンスの利点を活用できます。

<include src="ProfileCard" picture="https://cdn.auth0.com/blog/auziro/julian-lywood-mulcock-mini.png" name="Julian Lywood-Mulcock" title="カスタマサクセスアーキテクト" team="カスタマサクセス" location="ロンドン（イギリス）" body="Device Flowの利用により、当社はエンドユーザーの不満を解消し、ログインアクションのセキュリティをできる限り確保しました。<br /><br />ログイン機能を入力に制限のあるデバイスから切り離すことで、エンドユーザーは安全な認証方法を活用し、ストレスのないエンドユーザーエクスペリエンスを実現できます。その噂はユーザーの友人たちにも伝わるでしょう。"/>

Device Flowの取り扱い方を理解するため、ビデオストリーミングアプリを例にとり、実際の仕組みを見ていきましょう。

## OAuth 2.0 Device Flowの仕組み

AuthU TVという技術者向けの架空のビデオプラットフォームをテレビで観るとします。最初に、AuthU TVアプリをスマートテレビにダウンロードします。初めてアプリを開くと、ログイン画面が表示されます。

手始めに、別のデバイス（スマートフォンやラップトップなど）でURLにアクセスし、短いコードを入力し、AuthUアカウントにログインしてユーザー認証を行う必要があります。

このプロセスが完了すると、テレビのソフトウェアからAuthUアカウントへのアクセス権が付与されます。AuthUコンテンツに移動するには、リモコンを使用する必要がありますが、資格情報の入力は不要です。

![デバイスに接続するOAuth 2.0 Device Flowの図](https://images.ctfassets.net/23aumh6u8s0i/2fc4mgnGc7TLVmFSyFCEmq/a1a849dbf53cc82ec7c30e6f6ff63b31/device-flow-banner-2)

大まかに言えば、このプロセスは、YouTubeでユーザーログインの処理時にaccounts.google.comへリダイレクトされる仕組みとよく似ています。OAuth 2.0 Device Flowため、2台目のデバイスを使用して、認証プロセスを一元化されたログインページで管理します。認証プロセスをデバイスから切り離してブラウザに統合すると、MFA、SSO、ソーシャルログインなどのより高度なアイデンティティ管理機能やセキュリティ機能を活用できます。

言うは易しですので、Device Flowの仕組みを見てみましょう。当社のAuth0担当エンジニアが対話型のデモを作成しました。このデモでは、ブラウザから直接、AuthUスマートテレビアプリの認証をシミュレートできます。

まず、[_Device Flow Playground_](https://auth0.github.io/device-flow-playground/)にアクセスしてください。アクセスしたら、当社のデフォルトのデモ設定を使用してプレイグラウンドを試してみるか、または自分のAuth0アカウント設定を使用して構成し、独自のアプリケーションで試すことができます。

> Auth0アカウントが必要になるかですって？<a href="https://auth0.com/signup" data-amp-replace="CLIENT_ID" data-amp-addparams="anonId=CLIENT_ID(cid-scope-cookie-fallback-name)">今すぐ無料でお始めください</a>。Auth0の無料トライアルが提供する充実した機能を使用すると、驚きの声を上げずにはいられないことでしょう。

目的のスコープを選択することもできます。選択したら、「Get Started」をクリックしてください。

![Auth0 Device Flowの始め方に関するダッシュボードを示す図](https://images.ctfassets.net/23aumh6u8s0i/2kEgfhvZh84ty2XsEfjDS4/282e39d53d32deef8e381d012bbce385/getting-started)

次に、模擬AuthU TVアプリからコンテンツをストリーム配信するため、「Authorize」ボタンをクリックしてアプリを認可するよう求められます。

![Auth0 Device Flow：認証リクエスト](https://images.ctfassets.net/23aumh6u8s0i/YYQyy8IRjr6yMu5bZ2CVK/a1d955489836849e35411d38da360a2e/authorization-request)

デバイスを認可するには、アクティベーション用URL（[_acme-demo.auth0.com/activate_](https://acme-demo.auth0.com/activate)）に移動し、別のデバイスを使用して、スマートテレビに表示されるコードを入力します。QRコードをスキャンし、自動的にユーザーコードを入力することもできます。TVアプリは、2台目のデバイスでプロセスを完了するまで待機状態となります。このプロセス完了により、AuthU TVサービスへのアクセス権を取得するために使用可能な認可レスポンスがトリガーされます。

![Auth0 Device Flow：トークンリクエスト](https://images.ctfassets.net/23aumh6u8s0i/1kbV5mJIgdzqj1zKttXvhx/edefed4de2bfd100c411b0e4192c6892/token-request-2)

提供されるリンクにアクセスし、ワンタイムコードを入力して、「Continue」をクリックします。別のブラウザタブまたはスマートフォンのモバイルブラウザを使用することもできます。

![Auth0 Device Flow：デバイスのアクティベーション](https://images.ctfassets.net/23aumh6u8s0i/2DyardhZGZL9dsFkyv1ntI/eeee2eee9563b6c32066c3b5df3223c2/device-activation-enter-code)

![Auth0 Device Flow：デバイスのアクティベーションコード](https://images.ctfassets.net/23aumh6u8s0i/5PUMsCJHIxEqQuqBhec3oC/6b3a2704a91bfd070ac57ad87983d7c9/device-activation-code-entered)

サイトに表示されるコードが、スマートテレビに表示されるコードと一致することを確認し、「Continue」をクリックします。

![Auth0 Device Flow：デバイスの確認](https://images.ctfassets.net/23aumh6u8s0i/7c5GzgdHLuYt2iPuqDzBhd/c5cd28ea0e35deee1a8648a757fd18d6/device-confirmation)

次に、アカウントを登録するか、または既存のアカウントを使用してログインします。

![Auth0 Device Flow：ユーザー認証](https://images.ctfassets.net/23aumh6u8s0i/1s4Z8pZ2FknPYkMD3BtcNr/0e46e566969ef95f364bb30afd12bb5e/authentication)

デバイスが接続されたことを確認するメッセージがサイトに表示されます。

![Auth0 Device Flow：デバイスの接続](https://images.ctfassets.net/23aumh6u8s0i/6rJnFfbuz2vv0gn5Du3ivY/3df5ee90405b34ebe7816149d8777d7f/your-device-is-now-connected)

スマートテレビに戻ると、AuthUはコンテンツのストリーム配信を開始する準備が整っています。TVアプリには、ユーザーに関する追加情報を取得してUIをカスタマイズするための認可機能が実装されています。

![Auth0 Device Flow：アクティベーション完了](https://images.ctfassets.net/23aumh6u8s0i/01qheEW2pvdEikaQlCUq2l/12338b0c904089d2d86eace3f955cff7/activation-complete)

以上が、OAuth 2.0 Device Flowの大まかな技術概要です。続いて、どのようにアイデンティティ管理プラットフォームとしてAuth0を用いて、このプロセスを円滑化に行うかについて、詳しく見ていきましょう。

## Auth0により円滑化されるOAuth 2.0 Device Flow

入力に制限のあるデバイスでAPIからユーザーデータを取得する必要があるとき、以下のプロセスが実行されます。

![APIを呼び出すOAuth 2.0 Device Flowの概要](https://images.ctfassets.net/23aumh6u8s0i/2Ykjsm2pB8MBDiqWLTq6RQ/e80d6aa8ab913d990107e81b2aa41dbc/overview-flow-call-api-device-app)

1. デバイスアプリケーションがまだ認可されていない場合、デバイスアプリケーションはデバイスコードを取得するためにAuth0認可サーバーを呼び出します。

2. Auth0は、URLとユーザーコードを返します。デバイスアプリは、ユーザーに2台目のデバイス（ラップトップやスマートフォンなど）で特定のURLにアクセスし、アクティベーションコードを入力することを求めます。

3. デバイスアプリは、アクセストークンとリフレッシュトークンのためにAuth0認可サーバーのポーリングを開始します。

4. ユーザーは、いずれかの設定済み認証方式を使用して2台目のデバイスでAuth0を認証します。Auth0は、各種プロトコル（OpenID Connect、SAML、WS-Federationなど）を使用して数多くの[_アイデンティティプロバイダ_](https://auth0.com/docs/identityproviders)をサポートするアイデンティティ管理ハブです。

5. 認証が完了すると、Auth0はデイバスアプリにアクセストークンおよびリフレッシュトークンを返します。リフレッシュトークンにより、ユーザーからリクエスト許可を再び得ることなくアクセストークンを更新できます。

6. アクセストークンを使用すると、APIを呼び出してリクエストされたデータを取得できます。

<include src="JpTweetQuote" quoteText="アクセストークンとリフレッシュトークンを使用すると、認証は迅速化され、持続します。OAuth 2.0 Device Flowにおけるトークンの機能に関する詳細をご覧ください。"/>

## まとめ

本日は、入力に制限のあるインターネット接続デバイスの種類、そのデバイスが開発者および顧客にも提示する課題、そしてDevice Flowの実装により、OAuth 2.0に準拠したAuth0がこうした課題に対してどのように取り組むかについて学びました。

OAuth 2.0 Device Flowの最大の特徴は、既存の認証ソリューションをスマートデバイスプラットフォームにまで拡張できるところにあります。この許可付与により、顧客は一方のデバイスで実行されるアプリケーションを別のデバイスを使用して簡単に認証・認可できます。

OAuth 2.0 Device FlowをAuth0で実装するために、どのようなコードを書けばよいかについて、興味が出てきましたか？Device Flowに関する詳細なチュートリアルを近日公開する予定です。乞うご期待ください。それまでは、以下のリソースで詳細をご確認ください。

- [Device Flowの紹介](https://auth0.com/device-flow/)

- [Auth0デバイス認証フロー取扱説明書](https://auth0.com/docs/flows/concepts/device-auth)

- [デバイス認証フローを使用してAPIを呼び出す](https://auth0.com/docs/flows/guides/device-auth/call-api-device-auth)

- [OAuth 2.0デバイス認証許可（ドラフト15）](https://tools.ietf.org/html/draft-ietf-oauth-device-flow-15)

<include src="JpTweetQuote" quoteText="OAuth 2.0 Device Flowは、ブラウザを実装していないか、または入力に制限のあるインターネット接続デバイスで実行されるアプリケーション向けに設計されています。この認証フローにより、エンドユーザーはデバイスアプリケーションを認証してサービスAPIにアクセスできます。"/>

<include src="asides/JpAboutAuth0" />

