Android 10(API レベル 29)以降のデバイスでは、新しいピアツーピア API を使用して、Chromecast や Google Home ハードウェアなどのセカンダリ デバイスの構成をブートストラップできます。この機能により、アプリは WifiNetworkSpecifier
を使用してリクエストされたネットワークのプロパティを記述することで、デバイスが接続されているアクセス ポイントを変更するようユーザーに促すことができます。
この API を使用する手順は次のとおりです。
WifiNetworkSpecifier.Builder
を使用して Wi-Fi ネットワーク指定子を作成します。接続先のネットワークと必要な認証情報に一致するネットワーク フィルタを設定します。
各リクエストでネットワーク フィルタを設定するには、次の要件に従い、
SSID
、SSID pattern
、BSSID
、BSSID pattern
の組み合わせを決定します。- 各リクエストでは、
SSID
、SSID pattern
、BSSID
、BSSID pattern
のうち少なくとも 1 つを指定する必要があります。 - 各リクエストで設定できるのは、
SSID
またはSSID pattern
のいずれか 1 つのみです。 - 各リクエストで設定できるのは、
BSSID
またはBSSID pattern
のいずれか 1 つのみです。
- 各リクエストでは、
リクエストのステータスを追跡するために、指定子を
NetworkCallback
インスタンスとともにネットワーク リクエストに追加します。ユーザーがリクエストを受け入れ、ネットワークへの接続に成功すると、コールバック オブジェクトで
NetworkCallback.onAvailable()
が呼び出されます。ユーザーがリクエストを拒否した場合、またはネットワークへの接続が失敗した場合は、コールバック オブジェクトでNetworkCallback.onUnavailable()
が呼び出されます。
ピアデバイスへの接続リクエストを開始すると、同じデバイスでダイアログ ボックスが開き、そのデバイスのユーザーは接続リクエストを承認できます。
ユーザー承認の回避
特定のアプリからのリクエストに応答してユーザーが接続先のネットワークを承認すると、デバイスは特定のアクセス ポイントに対する承認を保存します。アプリがそのアクセス ポイントに再度接続するように特定のリクエストを行うと、デバイスはユーザーの承認フェーズをスキップして、自動的にネットワークに接続します。API によってリクエストされたネットワークに接続中に、ユーザーがネットワークの削除を選択した場合、この保存済みのアプリとネットワークの組み合わせに対する承認が削除されます。アプリからの今後のリクエストはすべて、ユーザーが再度承認する必要があります。アプリが SSID や BSSID のパターンを使用するなど、非特定のリクエストを行う場合、ユーザーはリクエストを承認する必要があります。
コードサンプル
次のコードサンプルは、SSID 接頭辞が "test"
で、BSSID OUI が "10:03:23"
のオープン ネットワークに接続する方法を示しています。
Kotlin
val specifier = WifiNetworkSpecifier.Builder() .setSsidPattern(PatternMatcher("test", PatternMatcher.PATTERN_PREFIX)) .setBssidPattern(MacAddress.fromString("10:03:23:00:00:00"), MacAddress.fromString("ff:ff:ff:00:00:00")) .build() val request = NetworkRequest.Builder() .addTransportType(NetworkCapabilities.TRANSPORT_WIFI) .removeCapability(NetworkCapabilities.NET_CAPABILITY_INTERNET) .setNetworkSpecifier(specifier) .build() val connectivityManager = context.getSystemService(Context.CONNECTIVITY_SERVICE) as ConnectivityManager val networkCallback = object : ConnectivityManager.NetworkCallback() { ... override fun onAvailable(network: Network?) { // do success processing here.. } override fun onUnavailable() { // do failure processing here.. } ... } connectivityManager.requestNetwork(request, networkCallback) ... // Release the request when done. connectivityManager.unregisterNetworkCallback(networkCallback)
Java
final NetworkSpecifier specifier = new WifiNetworkSpecifier.Builder() .setSsidPattern(new PatternMatcher("test", PatternMatcher.PATTERN_PREFIX)) .setBssidPattern(MacAddress.fromString("10:03:23:00:00:00"), MacAddress.fromString("ff:ff:ff:00:00:00")) .build(); final NetworkRequest request = new NetworkRequest.Builder() .addTransportType(NetworkCapabilities.TRANSPORT_WIFI) .removeCapability(NetworkCapabilities.NET_CAPABILITY_INTERNET) .setNetworkSpecifier(specifier) .build(); final ConnectivityManager connectivityManager = (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE); final NetworkCallback networkCallback = new NetworkCallback() { ... @Override void onAvailable(...) { // do success processing here.. } @Override void onUnavailable(...) { // do failure processing here.. } ... }; connectivityManager.requestNetwork(request, networkCallback); ... // Release the request when done. connectivityManager.unregisterNetworkCallback(networkCallback);