共用方式為


StrongNameSignatureGenerationEx 函式

依據指定的旗標為指定組件產生的強式名稱簽章。

此函式已被取代。 請改用 ICLRStrongName::StrongNameSignatureGenerationEx 方法。

語法

BOOLEAN StrongNameSignatureGenerationEx (  
    [in]  LPCWSTR   wszFilePath,  
    [in]  LPCWSTR   wszKeyContainer,  
    [in]  BYTE      *pbKeyBlob,  
    [in]  ULONG     cbKeyBlob,  
    [out] BYTE      **ppbSignatureBlob,  
    [out] ULONG     *pcbSignatureBlob,  
    [in]  DWORD     dwFlags  
);  

參數

wszFilePath
[in] 檔案的路徑,其中包含將產生強式名稱簽章之組件的資訊清單。

wszKeyContainer
[in] 包含公開/私密金鑰組的金鑰容器名稱。

如果 pbKeyBlob 為 null,則 wszKeyContainer 必須在密碼編譯服務提供者 (CSP) 內指定有效的容器。 在此情況下,儲存在容器中的金鑰組會用來簽署檔案。

如果 pbKeyBlob 不是 null,則會假設金鑰組包含在金鑰二進位大型物件中 (BLOB)。

pbKeyBlob
[in] 公開/私密金鑰組的指標。 此金鑰組的格式由 Win32 CryptExportKey 函式建立。 如果 pbKeyBlob 為 null,可假設 wszKeyContainer 指定的金鑰容器包含金鑰組。

cbKeyBlob
[in] pbKeyBlob 的大小,單位是位元組。

ppbSignatureBlob
[out] 通用語言執行平台傳回簽章所在位置的指標。 如果 ppbSignatureBlob 為 null,則執行階段會將簽章儲存在 wszFilePath 所指定的檔案中。

如果 ppbSignatureBlob 不是 null,通用語言執行平台會配置用來傳回簽章的空間。 呼叫端必須使用 StrongNameFreeBuffer 函式釋放此空間。

pcbSignatureBlob
[out] 傳回簽章的大小 (以位元組為單位)。

dwFlags
[in] 指定下列一或多個值:

  • SN_SIGN_ALL_FILES (0x00000001):重新計算連結模組的所有雜湊。

  • SN_TEST_SIGN (0x00000002):測試簽署組件。

傳回值

如果成功編譯則為 true,否則為 false

備註

針對 wszFilePath 指定 null 來計算簽章的大小,而不需建立簽章。

簽章可以直接儲存在檔案中,或傳回給呼叫端。

如果 SN_SIGN_ALL_FILES 已指定,但未同時包含公開金鑰 (pbKeyBlobwszFilePath 為 null),則會重新計算連結模組的雜湊,但組件不會重新簽署。

如果 SN_TEST_SIGN 已指定 ,則不會修改通用語言執行平台標頭,表示組件是以強式名稱簽署。

如果 StrongNameSignatureGenerationEx 函式未順利完成,請呼叫 StrongNameErrorInfo 函式來擷取最後產生的錯誤。

規格需求

平台:請參閱系統需求

標頭:StrongName.h

程式庫:包含作為 MSCorEE.dll 中的資源

.NET Framework版本:自 1.0 起提供

另請參閱