MediaCas Klasse
Definition
Wichtig
Einige Informationen beziehen sich auf Vorabversionen, die vor dem Release ggf. grundlegend überarbeitet werden. Microsoft übernimmt hinsichtlich der hier bereitgestellten Informationen keine Gewährleistungen, seien sie ausdrücklich oder konkludent.
MediaCas kann verwendet werden, um Schlüssel für das Entschlüsseln geschützter Medienströme in Verbindung mit android.media.MediaDescrambler
.
[Android.Runtime.Register("android/media/MediaCas", ApiSince=26, DoNotGenerateAcw=true)]
public sealed class MediaCas : Java.Lang.Object, IDisposable, Java.Interop.IJavaPeerable, Java.Lang.IAutoCloseable
[<Android.Runtime.Register("android/media/MediaCas", ApiSince=26, DoNotGenerateAcw=true)>]
type MediaCas = class
inherit Object
interface IAutoCloseable
interface IJavaObject
interface IDisposable
interface IJavaPeerable
- Vererbung
- Attribute
- Implementiert
Hinweise
MediaCas kann verwendet werden, um Schlüssel für das Entschlüsseln geschützter Medienströme in Verbindung mit android.media.MediaDescrambler
. Die MediaCas-APIs sollen bedingten Zugriff unterstützen, z. B. die im ISO/IEC13818-1. Das Zertifizierungsstellensystem wird durch eine 16-Bit-ganzzahlige CA_system_id identifiziert. Die Scramblingalgorithmen sind in der Regel proprietäre und implementiert von herstellerspezifischen CA-Plug-Ins, die auf dem Gerät installiert sind.
Die App ist für die Erstellung eines MediaCas-Objekts für das CA-System verantwortlich, das sie verwenden möchte. Die App kann abfragen, ob ein bestimmtes Zertifizierungsstellensystem mit statischer Methode #isSystemIdSupported
unterstützt wird. Sie kann auch die gesamte Liste der unterstützten Zertifizierungsstellensysteme mit statischer Methode #enumeratePlugins
abrufen.
Nachdem das MediaCas-Objekt erstellt wurde, sollte sie von der App ordnungsgemäß mithilfe der Methode #provision
und/oder bereitgestellt #processEmm
werden. Die EMMs (Berechtigungsverwaltungsnachrichten) können out-of-band oder in-band mit dem Datenstrom verteilt werden.
Um elementare Datenströme zu entwischen, ruft #openSession
die App zunächst auf, um ein Session
Objekt zu generieren, das eine Sitzung eindeutig identifiziert. Eine Sitzung stellt einen Kontext für nachfolgende Schlüsselaktualisierungen und Deskramblingaktivitäten bereit. Die ECMs (Berechtigungssteuerungsmeldungen) werden per Methode Session#processEcm
an die Sitzung gesendet.
Die App erstellt als Nächstes ein MediaDescrambler -Objekt und initialisiert es mit der Sitzung.MediaDescrambler#setMediaCasSession
Dadurch wird der Descrambler mit der Sitzung verknüpft, und der Descrambler kann dann verwendet werden, um mit dem Schlüssel der Sitzung gesicherten Inhalt zu entschlüsseln, entweder während der Extraktion oder während der Decodierung mit android.media.MediaCodec
.
Wenn die App die Beispielextraktion mithilfe eines eigenen Extraktors verarbeitet, kann sie MediaDescrambler verwenden, um Beispiele in klare Puffer zu entschlüsseln (wenn die Lizenz der Sitzung keine sicheren Decoder erfordert) oder eine kleine Datenmenge entschlüsselt, um Informationen abzurufen, die für die nachgeschaltete Pipeline erforderlich sind, um das Beispiel zu verarbeiten (wenn die Lizenz der Sitzung sichere Decoder erfordert).
Wenn für die Sitzung ein sicherer Decoder erforderlich ist, muss für MediaCodec ein MediaDescrambler bereitgestellt werden, um In die Warteschlange von Beispielen zu entschlüsseln, die in MediaCodec#queueSecureInputBuffer
geschützten Puffern in die Warteschlange gestellt werden. Die App sollte anstelle der normalen MediaCodec#configure(MediaFormat, android.view.Surface, MediaCrypto, int)
Methode zum Konfigurieren von MediaCodec verwendet MediaCodec#configure(MediaFormat, android.view.Surface, int, MediaDescrambler)
werden.
<h3>Verwenden des MediaExtractors</h3 von Android>
Wenn die App verwendet MediaExtractor
, kann sie die CAS-Sitzungsverwaltung durch Aufrufen MediaExtractor#setMediaCas
an MediaExtractor delegieren. MediaExtractor übernimmt und anruft #openSession
, #processEmm
und/oder Session#processEcm
, usw. gegebenenfalls.
Bei verwendung MediaExtractor
würde die App weiterhin einen MediaDescrambler verwenden MediaCodec
, wenn die Lizenzierung einen sicheren Decoder erfordert. Die sitzung, die dem Descrambler eines Titels zugeordnet ist, kann durch Aufrufen MediaExtractor#getCasInfo
abgerufen und zum Initialisieren eines MediaDescrambler-Objekts für MediaCodec verwendet werden.
<h3>Listener</h3>
Die App kann einen Listener registrieren, um Ereignisse vom Zertifizierungsstellensystem mithilfe der Methode #setEventListener
zu empfangen. Das genaue Format des Ereignisses ist schemaspezifisch und wird von dieser API nicht angegeben.
Java-Dokumentation für android.media.MediaCas
.
Teile dieser Seite sind Änderungen auf der Grundlage von Arbeiten, die vom Android Open Source-Projekt erstellt und freigegeben werden und gemäß den in der Creative Commons 2.5 Attribution License beschriebenen Begriffen verwendet werden.
Konstruktoren
MediaCas(Context, Int32, String, Int32) |
Instanziieren Sie ein Zertifizierungsstellensystem der angegebenen System-ID. |
MediaCas(Context, Int32, String, Int32, Handler, MediaCas+IEventListener) |
Instanziieren Sie ein Zertifizierungsstellensystem der angegebenen System-ID. |
MediaCas(Int32) |
Instanziieren Sie ein Zertifizierungsstellensystem der angegebenen System-ID. |
Felder
PluginStatusPhysicalModuleChanged |
Veraltet.
Das Ereignis, das angibt, dass der Status des CAS-Systems durch das Entfernen oder Einfügen physischer CAS-Module geändert wird. |
PluginStatusSessionNumberChanged |
Veraltet.
Das Ereignis, das angibt, dass die Anzahl der Sitzung des CAS-Systems geändert wird. |
ScramblingModeAes128 |
Veraltet.
Advanced Encryption System (AES) 128-Bit-Verschlüsselungsmodus. |
ScramblingModeAesCbc |
Veraltet.
Advanced Encryption System (AES) Cipher Block Chaining (CBC)-Modus. |
ScramblingModeAesEcb |
Veraltet.
Advanced Encryption System (AES) Electronic Code Book (ECB)-Modus. |
ScramblingModeAesScte52 |
Veraltet.
Advanced Encryption System (AES) Society of Cable Telecommunications Engineers (SCTE) 52 Mode. |
ScramblingModeDvbCissaV1 |
Veraltet.
DVB Common IPTV Software-orientierte Scrambling Algorithm (CISSA) Version 1. |
ScramblingModeDvbCsa1 |
Veraltet.
DVB (Digital Video Broadcasting) Common Scrambling Algorithm (CSA) 1. |
ScramblingModeDvbCsa2 |
Veraltet.
DVB CSA 2. |
ScramblingModeDvbCsa3Enhance |
Veraltet.
DVB CSA 3 im voll erweiterten Modus. |
ScramblingModeDvbCsa3Minimal |
Veraltet.
DVB CSA 3 im minimal erweiterten Modus. |
ScramblingModeDvbCsa3Standard |
Veraltet.
DVB CSA 3 im Standardmodus. |
ScramblingModeDvbIdsa |
Veraltet.
ATIS-0800006 IIF Default Scrambling Algorithm (IDSA). |
ScramblingModeMulti2 |
Veraltet.
Ein symmetrischer Schlüsselalgorithmus. |
ScramblingModeReserved |
Veraltet.
DVB (Digital Video Broadcasting) reservierter Modus. |
ScramblingModeTdesEcb |
Veraltet.
Triple Data Encryption Algorithm (TDES) Electronic Code Book (ECB)-Modus. |
ScramblingModeTdesScte52 |
Veraltet.
Triple Data Encryption Algorithm (TDES) Society of Cable Telecommunications Engineers (SCTE) 52 Mode. |
SessionUsageLive |
Veraltet.
Cas-Sitzung wird verwendet, um Livestreams zu descramble. |
SessionUsagePlayback |
Veraltet.
Cas-Sitzung wird zum Descramble recored streams verwendet. |
SessionUsageRecord |
Veraltet.
Cas-Sitzung wird verwendet, um Livestreams zu entschlüsseln und lokale aufgezeichnete Inhalte zu verschlüsseln |
SessionUsageTimeshift |
Veraltet.
Cas-Sitzung wird verwendet, um Livestreams zu entschlüsseln, lokale aufgezeichnete Inhalte zu verschlüsseln und lokale verschlüsselte Inhalte wiederzugeben. |
Eigenschaften
Class |
Gibt die Laufzeitklasse dieses Werts |
Handle |
Das Handle für die zugrunde liegende Android-Instanz. (Geerbt von Object) |
JniIdentityHashCode |
MediaCas kann verwendet werden, um Schlüssel für das Entschlüsseln geschützter Medienströme in Verbindung mit |
JniPeerMembers |
MediaCas kann verwendet werden, um Schlüssel für das Entschlüsseln geschützter Medienströme in Verbindung mit |
PeerReference |
MediaCas kann verwendet werden, um Schlüssel für das Entschlüsseln geschützter Medienströme in Verbindung mit |
ThresholdClass |
Diese API unterstützt die Mono für Android-Infrastruktur und ist nicht für die direkte Verwendung aus Ihrem Code vorgesehen. (Geerbt von Object) |
ThresholdType |
Diese API unterstützt die Mono für Android-Infrastruktur und ist nicht für die direkte Verwendung aus Ihrem Code vorgesehen. (Geerbt von Object) |
Methoden
Clone() |
Erstellt und gibt eine Kopie dieses Objekts zurück. (Geerbt von Object) |
Close() |
MediaCas kann verwendet werden, um Schlüssel für das Entschlüsseln geschützter Medienströme in Verbindung mit |
Dispose() |
MediaCas kann verwendet werden, um Schlüssel für das Entschlüsseln geschützter Medienströme in Verbindung mit |
Dispose(Boolean) |
MediaCas kann verwendet werden, um Schlüssel für das Entschlüsseln geschützter Medienströme in Verbindung mit |
EnumeratePlugins() |
Auflisten aller verfügbaren CA-Plug-Ins auf dem Gerät. |
Equals(Object) |
Gibt an, ob ein anderes Objekt "gleich" diesem Objekt ist. (Geerbt von Object) |
GetHashCode() |
Gibt einen Hashcodewert für das Objekt zurück. (Geerbt von Object) |
IsSystemIdSupported(Int32) |
Abfrage, ob ein bestimmtes Zertifizierungsstellensystem auf diesem Gerät unterstützt wird. |
JavaFinalize() |
Wird vom Garbage Collector für ein Objekt aufgerufen, wenn die Garbage Collection bestimmt, dass keine weiteren Verweise auf das Objekt vorhanden sind. (Geerbt von Object) |
Notify() |
Aktiviert einen einzelnen Thread, der auf dem Monitor dieses Objekts wartet. (Geerbt von Object) |
NotifyAll() |
Aktiviert alle Threads, die auf dem Monitor dieses Objekts warten. (Geerbt von Object) |
OpenSession() |
Öffnen Sie eine Sitzung, um einen oder mehrere Datenströme vom System für bedingten Zugriff zu entwischen. |
OpenSession(Int32, Int32) |
Öffnen Sie eine Sitzung, um einen oder mehrere Datenströme vom System für bedingten Zugriff zu entwischen. |
ProcessEmm(Byte[]) |
Senden Sie ein empfangenes EMM-Paket an das Zertifizierungsstellensystem. |
ProcessEmm(Byte[], Int32, Int32) |
Senden Sie ein empfangenes EMM-Paket an das Zertifizierungsstellensystem. |
Provision(String) |
Initiieren eines Bereitstellungsvorgangs für ein Zertifizierungsstellensystem. |
RefreshEntitlements(Int32, Byte[]) |
Benachrichtigen Sie das Zertifizierungsstellensystem, um Berechtigungsschlüssel zu aktualisieren. |
SendEvent(Int32, Int32, Byte[]) |
Senden eines Ereignisses an ein Zertifizierungsstellensystem. |
SetEventListener(MediaCas+IEventListener, Handler) |
Legen Sie einen Ereignislistener fest, um Benachrichtigungen von der MediaCas-Instanz zu empfangen. |
SetHandle(IntPtr, JniHandleOwnership) |
Legt die Handle-Eigenschaft fest. (Geerbt von Object) |
SetPrivateData(Byte[]) |
Senden Sie die privaten Daten für das Zertifizierungsstellensystem. |
ToArray<T>() |
MediaCas kann verwendet werden, um Schlüssel für das Entschlüsseln geschützter Medienströme in Verbindung mit |
ToString() |
Gibt eine Zeichenfolgendarstellung des Objekts zurück. (Geerbt von Object) |
UnregisterFromRuntime() |
MediaCas kann verwendet werden, um Schlüssel für das Entschlüsseln geschützter Medienströme in Verbindung mit |
Wait() |
Bewirkt, dass der aktuelle Thread wartet, bis er wach ist, in der Regel durch em benachrichtigt/em> oder <em>unterbrochen</em>.<>< (Geerbt von Object) |
Wait(Int64) |
Bewirkt, dass der aktuelle Thread wartet, bis er wach ist, in der Regel durch <em>benachrichtigt</em> oder <em>unterbrochen</em> oder bis eine bestimmte Menge an Echtzeit verstrichen ist. (Geerbt von Object) |
Wait(Int64, Int32) |
Bewirkt, dass der aktuelle Thread wartet, bis er wach ist, in der Regel durch <em>benachrichtigt</em> oder <em>unterbrochen</em> oder bis eine bestimmte Menge an Echtzeit verstrichen ist. (Geerbt von Object) |
Explizite Schnittstellenimplementierungen
IJavaPeerable.Disposed() |
MediaCas kann verwendet werden, um Schlüssel für das Entschlüsseln geschützter Medienströme in Verbindung mit |
IJavaPeerable.DisposeUnlessReferenced() |
MediaCas kann verwendet werden, um Schlüssel für das Entschlüsseln geschützter Medienströme in Verbindung mit |
IJavaPeerable.Finalized() |
MediaCas kann verwendet werden, um Schlüssel für das Entschlüsseln geschützter Medienströme in Verbindung mit |
IJavaPeerable.JniManagedPeerState |
MediaCas kann verwendet werden, um Schlüssel für das Entschlüsseln geschützter Medienströme in Verbindung mit |
IJavaPeerable.SetJniIdentityHashCode(Int32) |
MediaCas kann verwendet werden, um Schlüssel für das Entschlüsseln geschützter Medienströme in Verbindung mit |
IJavaPeerable.SetJniManagedPeerState(JniManagedPeerStates) |
MediaCas kann verwendet werden, um Schlüssel für das Entschlüsseln geschützter Medienströme in Verbindung mit |
IJavaPeerable.SetPeerReference(JniObjectReference) |
MediaCas kann verwendet werden, um Schlüssel für das Entschlüsseln geschützter Medienströme in Verbindung mit |
Erweiterungsmethoden
JavaCast<TResult>(IJavaObject) |
Führt eine android-laufzeitgecheckte Typkonvertierung aus. |
JavaCast<TResult>(IJavaObject) |
MediaCas kann verwendet werden, um Schlüssel für das Entschlüsseln geschützter Medienströme in Verbindung mit |
GetJniTypeName(IJavaPeerable) |
MediaCas kann verwendet werden, um Schlüssel für das Entschlüsseln geschützter Medienströme in Verbindung mit |