PBEKeySpec 类
定义
重要
一些信息与预发行产品相关,相应产品在发行之前可能会进行重大修改。 对于此处提供的信息,Microsoft 不作任何明示或暗示的担保。
用户选择的密码,可用于基于密码的加密 (PBE) 。
[Android.Runtime.Register("javax/crypto/spec/PBEKeySpec", DoNotGenerateAcw=true)]
public class PBEKeySpec : Java.Lang.Object, IDisposable, Java.Interop.IJavaPeerable, Java.Security.Spec.IKeySpec
[<Android.Runtime.Register("javax/crypto/spec/PBEKeySpec", DoNotGenerateAcw=true)>]
type PBEKeySpec = class
inherit Object
interface IKeySpec
interface IJavaObject
interface IDisposable
interface IJavaPeerable
- 继承
- 属性
- 实现
注解
用户选择的密码,可用于基于密码的加密 (PBE) 。
可以将密码视为某种原始密钥材料,使用它的加密机制从中派生加密密钥。
不同的 PBE 机制可能会使用每个密码字符的不同位。 例如, PKCS #5 中定义的 PBE 机制仅查看每个字符的低位 8 位,而 PKCS #12 则查看每个字符的所有 16 位。
通过创建相应密钥工厂的实例,将密码字符转换为 PBE 密钥。 例如,PKCS #5 的密钥工厂仅从每个密码字符的低位 8 位构造 PBE 密钥,而 PKCS #12 的密钥工厂将采用每个字符的所有 16 位。
另请注意,此类将密码存储为 char 数组而不是 String
对象 (这看起来更具有逻辑) ,因为 String 类是不可变的,当不再需要存储在其中的密码时,无法覆盖其内部值。 因此,此类以 char 数组的形式请求密码,因此可以在完成后将其覆盖。
在 1.4 中添加。
的 javax.crypto.spec.PBEKeySpec
Java 文档。
此页面的某些部分是基于 创建和共享的工作进行的修改,并根据 署名许可中所述的条款使用。
构造函数
PBEKeySpec(Char[]) |
采用密码的构造函数。 |
PBEKeySpec(Char[], Byte[], Int32) |
采用密码、salt、迭代计数的构造函数,用于生成固定键大小 PBE 密码的 PBEKey。 |
PBEKeySpec(Char[], Byte[], Int32, Int32) |
采用密码、salt、迭代计数和要派生的密钥长度的构造函数,用于生成可变键大小 PBE 密码的 PBEKey。 |
PBEKeySpec(IntPtr, JniHandleOwnership) |
创建 JNI 对象的托管表示形式时使用的构造函数;由运行时调用。 |
属性
Class |
返回此 |
Handle |
基础 Android 实例的句柄。 (继承自 Object) |
IterationCount |
返回迭代计数,如果未指定,则返回 0。 |
JniIdentityHashCode |
用户选择的密码,可用于基于密码的加密 (PBE) 。 (继承自 Object) |
JniPeerMembers |
用户选择的密码,可用于基于密码的加密 (PBE) 。 |
KeyLength |
返回要派生的密钥长度,如果未指定,则返回 0。 |
PeerReference |
用户选择的密码,可用于基于密码的加密 (PBE) 。 (继承自 Object) |
ThresholdClass |
此 API 支持 Mono for Android 基础结构,不应直接从代码中使用。 |
ThresholdType |
此 API 支持 Mono for Android 基础结构,不应直接从代码中使用。 |
方法
ClearPassword() |
清除密码的内部副本。 |
Clone() |
创建并返回此对象的副本。 (继承自 Object) |
Dispose() |
用户选择的密码,可用于基于密码的加密 (PBE) 。 (继承自 Object) |
Dispose(Boolean) |
用户选择的密码,可用于基于密码的加密 (PBE) 。 (继承自 Object) |
Equals(Object) |
指示某个其他对象是否“等于”此对象。 (继承自 Object) |
GetHashCode() |
返回对象的哈希代码值。 (继承自 Object) |
GetPassword() |
返回密码的副本。 |
GetSalt() |
如果未指定,则返回 salt 或 null 的副本。 |
JavaFinalize() |
当垃圾回收确定不再引用对象时,由垃圾回收器对对象调用。 (继承自 Object) |
Notify() |
唤醒正在等待此对象的监视器的单个线程。 (继承自 Object) |
NotifyAll() |
唤醒正在等待此对象的监视器的所有线程。 (继承自 Object) |
SetHandle(IntPtr, JniHandleOwnership) |
设置 Handle 属性。 (继承自 Object) |
ToArray<T>() |
用户选择的密码,可用于基于密码的加密 (PBE) 。 (继承自 Object) |
ToString() |
返回对象的字符串表示形式。 (继承自 Object) |
UnregisterFromRuntime() |
用户选择的密码,可用于基于密码的加密 (PBE) 。 (继承自 Object) |
Wait() |
导致当前线程等待,直到它被唤醒,通常是通过 em <通知/em> 或 <em>interrupted</em>。<> (继承自 Object) |
Wait(Int64) |
导致当前线程等待,直到它被唤醒,通常是通过 em <通知/em> 或 <em>interrupted</em>,或直到经过一定数量的实时。<> (继承自 Object) |
Wait(Int64, Int32) |
导致当前线程等待,直到它被唤醒,通常是通过 em <通知/em> 或 <em>interrupted</em>,或直到经过一定数量的实时。<> (继承自 Object) |
显式接口实现
IJavaPeerable.Disposed() |
用户选择的密码,可用于基于密码的加密 (PBE) 。 (继承自 Object) |
IJavaPeerable.DisposeUnlessReferenced() |
用户选择的密码,可用于基于密码的加密 (PBE) 。 (继承自 Object) |
IJavaPeerable.Finalized() |
用户选择的密码,可用于基于密码的加密 (PBE) 。 (继承自 Object) |
IJavaPeerable.JniManagedPeerState |
用户选择的密码,可用于基于密码的加密 (PBE) 。 (继承自 Object) |
IJavaPeerable.SetJniIdentityHashCode(Int32) |
用户选择的密码,可用于基于密码的加密 (PBE) 。 (继承自 Object) |
IJavaPeerable.SetJniManagedPeerState(JniManagedPeerStates) |
用户选择的密码,可用于基于密码的加密 (PBE) 。 (继承自 Object) |
IJavaPeerable.SetPeerReference(JniObjectReference) |
用户选择的密码,可用于基于密码的加密 (PBE) 。 (继承自 Object) |
扩展方法
JavaCast<TResult>(IJavaObject) |
执行 Android 运行时检查的类型转换。 |
JavaCast<TResult>(IJavaObject) |
用户选择的密码,可用于基于密码的加密 (PBE) 。 |
GetJniTypeName(IJavaPeerable) |
用户选择的密码,可用于基于密码的加密 (PBE) 。 |