Foxit PDF SDK
com.foxit.sdk.pdf.SignatureCallback类 参考

Public 成员函数

int checkCertificateValidity (String cert_path, byte[] cert_password, java.lang.Object client_data)
 用于检查证书有效性的回调函数。 更多...
 
int continueCalcDigest (java.lang.Object client_data, PauseCallback pause)
 用于继续自定义摘要计算过程的回调函数。 更多...
 
byte [] getDigest (java.lang.Object client_data)
 用于在计算过程完成后获取摘要的回调函数。 更多...
 
boolean isNeedPadData ()
 用于检查在调用回调函数SignatureCallback.verifySigState 时 是否返回所有带有填充零的内容的回调函数。 更多...
 
void release ()
 用于释放当前回调对象自身的回调函数。 更多...
 
byte [] sign (byte[] digest, String cert_path, byte[] cert_password, int digest_algorithm, java.lang.Object client_data)
 用于执行签名并返回签名数据的回调函数。 更多...
 
byte [] sign (byte[] digest, StreamCallback cert_file_stream, byte[] cert_password, int digest_algorithm, java.lang.Object client_data)
 用于执行签名并返回签名数据的回调函数。 更多...
 
boolean startCalcDigest (FileReaderCallback file, int[] byte_range_array, Signature signature, java.lang.Object client_data)
 用于启动自定义摘要计算的回调函数,主要用于初始化计算过程。 更多...
 
int verifySigState (byte[] digest, byte[] signed_data, java.lang.Object client_data)
 用于验证签名完整性并返回验证状态的回调函数。 更多...
 

静态 Public 属性

static final int e_CertCannotGetPrivateKey = 7
 无法获取证书的私钥。
 
static final int e_CertDataError = 3
 证书数据错误。
 
static final int e_CertExpired = 1
 证书已过期。
 
static final int e_CertInvalidPassword = 4
 证书密码错误。
 
static final int e_CertInvalidPath = 5
 证书路径错误。
 
static final int e_CertNotSet = 6
 证书未设置为签名。
 
static final int e_CertUnsupportType = 2
 证书是不支持的类型。
 
static final int e_CertValid = 0
 证书有效。
 

详细描述

此类表示用于签名或验证签名的回调对象。 此类中的所有纯虚函数都用作回调函数,应由用户实现, 以便以自定义方式签名或验证签名。
用户可以通过函数common.Library.registerSignatureCallback 将自定义签名回调对象注册到Foxit PDF SDK,使用过滤器和子过滤器作为回调名称。

参见
com.foxit.sdk.common.Library

成员函数说明

◆ checkCertificateValidity()

int com.foxit.sdk.pdf.SignatureCallback.checkCertificateValidity ( String  cert_path,
byte []  cert_password,
java.lang.Object  client_data 
)

用于检查证书有效性的回调函数。

当调用函数Signature.startSign 时会触发此回调函数。 如果不需要检查证书,可以直接返回值com.foxit.sdk.pdf.SignatureCallback.e_CertValid

参数
[in]cert_path将用于签名的证书文件的完整路径(包括文件名和扩展名)。 这是用户从函数Signature.startSign 传递的。
[in]cert_password用于打开证书文件的密码字符串。如果这是空字符串, 表示不需要密码。这是用户从函数Signature.startSign 传递的。
[in]client_data用户定义的对象,由用户从函数Signature.startSign 传递。
返回
证书有效性。请参考从com.foxit.sdk.pdf.SignatureCallback.e_CertValid 开始的值, 应为这些值中的一个。

◆ continueCalcDigest()

int com.foxit.sdk.pdf.SignatureCallback.continueCalcDigest ( java.lang.Object  client_data,
PauseCallback  pause 
)

用于继续自定义摘要计算过程的回调函数。

参数
[in]pause决定计算过程是否需要暂停的暂停对象。 如果为null,表示在计算过程中不暂停。 如果不为null,请检查此输入参数的 函数NeedToPauseNow()的返回值,并决定何时暂停计算过程。
[in]client_data用户定义的对象,由用户从函数 Signature.startSign Signature.startVerify 传递。
返回
com.foxit.sdk.common.Progressive.e_Finished 表示计算过程已成功完成。
com.foxit.sdk.common.Progressive.e_ToBeContinued 表示计算过程尚未完成, 将再次触发回调函数 SignatureCallback.continueCalcDigest 以继续该过程。
com.foxit.sdk.common.Progressive.e_Error 表示发生任何错误。

◆ getDigest()

DX_BYTE_ARRAY com.foxit.sdk.pdf.SignatureCallback.getDigest ( java.lang.Object  client_data)

用于在计算过程完成后获取摘要的回调函数。

当计算过程成功完成时,将触发此回调函数。

参数
[in]client_data用户定义的对象,由用户从函数 Signature.startSign Signature.startVerify 传递。
返回
摘要字符串。 如果出现任何错误,请返回空字符串。

◆ isNeedPadData()

boolean com.foxit.sdk.pdf.SignatureCallback.isNeedPadData ( )

用于检查在调用回调函数SignatureCallback.verifySigState 时 是否返回所有带有填充零的内容的回调函数。

返回
true表示返回内容流中的所有数据(包括填充零), false表示返回流末尾不带填充零的内容数据。

◆ release()

void com.foxit.sdk.pdf.SignatureCallback.release ( )

用于释放当前回调对象自身的回调函数。

返回
None.

◆ sign() [1/2]

DX_BYTE_ARRAY com.foxit.sdk.pdf.SignatureCallback.sign ( byte []  digest,
String  cert_path,
byte []  cert_password,
int  digest_algorithm,
java.lang.Object  client_data 
)

用于执行签名并返回签名数据的回调函数。

宿主应用程序为自定义签名机制提供此回调函数。 此回调函数将在签名过程中被触发。

参数
[in]digest要签名的源文件缓冲区的摘要数据缓冲区。
[in]cert_path将用于签名的证书文件路径。
[in]cert_password用于打开证书文件的密码字符串。如果这是空字符串, 表示不需要密码。
[in]digest_algorithm签名数据的消息摘要算法。请参考从com.foxit.sdk.pdf.Signature.e_DigestSHA1 开始的值, 这将是这些值中的一个。
[in]client_data用户定义的对象,由用户从函数 Signature.startSign Signature.startVerify 传递。
返回
签名数据。如果出现任何错误,请返回空字符串。
返回的签名数据长度应在默认签名内容长度范围内, 默认长度为7942,或在签名未签名的签名之前通过函数Signature.setDefaultContentsLength 指定的长度。

◆ sign() [2/2]

DX_BYTE_ARRAY com.foxit.sdk.pdf.SignatureCallback.sign ( byte []  digest,
StreamCallback  cert_file_stream,
byte []  cert_password,
int  digest_algorithm,
java.lang.Object  client_data 
)

用于执行签名并返回签名数据的回调函数。

宿主应用程序为自定义签名机制提供此回调函数。 此回调函数将在签名过程中被触发。

参数
[in]digest要签名的源文件缓冲区的摘要数据缓冲区。
[in]cert_file_stream用户实现的com.foxit.sdk.common.fxcrt.StreamCallback 对象, 用于访问将用于签名的证书文件内容。
[in]cert_password用于打开证书文件的密码字符串。如果这是空字符串, 表示不需要密码。
[in]digest_algorithm签名数据的消息摘要算法。请参考从com.foxit.sdk.pdf.Signature.e_DigestSHA1 开始的值, 这将是这些值中的一个。
[in]client_data用户定义的对象,由用户从函数 Signature.startSign Signature.startVerify 传递。
返回
签名数据。如果出现任何错误,请返回空字符串。
返回的签名数据长度应在默认签名内容长度范围内, 默认长度为7942,或在签名未签名的签名之前通过函数Signature.setDefaultContentsLength 指定的长度。

◆ startCalcDigest()

boolean com.foxit.sdk.pdf.SignatureCallback.startCalcDigest ( FileReaderCallback  file,
int []  byte_range_array,
Signature  signature,
java.lang.Object  client_data 
)

用于启动自定义摘要计算的回调函数,主要用于初始化计算过程。

参数
[in]file签名时,这表示要签名的源文件对象。
验证签名字段时,这表示要验证的源文件对象。
[in]byte_range_array已签名文档(非源文档)的字节范围数组。
此数组中的元素总是成对的偏移-大小值,顺序为: offset,size,offset,size...
[in]signature签名对象。
[in]client_data用户定义的对象,由用户从函数 Signature.startSign Signature.startVerify 传递。
返回
true表示成功启动计算过程,然后将触发 SignatureCallback.continueCalcDigest 以继续计算过程。 false表示启动计算过程失败。

◆ verifySigState()

int com.foxit.sdk.pdf.SignatureCallback.verifySigState ( byte []  digest,
byte []  signed_data,
java.lang.Object  client_data 
)

用于验证签名完整性并返回验证状态的回调函数。

宿主应用程序为自定义签名机制提供此回调函数。 此回调函数将在签名验证过程中被触发。
从7.0版本开始,此回调函数仅用于验证签名的完整性。 有关更多详细信息,请查看有关返回值的注释。

参数
[in]digest要验证的源文件缓冲区的摘要数据缓冲区。
[in]signed_data签名数据缓冲区。
[in]client_data用户定义的对象,由用户从函数 Signature.startSign Signature.startVerify 传递。
返回
验证状态: