Freigeben über


KeyGenerator Klasse

Definition

Diese Klasse stellt die Funktionalität eines geheimen (symmetrischen) Schlüsselgenerators bereit.

[Android.Runtime.Register("javax/crypto/KeyGenerator", DoNotGenerateAcw=true)]
public class KeyGenerator : Java.Lang.Object
[<Android.Runtime.Register("javax/crypto/KeyGenerator", DoNotGenerateAcw=true)>]
type KeyGenerator = class
    inherit Object
Vererbung
KeyGenerator
Attribute

Hinweise

Diese Klasse stellt die Funktionalität eines geheimen (symmetrischen) Schlüsselgenerators bereit.

Schlüsselgeneratoren werden mit einer der getInstance Klassenmethoden dieser Klasse erstellt.

KeyGenerator-Objekte sind wiederverwendbar, d. h., nachdem ein Schlüssel generiert wurde, kann dasselbe KeyGenerator-Objekt erneut verwendet werden, um weitere Schlüssel zu generieren.

Es gibt zwei Möglichkeiten, einen Schlüssel zu generieren: in algorithmusunabhängiger Weise und auf algorithmusspezifische Weise. Der einzige Unterschied zwischen den beiden Ist die Initialisierung des Objekts:

<ul><li><b>Algorithmusunabhängige Initialisierung</b>

Alle Schlüsselgeneratoren teilen die Konzepte einer Schlüsselgröße und eine Quelle von Zufallszahlen. Es gibt eine #init(int, java.security.SecureRandom) init Methode in dieser KeyGenerator-Klasse, die diese beiden universell freigegebenen Typen von Argumenten verwendet. Es gibt auch eine, die nur ein keysize Argument akzeptiert und die SecureRandom-Implementierung des installierten Anbieters mit der höchsten Priorität als Quelle der Zufälligkeit verwendet (oder eine vom System bereitgestellte Quelle der Zufallssuche, wenn keiner der installierten Anbieter eine SecureRandom-Implementierung bereitstellt), und eine, die nur eine Quelle der Zufallssuche akzeptiert.

Da beim Aufrufen der oben genannten algorithmusunabhängigen init Methoden keine anderen Parameter angegeben werden, liegt es an dem Anbieter, was sie mit den algorithmusspezifischen Parametern (falls vorhanden) tun müssen, die den einzelnen Schlüsseln zugeordnet werden sollen.

<li><b>Algorithmusspezifische Initialisierung</b>

In Situationen, in denen bereits eine Reihe von algorithmusspezifischen Parametern vorhanden ist, gibt es zwei #init(java.security.spec.AlgorithmParameterSpec) init Methoden mit einem AlgorithmParameterSpec Argument. Eines hat auch ein SecureRandom Argument, während die andere die SecureRandom-Implementierung des installierten Anbieters mit der höchsten Priorität als Quelle der Zufälligkeit verwendet (oder eine vom System bereitgestellte Quelle der Zufallssuche, wenn keiner der installierten Anbieter eine SecureRandom-Implementierung bereitstellt). </ul>

Falls der Client den KeyGenerator (über einen Aufruf einer init Methode) nicht explizit initialisiert, muss jeder Anbieter eine Standardinitialisierung bereitstellen (und dokumentieren).

Android stellt die folgenden KeyGenerator Algorithmen bereit: <Tabelle<>thead<>tr<>th>Algorithm</th th><>Unterstützte API Levels</th<>/tr></thead<>tbody<>tr><td>AES</td td><>1+</td<>/tr<>class="deprecated"><td>AESWRAP</td td td<>>1-8</td/tr td><><><>ARC4</td td>><14+</td></tr td>BLOWFISH</td td><>10+</td<>/tr<<>>t td>ChaCha20</td<>td td>28+</td></tr>><<><<>t td>DES</td<>td>1+</td<>/tr<><>td>DESede</td><td>1+</td/>< tr>tr class="deprecated"><td>DESedeWRAP</td td>><1-8</td/tr><<>td<>> HmacMD5</td><td>1+</td></tr<><>td>HmacSHA1</td><td 11+</td></tr><><t td>HmacSHA224</td td td><>1-8,22+</td td><></tr><tr><td>HmacSHA256</td><td>1+</td></tr t td>HmacSHA384</td td><>1+</td<>/tr>><<td>HmacSHA512</td<>td>1+</td></tr><<>><class="deprecated"<>td>RC4</td><td>10-13</Td></tr></tbody></table>

Diese Algorithmen werden im KeyGenerator-Abschnitt der Java Cryptography Architecture Standard Algorithm Name Documentation beschrieben.

In 1.4 hinzugefügt.

Java-Dokumentation für javax.crypto.KeyGenerator.

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

KeyGenerator(IntPtr, JniHandleOwnership)

Ein Konstruktor, der beim Erstellen verwalteter Darstellungen von JNI-Objekten verwendet wird; wird von der Laufzeit aufgerufen.

KeyGenerator(KeyGeneratorSpi, Provider, String)

Erstellt ein KeyGenerator -Objekt.

Eigenschaften

Algorithm

Gibt den Algorithmusnamen dieses KeyGenerator Objekts zurück.

Class

Gibt die Laufzeitklasse dieses Werts Objectzurück.

(Geerbt von Object)
Handle

Das Handle für die zugrunde liegende Android-Instanz.

(Geerbt von Object)
JniIdentityHashCode

Diese Klasse stellt die Funktionalität eines geheimen (symmetrischen) Schlüsselgenerators bereit.

(Geerbt von Object)
JniPeerMembers

Diese Klasse stellt die Funktionalität eines geheimen (symmetrischen) Schlüsselgenerators bereit.

PeerReference

Diese Klasse stellt die Funktionalität eines geheimen (symmetrischen) Schlüsselgenerators bereit.

(Geerbt von Object)
Provider

Gibt den Anbieter dieses KeyGenerator Objekts zurück.

ThresholdClass

Diese API unterstützt die Mono für Android-Infrastruktur und ist nicht für die direkte Verwendung aus Ihrem Code vorgesehen.

ThresholdType

Diese API unterstützt die Mono für Android-Infrastruktur und ist nicht für die direkte Verwendung aus Ihrem Code vorgesehen.

Methoden

Clone()

Erstellt und gibt eine Kopie dieses Objekts zurück.

(Geerbt von Object)
Dispose()

Diese Klasse stellt die Funktionalität eines geheimen (symmetrischen) Schlüsselgenerators bereit.

(Geerbt von Object)
Dispose(Boolean)

Diese Klasse stellt die Funktionalität eines geheimen (symmetrischen) Schlüsselgenerators bereit.

(Geerbt von Object)
Equals(Object)

Gibt an, ob ein anderes Objekt "gleich" diesem Objekt ist.

(Geerbt von Object)
GenerateKey()

Generiert einen geheimen Schlüssel.

GetHashCode()

Gibt einen Hashcodewert für das Objekt zurück.

(Geerbt von Object)
GetInstance(String)

Gibt ein KeyGenerator Objekt zurück, das geheime Schlüssel für den angegebenen Algorithmus generiert.

GetInstance(String, Provider)

Gibt ein KeyGenerator Objekt zurück, das geheime Schlüssel für den angegebenen Algorithmus generiert.

GetInstance(String, String)

Gibt ein KeyGenerator Objekt zurück, das geheime Schlüssel für den angegebenen Algorithmus generiert.

Init(IAlgorithmParameterSpec)

Initialisiert diesen Schlüsselgenerator mit dem angegebenen Parametersatz.

Init(IAlgorithmParameterSpec, SecureRandom)

Initialisiert diesen Schlüsselgenerator mit dem angegebenen Parametersatz und einer vom Benutzer bereitgestellten Zufallsquelle.

Init(Int32)

Initialisiert diesen Schlüsselgenerator für eine bestimmte Schlüsselgröße.

Init(Int32, SecureRandom)

Initialisiert diesen Schlüsselgenerator für eine bestimmte Schlüsselgröße, wobei eine vom Benutzer bereitgestellte Zufallsquelle verwendet wird.

Init(SecureRandom)

Initialisiert diesen Schlüsselgenerator.

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)
SetHandle(IntPtr, JniHandleOwnership)

Legt die Handle-Eigenschaft fest.

(Geerbt von Object)
ToArray<T>()

Diese Klasse stellt die Funktionalität eines geheimen (symmetrischen) Schlüsselgenerators bereit.

(Geerbt von Object)
ToString()

Gibt eine Zeichenfolgendarstellung des Objekts zurück.

(Geerbt von Object)
UnregisterFromRuntime()

Diese Klasse stellt die Funktionalität eines geheimen (symmetrischen) Schlüsselgenerators bereit.

(Geerbt von Object)
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()

Diese Klasse stellt die Funktionalität eines geheimen (symmetrischen) Schlüsselgenerators bereit.

(Geerbt von Object)
IJavaPeerable.DisposeUnlessReferenced()

Diese Klasse stellt die Funktionalität eines geheimen (symmetrischen) Schlüsselgenerators bereit.

(Geerbt von Object)
IJavaPeerable.Finalized()

Diese Klasse stellt die Funktionalität eines geheimen (symmetrischen) Schlüsselgenerators bereit.

(Geerbt von Object)
IJavaPeerable.JniManagedPeerState

Diese Klasse stellt die Funktionalität eines geheimen (symmetrischen) Schlüsselgenerators bereit.

(Geerbt von Object)
IJavaPeerable.SetJniIdentityHashCode(Int32)

Diese Klasse stellt die Funktionalität eines geheimen (symmetrischen) Schlüsselgenerators bereit.

(Geerbt von Object)
IJavaPeerable.SetJniManagedPeerState(JniManagedPeerStates)

Diese Klasse stellt die Funktionalität eines geheimen (symmetrischen) Schlüsselgenerators bereit.

(Geerbt von Object)
IJavaPeerable.SetPeerReference(JniObjectReference)

Diese Klasse stellt die Funktionalität eines geheimen (symmetrischen) Schlüsselgenerators bereit.

(Geerbt von Object)

Erweiterungsmethoden

JavaCast<TResult>(IJavaObject)

Führt eine android-laufzeitgecheckte Typkonvertierung aus.

JavaCast<TResult>(IJavaObject)

Diese Klasse stellt die Funktionalität eines geheimen (symmetrischen) Schlüsselgenerators bereit.

GetJniTypeName(IJavaPeerable)

Diese Klasse stellt die Funktionalität eines geheimen (symmetrischen) Schlüsselgenerators bereit.

Gilt für: