Encrypting and Decrypting PDF Documents
CREATED FOR:
- Developer
About the Encryption Service
The Encryption service lets you encrypt and decrypt documents. When a document is encrypted, its contents become unreadable. An authorized user can decrypt the document to obtain access to the contents. If a PDF document is encrypted with a password, the user must specify the open password before the document can be viewed in Adobe Reader or Adobe Acrobat. Likewise, if a PDF document is encrypted with a certificate, the user must decrypt the PDF document with the public key that corresponds to the certificate (private key) that was used to encrypt the PDF document.
You can accomplish these tasks using the Encryption service:
-
Encrypt a PDF document with a password. (See Encrypting PDF Documents with a Password.)
-
Encrypt a PDF document with a certificate. (See Encrypting PDF Documents with Certificates.)
-
Remove password-based encryption from a PDF document. (See Removing Password Encryption.)
-
Remove certificate-based encryption from a PDF document. (See Removing Certificate Based Encryption.)
-
Unlock the PDF document so that other service operations can be performed. For example, after a password-encrypted PDF document is unlocked, you can apply a digital signature to it. (See Unlocking Encrypted PDF Documents.)
-
Determine the encryption type of a secured PDF document. (See Determining Encryption Type.)
NOTEFor more information about the Encryption service, see Services Reference for AEM Forms.
Encrypting PDF Documents with a Password
When you encrypt a PDF document with a password, a user must specify the password to open the PDF document in Adobe Reader or Acrobat. Also, before another AEM Forms operation, such as digitally signing the PDF document, can be performed on the document, a password-encrypted PDF document must be unlocked.
Summary of steps
To encrypt a PDF document with a password, perform the following steps:
- Include project files.
- Create an Encryption Client API object.
- Get a PDF document to encrypt.
- Set encryption run-time options.
- Add the password.
- Save the encrypted PDF document as a PDF file.
Include project files
Include necessary files in your development project. If you are creating a client application using Java, include the necessary JAR files. If you are using web services, ensure that you include the proxy files.
The following JAR files must be added to your project’s class path:
- adobe-livecycle-client.jar
- adobe-usermanager-client.jar
- adobe-encryption-client.jar
- adobe-utilities.jar (required if AEM Forms is deployed on JBoss)
- jbossall-client.jar (required if AEM Forms is deployed on JBoss)
Create an Encryption Client API object
To programmatically perform an Encryption service operation, you must create an Encryption service client.
Get a PDF document to encrypt
You must obtain an unencrypted PDF document to encrypt the document with a password. If you attempt to secure a PDF document that is already encrypted, you cause an exception.
Set encryption run-time options
To encrypt a PDF document with a password, you specify four values, including two password values. The first password value is used to encrypt the PDF document and must be specified when opening the PDF document. The second password value, named the master password value, is used to remove encryption from the PDF document. Password values are case sensitive, and these two password values cannot be the same values.
You must specify the PDF document resources to encrypt. You can encrypt the entire PDF document, everything except for the document’s metadata, or just the document’s attachments. If you encrypt only the document’s attachments, a user is prompted for a password when they attempt to access the file attachments.
When encrypting a PDF document, you can specify permissions that are associated with the secured document. By specifying permissions, you can control the actions that a user who opens a password-encrypted PDF document is allowed to perform. For example to successfully extract form data, you must set the following permissions:
- PASSWORD_EDIT_ADD
- PASSWORD_EDIT_MODIFY
PasswordEncryptionPermission
enumeration values.Add the password
After you retrieve an unsecured PDF document and set encryption run-time values, you can add a password to the PDF document.
Save the encrypted PDF document as a PDF file
You can save the password-encrypted PDF document as a PDF file.
See also
Encrypt a PDF document using the Java API
Encrypting a PDF document using the web service API
Including AEM Forms Java library files
Encryption Service API Quick Starts
Encrypting PDF Documents with Certificates
Encrypt a PDF document using the Java API
Encrypt a PDF document with a password by using the Encryption API (Java):
-
Include project files.
Include client JAR files, such as adobe-encryption-client.jar, in your Java project’s class path.
-
Create an Encryption Client API.
- Create a
ServiceClientFactory
object that contains connection properties. - Create an
EncryptionServiceClient
object by using its constructor and passing theServiceClientFactory
object.
- Create a
-
Get a PDF document to encrypt.
- Create a
java.io.FileInputStream
object that represents the PDF document to encrypt by using its constructor and passing a string value that specifies the location of the PDF document. - Create a
com.adobe.idp.Document
object by using its constructor and passing thejava.io.FileInputStream
object.
- Create a
-
Set encryption run-time options.
- Create a
PasswordEncryptionOptionSpec
object by invoking its constructor. - Specify the PDF document resources to encrypt by invoking the
PasswordEncryptionOptionSpec
object’ssetEncryptOption
method and passing aPasswordEncryptionOption
enumeration value that specifies the document resources to encrypt. For example, to encrypt the entire PDF document, including its metadata and its attachments, specifyPasswordEncryptionOption.ALL
. - Create a
java.util.List
object that stores the encryption permissions by using theArrayList
constructor. - Specify a permission by invoking the
java.util.List
object ‘sadd
method and passing an enumeration value that corresponds to the permission that you want to set. For example, to set the permission that lets a user copy data located in the PDF document, specifyPasswordEncryptionPermission.PASSWORD_EDIT_COPY
. (Repeat this step for each permission to set). - Specify the Acrobat compatibility option by invoking the
PasswordEncryptionOptionSpec
object’ssetCompatability
method and passing an enumeration value that specifies the Acrobat compatibility level. For example, you can specifyPasswordEncryptionCompatability.ACRO_7
. - Specify the password value that lets a user open the encrypted PDF document by invoking the
PasswordEncryptionOptionSpec
object’ssetDocumentOpenPassword
method and passing a string value that represents the open password. - Specify the master password value that lets a user remove encryption from the PDF document by invoking the
PasswordEncryptionOptionSpec
object’ssetPermissionPassword
method and passing a string value that represents the master password.
- Create a
-
Add the password.
Encrypt the PDF document by invoking the
EncryptionServiceClient
object’sencryptPDFUsingPassword
method and passing the following values:- The
com.adobe.idp.Document
object that contains the PDF document to encrypt with the password. - The
PasswordEncryptionOptionSpec
object that contains encryption run-time options.
The
encryptPDFUsingPassword
method returns acom.adobe.idp.Document
object that contains a password-encrypted PDF document. - The
-
Save the encrypted PDF document as a PDF file.
- Create a
java.io.File
object and ensure that the file extension is .pdf. - Invoke the
com.adobe.idp.Document
object’scopyToFile
method to copy the contents of thecom.adobe.idp.Document
object to the file. Ensure that you use thecom.adobe.idp.Document
object that was returned by theencryptPDFUsingPassword
method.
- Create a
See also
Quick Start (SOAP mode): Encrypting a PDF document using the Java API
Including AEM Forms Java library files
Encrypting a PDF document using the web service API
Encrypt a PDF document with a password by using the Encryption API (web service):
-
Include project files.
Create a Microsoft .NET project that uses MTOM. Ensure that you use the following WSDL definition:
http://localhost:8080/soap/services/EncryptionService?WSDL&lc_version=9.0.1
.NOTEReplacelocalhost
with the IP address of the server hosting AEM Forms. -
Create an Encryption Client API object.
-
Create an
EncryptionServiceClient
object by using its default constructor. -
Create an
EncryptionServiceClient.Endpoint.Address
object by using theSystem.ServiceModel.EndpointAddress
constructor. Pass a string value that specifies the WSDL to the AEM Forms service (for example,http://localhost:8080/soap/services/EncryptionService?WSDL
.) You do not need to use thelc_version
attribute. This attribute is used when you create a service reference.) -
Create a
System.ServiceModel.BasicHttpBinding
object by getting the value of theEncryptionServiceClient.Endpoint.Binding
field. Cast the return value toBasicHttpBinding
. -
Set the
System.ServiceModel.BasicHttpBinding
object’sMessageEncoding
field toWSMessageEncoding.Mtom
. This value ensures that MTOM is used. -
Enable basic HTTP authentication by performing the following tasks:
- Assign the AEM forms user name to the field
EncryptionServiceClient.ClientCredentials.UserName.UserName
. - Assign the corresponding password value to the field
EncryptionServiceClient.ClientCredentials.UserName.Password
. - Assign the constant value
HttpClientCredentialType.Basic
to the fieldBasicHttpBindingSecurity.Transport.ClientCredentialType
. - Assign the constant value
BasicHttpSecurityMode.TransportCredentialOnly
to the fieldBasicHttpBindingSecurity.Security.Mode
.
- Assign the AEM forms user name to the field
-
-
Get a PDF document to encrypt.
- Create a
BLOB
object by using its constructor. TheBLOB
object is used to store a PDF document that is encrypted with a password. - Create a
System.IO.FileStream
object by invoking its constructor and passing a string value that represents the file location of the PDF document to encrypt and the mode in which to open the file. - Create a byte array that stores the content of the
System.IO.FileStream
object. You can determine the size of the byte array by getting theSystem.IO.FileStream
object’sLength
property. - Populate the byte array with stream data by invoking the
System.IO.FileStream
object’sRead
method and passing the byte array, the starting position, and the stream length to read. - Populate the
BLOB
object by assigning the contents of the byte array to theBLOB
object’sMTOM
data member.
- Create a
-
Set encryption run-time options.
- Create a
PasswordEncryptionOptionSpec
object by using its constructor. - Specify the PDF document resources to encrypt by assigning a
PasswordEncryptionOption
enumeration value to thePasswordEncryptionOptionSpec
object’sencryptOption
data member. To encrypt the entire PDF, including its metadata and its attachments, assignPasswordEncryptionOption.ALL
to this data member. - Specify the Acrobat compatibility option by assigning a
PasswordEncryptionCompatability
enumeration value to thePasswordEncryptionOptionSpec
object’scompatability
data member. For example, assignPasswordEncryptionCompatability.ACRO_7
to this data member. - Specify the password value that lets a user open the encrypted PDF document by assigning a string value that represents the open password to the
PasswordEncryptionOptionSpec
object’sdocumentOpenPassword
data member. - Specify the password value that lets a user remove encryption from the PDF document by assigning a string value that represents the master password to the
PasswordEncryptionOptionSpec
object’spermissionPassword
data member.
- Create a
-
Add the password.
Encrypt the PDF document by invoking the
EncryptionServiceClient
object’sencryptPDFUsingPassword
method and passing the following values:- The
BLOB
object that contains the PDF document to encrypt with the password. - The
PasswordEncryptionOptionSpec
object that contains encryption run-time options.
The
encryptPDFUsingPassword
method returns aBLOB
object that contains a password-encrypted PDF document. - The
-
Save the encrypted PDF document as a PDF file.
- Create a
System.IO.FileStream
object by invoking its constructor and passing a string value that represents the file location of the secured PDF document. - Create a byte array that stores the data content of the
BLOB
object that was returned by theencryptPDFUsingPassword
method. Populate the byte array by getting the value of theBLOB
object’sMTOM
data member. - Create a
System.IO.BinaryWriter
object by invoking its constructor and passing theSystem.IO.FileStream
object. - Write the contents of the byte array to a PDF file by invoking the
System.IO.BinaryWriter
object’sWrite
method and passing the byte array.
- Create a
See also
Invoking AEM Forms using SwaRef
Encrypting PDF Documents with Certificates
Certificate-based encryption lets you encrypt a document for specific recipients by means of public key technology. Various recipients can be given different permissions for the document. Many aspects of encryption are made possible by public key technology. An algorithm is used to generate two large numbers, known as keys, that have the following properties:
- One key is used to encrypt a set of data. Subsequently, only the other key can be used to decrypt the data.
- It is impossible to distinguish one key from the other.
One of the keys acts as a user’s private key. It is important that only the user has access to this key. The other key is the user’s public key, which can be shared with others.
A public key certificate contains a user’s public key and identifying information. The X.509 format is used for storing certificates. Certificates are typically issued and digitally signed by a certificate authority (CA), which is a recognized entity that provides a measure of confidence in the validity of the certificate. Certificates have an expiration date, after which they are no longer valid. In addition, certificate revocation lists (CRLs) provide information about certificates that were revoked prior to their expiration date. CRLs are published periodically by certificate authorities. The revocation status of a certificate can also be retrieved through Online Certificate Status Protocol (OCSP) over the network.
Summary of steps
To encrypt a PDF document with a certificate, perform the following steps:
- Include project files.
- Create an Encryption Client API object.
- Get a PDF document to encrypt.
- Reference the certificate.
- Set encryption run-time options.
- Create a certificate-encrypted PDF document.
- Save the encrypted PDF document as a PDF file.
Include project files
Include the necessary files in your development project. If you are creating a client application by using Java, include the necessary JAR files. If you are using web services, ensure that you include the proxy files.
The following JAR files must be added to your project’s class path:
- adobe-livecycle-client.jar
- adobe-usermanager-client.jar
- adobe-encryption-client.jar
- adobe-utilities.jar (required if AEM Forms is deployed on JBoss Application Server)
- jbossall-client.jar (required if AEM Forms is deployed on JBoss Application Server)
Create an Encryption Client API object
To programmatically perform an Encryption service operation, you must create an Encryption service client. If you are using the Java Encryption Service API, create an EncrytionServiceClient
object. If you are using the web service Encryption Service API, create an EncryptionServiceService
object.
Get a PDF document to encrypt
You must obtain an unencrypted PDF document to encrypt. If you attempt to secure a PDF document that is already encrypted, an exception is thrown.
Reference the certificate
To encrypt a PDF document with a certificate, reference a certificate that is used to encrypt a PDF document. The certificate is a .cer file, a .crt file, or a .pem file. A PKCS#12 file is used to store private keys with corresponding certificates.
When encrypting a PDF document with a certificate, specify permissions that are associated with the secured document. By specifying permissions, you can control the actions that a user who opens a certificate-encrypted PDF document can perform.
Set encryption run-time options
Specify the PDF document resources to encrypt. You can encrypt the entire PDF document, everything except the document’s metadata, or only the document’s attachments.
Create a certificate-encrypted PDF document
After you retrieve an unsecured PDF document, reference the certificate, and set run-time options, you can create a certificate-encrypted PDF document. After the PDF document is encrypted, you need the corresponding public key to decrypt it.
Save the encrypted PDF document as a PDF file
You can save the encrypted PDF document as a PDF file.
See also
Encrypt a PDF document with a certificate using the Java API
Encrypt a PDF document with a certificate using the web service API
Including AEM Forms Java library files
Encryption Service API Quick Starts
Encrypting PDF Documents with a Password
Encrypt a PDF document with a certificate using the Java API
Encrypt a PDF document with a certificate by using the Encryption API (Java):
-
Include project files.
Include client JAR files, such as adobe-encryption-client.jar, in your Java project’s class path.
-
Create an Encryption Client API object.
- Create a
ServiceClientFactory
object that contains connection properties. - Create an
EncryptionServiceClient
object by using its constructor and passing theServiceClientFactory
object.
- Create a
-
Get a PDF document to encrypt.
- Create a
java.io.FileInputStream
object that represents the PDF document to encrypt by using its constructor and passing a string value that specifies the location of the PDF document. - Create a
com.adobe.idp.Document
object by using its constructor and passing thejava.io.FileInputStream
object.
- Create a
-
Reference the certificate.
- Create a
java.util.List
object that stores permission information by using its constructor. - Specify the permission associated with the encrypted document by invoking the
java.util.List
object’sadd
method and passing aCertificateEncryptionPermissions
enumeration value that represents the permissions that are granted to the user who opens the secured PDF document. For example, to specify all permissions, passCertificateEncryptionPermissions.PKI_ALL_PERM
. - Create a
Recipient
object by using its constructor. - Create a
java.io.FileInputStream
object that represents the certificate that is used to encrypt the PDF document by using its constructor and passing a string value that specifies the location of the certificate. - Create a
com.adobe.idp.Document
object by using its constructor and passing thejava.io.FileInputStream
object that represents the certificate. - Invoke the
Recipient
object’ssetX509Cert
method and pass thecom.adobe.idp.Document
object that contains the certificate. (In addition, theRecipient
object can have a Truststore certificate alias or LDAP URL as a certificate source.) - Create a
CertificateEncryptionIdentity
object that stores permission and certificate information by using its constructor. - Invoke the
CertificateEncryptionIdentity
object’ssetPerms
method and pass thejava.util.List
object that stores permission information. - Invoke the
CertificateEncryptionIdentity
object’ssetRecipient
method and pass theRecipient
object that stores certificate information. - Create a
java.util.List
object that stores certificate information by using its constructor. - Invoke the
java.util.List
object’s add method and pass theCertificateEncryptionIdentity
object. (Thisjava.util.List
object is passed as a parameter to theencryptPDFUsingCertificates
method.)
- Create a
-
Set encryption run-time options.
- Create a
CertificateEncryptionOptionSpec
object by invoking its constructor. - Specify the PDF document resources to encrypt by invoking the
CertificateEncryptionOptionSpec
object’ssetOption
method and passing aCertificateEncryptionOption
enumeration value that specifies the document resources to encrypt. For example, to encrypt the entire PDF document, including its metadata and its attachments, specifyCertificateEncryptionOption.ALL
. - Specify the Acrobat compatibility option by invoking the
CertificateEncryptionOptionSpec
object’ssetCompat
method and passing aCertificateEncryptionCompatibility
enumeration value that specifies the Acrobat compatibility level. For example, you can specifyCertificateEncryptionCompatibility.ACRO_7
.
- Create a
-
Create a certificate-encrypted PDF document.
Encrypt the PDF document with a certificate by invoking the
EncryptionServiceClient
object’sencryptPDFUsingCertificates
method and passing the following values:- The
com.adobe.idp.Document
object that contains the PDF document to encrypt. - The
java.util.List
object that stores certificate information. - The
CertificateEncryptionOptionSpec
object that contains encryption run-time options.
The
encryptPDFUsingCertificates
method returns acom.adobe.idp.Document
object that contains a certificate-encrypted PDF document. - The
-
Save the encrypted PDF document as a PDF file.
- Create a
java.io.File
object and ensure that the file name extension is .pdf. - Invoke the
com.adobe.idp.Document
object’scopyToFile
method to copy the contents of thecom.adobe.idp.Document
object to the file. Ensure that you use thecom.adobe.idp.Document
object that was returned by theencryptPDFUsingCertificates
method.
- Create a
See also
Quick Start (SOAP mode): Encrypting a PDF document with a certificate using the Java API
Including AEM Forms Java library files
Encrypt a PDF document with a certificate using the web service API
Encrypt a PDF document with a certificate by using the Encryption API (web service):
-
Include project files.
Create a Microsoft .NET project that uses MTOM. Ensure that you use the following WSDL definition:
http://localhost:8080/soap/services/EncryptionService?WSDL&lc_version=9.0.1
.NOTEReplacelocalhost
with the IP address of the server hosting AEM Forms. -
Create an Encryption Client API object.
-
Create an
EncryptionServiceClient
object by using its default constructor. -
Create an
EncryptionServiceClient.Endpoint.Address
object by using theSystem.ServiceModel.EndpointAddress
constructor. Pass a string value that specifies the WSDL to the AEM Forms service (for example,http://localhost:8080/soap/services/EncryptionService?WSDL
.) You do not need to use thelc_version
attribute. This attribute is used when you create a service reference.) -
Create a
System.ServiceModel.BasicHttpBinding
object by getting the value of theEncryptionServiceClient.Endpoint.Binding
field. Cast the return value toBasicHttpBinding
. -
Set the
System.ServiceModel.BasicHttpBinding
object’sMessageEncoding
field toWSMessageEncoding.Mtom
. This value ensures that MTOM is used. -
Enable basic HTTP authentication by performing the following tasks:
- Assign the AEM forms user name to the field
EncryptionServiceClient.ClientCredentials.UserName.UserName
. - Assign the corresponding password value to the field
EncryptionServiceClient.ClientCredentials.UserName.Password
. - Assign the constant value
HttpClientCredentialType.Basic
to the fieldBasicHttpBindingSecurity.Transport.ClientCredentialType
. - Assign the constant value
BasicHttpSecurityMode.TransportCredentialOnly
to the fieldBasicHttpBindingSecurity.Security.Mode
.
- Assign the AEM forms user name to the field
-
-
Get a PDF document to encrypt.
- Create a
BLOB
object by using its constructor. TheBLOB
object is used to store a PDF document that is encrypted with a certificate. - Create a
System.IO.FileStream
object by invoking its constructor and passing a string value that represents the file location of the PDF document to encrypt and the mode in which to open the file. - Create a byte array that stores the content of the
System.IO.FileStream
object. You can determine the size of the byte array by getting theSystem.IO.FileStream
object’sLength
property. - Populate the byte array with stream data by invoking the
System.IO.FileStream
object’sRead
method and passing the byte array, the starting position, and the stream length to read. - Populate the
BLOB
object by assigning itsMTOM
property with the contents of the byte array.
- Create a
-
Reference the certificate.
- Create a
Recipient
object by using its constructor. This object will store certificate information. - Create a
BLOB
object by using its constructor. ThisBLOB
object will store the certificate that encrypts the PDF document. - Create a
System.IO.FileStream
object by invoking its constructor and passing a string value that represents the file location of the certificate and the mode in which to open the file. - Create a byte array that stores the content of the
System.IO.FileStream
object. You can determine the size of the byte array by getting theSystem.IO.FileStream
object’sLength
property. - Populate the byte array with stream data by invoking the
System.IO.FileStream
object’sRead
method and passing the byte array, the starting position, and the stream length to read. - Populate the
BLOB
object by assigning the contents of the byte array to theBLOB
object’sMTOM
data member. - Assign the
BLOB
object that stores the certificate to theRecipient
object’sx509Cert
data member. - Create a
CertificateEncryptionIdentity
object that stores certificate information by using its constructor. - Assign the
Recipient
object that stores the certificate to theCertificateEncryptionIdentity
object’s recipient data member. - Create an
Object
array and assign theCertificateEncryptionIdentity
object to the first element of theObject
array. ThisObject
array is passed as a parameter to theencryptPDFUsingCertificates
method.
- Create a
-
Set encryption run-time options.
- Create a
CertificateEncryptionOptionSpec
object by using its constructor. - Specify the PDF document resources to encrypt by assigning a
CertificateEncryptionOption
enumeration value to theCertificateEncryptionOptionSpec
object’soption
data member. To encrypt the entire PDF document, including its metadata and its attachments, assignCertificateEncryptionOption.ALL
to this data member. - Specify the Acrobat compatibility option by assigning a
CertificateEncryptionCompatibility
enumeration value to theCertificateEncryptionOptionSpec
object’scompat
data member. For example, assignCertificateEncryptionCompatibility.ACRO_7
to this data member.
- Create a
-
Create a certificate-encrypted PDF document.
Encrypt the PDF document with a certificate by invoking the
EncryptionServiceService
object’sencryptPDFUsingCertificates
method and passing the following values:- The
BLOB
object that contains the PDF document to encrypt. - The
Object
array that stores certificate information. - The
CertificateEncryptionOptionSpec
object that contains encryption run-time options.
The
encryptPDFUsingCertificates
method returns aBLOB
object that contains a certificate-encrypted PDF document. - The
-
Save the encrypted PDF document as a PDF file.
- Create a
System.IO.FileStream
object by invoking its constructor and passing a string value that represents the file location of the secured PDF document. - Create a byte array that stores the data content of the
BLOB
object that was returned by theencryptPDFUsingCertificates
method. Populate the byte array by getting the value of theBLOB
object’sbinaryData
data member. - Create a
System.IO.BinaryWriter
object by invoking its constructor and passing theSystem.IO.FileStream
object. - Write the contents of the byte array to a PDF file by invoking the
System.IO.BinaryWriter
object’sWrite
method and passing the byte array.
- Create a
See also
Invoking AEM Forms using SwaRef
Removing Certificate Based Encryption
Certificate-based encryption can be removed from a PDF document so that users can open the PDF document in Adobe Reader or Acrobat. To remove encryption from a PDF document that is encrypted with a certificate, a public key must be referenced. After encryption is removed from a PDF document, it is no longer secure.
Summary of steps
To remove certificate-based encryption from a PDF document, perform the following steps:
- Include project files.
- Create an encryption service client.
- Get the encrypted PDF document.
- Remove encryption.
- Save the PDF document as a PDF file.
Include project files
Include necessary files into your development project. If you are creating a client application using Java, include the necessary JAR files. If you are using web services, ensure that you include the proxy files.
The following JAR files must be added to your project’s class path:
- adobe-livecycle-client.jar
- adobe-usermanager-client.jar
- adobe-encryption-client.jar
- adobe-utilities.jar (required if AEM Forms is deployed on JBoss Application Server)
- jbossall-client.jar (required if AEM Forms is deployed on JBoss Application Server)
Create an encryption service client
To programmatically perform an Encryption service operation, you must create an Encryption service client. If you are using the Java Encryption Service API, create an EncrytionServiceClient
object. If you are using the web service Encryption Service API, create an EncryptionServiceService
object.
Get the encrypted PDF document
You must obtain an encrypted PDF document to remove certificate-based encryption. If you attempt to remove encryption from a PDF document that is not encrypted, an exception is thrown. Likewise, if you attempt to remove certificate-based encryption from a password-encrypted document, an exception is thrown.
Remove encryption
To remove certificate-based encryption from an encrypted PDF document, you require both an encrypted PDF document and the private key that corresponds to the key that was used to encrypt the PDF document. The alias value of the private key is specified when removing certificate-based encryption from an encrypted PDF document. For information about the public key, see Encrypting PDF Documents with Certificates.
Save the PDF document
After certificate-based encryption is removed from an encrypted PDF document, you can save the PDF document as a PDF file. Users can open the PDF document in Adobe Reader or Acrobat.
See also
Remove certificate-based encryption using the Java API
Remove certificate-based encryption using the web service API
Including AEM Forms Java library files
Encryption Service API Quick Starts
Remove certificate-based encryption using the Java API
Remove certificate-based encryption from a PDF document by using the Encryption API (Java):
-
Include project files.
Include client JAR files, such as adobe-encryption-client.jar, in your Java project’s class path.
-
Create an encryption service client.
- Create a
ServiceClientFactory
object that contains connection properties. - Create an
EncryptionServiceClient
object by using its constructor and passing theServiceClientFactory
object.
- Create a
-
Get the encrypted PDF document.
- Create a
java.io.FileInputStream
object that represents the encrypted PDF document by using its constructor and passing a string value that specifies the location of the encrypted PDF document. - Create a
com.adobe.idp.Document
object by using its constructor and passing thejava.io.FileInputStream
object.
- Create a
-
Remove encryption.
Remove certificate-based encryption from the PDF document by invoking the
EncryptionServiceClient
object’sremovePDFCertificateSecurity
method and passing the following values:- The
com.adobe.idp.Document
object that contains the encrypted PDF document. - A string value that specifies the alias name of the private key that corresponds to the key used to encrypt the PDf document.
The
removePDFCertificateSecurity
method returns acom.adobe.idp.Document
object that contains an unsecured PDF document. - The
-
Save the PDF document.
- Create a
java.io.File
object and ensure that the file extension is .pdf. - Invoke the
com.adobe.idp.Document
object’scopyToFile
method to copy the contents of theDocument
object to the file. Ensure that you use thecom.adobe.idp.Document
object that was returned by theremovePDFCredentialSecurity
method.
- Create a
See also
Quick Start (SOAP mode): Removing certificate-based encryption using the Java API
Including AEM Forms Java library files
Remove certificate-based encryption using the web service API
Remove certificate-based encryption by using the Encryption API (web service):
-
Include project files.
Create a Microsoft .NET project that uses MTOM. Ensure that you use the following WSDL definition:
http://localhost:8080/soap/services/EncryptionService?WSDL&lc_version=9.0.1
.NOTEReplacelocalhost
with the IP address of the server hosting AEM Forms. -
Create an encryption service client.
-
Create an
EncryptionServiceClient
object by using its default constructor. -
Create an
EncryptionServiceClient.Endpoint.Address
object by using theSystem.ServiceModel.EndpointAddress
constructor. Pass a string value that specifies the WSDL to the AEM Forms service (for example,http://localhost:8080/soap/services/EncryptionService?WSDL
.) You do not need to use thelc_version
attribute. This attribute is used when you create a service reference.) -
Create a
System.ServiceModel.BasicHttpBinding
object by getting the value of theEncryptionServiceClient.Endpoint.Binding
field. Cast the return value toBasicHttpBinding
. -
Set the
System.ServiceModel.BasicHttpBinding
object’sMessageEncoding
field toWSMessageEncoding.Mtom
. This value ensures that MTOM is used. -
Enable basic HTTP authentication by performing the following tasks:
- Assign the AEM forms user name to the field
EncryptionServiceClient.ClientCredentials.UserName.UserName
. - Assign the corresponding password value to the field
EncryptionServiceClient.ClientCredentials.UserName.Password
. - Assign the constant value
HttpClientCredentialType.Basic
to the fieldBasicHttpBindingSecurity.Transport.ClientCredentialType
. - Assign the constant value
BasicHttpSecurityMode.TransportCredentialOnly
to the fieldBasicHttpBindingSecurity.Security.Mode
.
- Assign the AEM forms user name to the field
-
-
Get the encrypted PDF document.
- Create a
BLOB
object by using its constructor. TheBLOB
object is used to store the encrypted PDF document. - Create a
System.IO.FileStream
object by invoking its constructor and passing a string value that represents the file location of the encrypted PDF document and the mode in which to open the file. - Create a byte array that stores the content of the
System.IO.FileStream
object. You can determine the size of the byte array by getting theSystem.IO.FileStream
object’sLength
property. - Populate the byte array with stream data by invoking the
System.IO.FileStream
object’sRead
method and passing the byte array, the starting position, and the stream length to read. - Populate the
BLOB
object by assigning the contents of the byte array to theBLOB
object’sMTOM
data member.
- Create a
-
Remove encryption.
Invoke the
EncryptionServiceClient
object’sremovePDFCertificateSecurity
method and pass the following values:- The
BLOB
object that contains file stream data that represents an encrypted PDF document. - A string value that specifies the alias name of the public key that corresponds to the private key used to encrypt the PDf document.
The
removePDFCredentialSecurity
method returns aBLOB
object that contains an unsecured PDF document. - The
-
Save the PDF document.
- Create a
System.IO.FileStream
object by invoking its constructor and passing a string value that represents the file location of the unsecured PDF document. - Create a byte array that stores the content of the
BLOB
object that was returned by theremovePDFPasswordSecurity
method. Populate the byte array by getting the value of theBLOB
object’sMTOM
data member. - Create a
System.IO.BinaryWriter
object by invoking its constructor and passing theSystem.IO.FileStream
object. - Write the contents of the byte array to a PDF file by invoking the
System.IO.BinaryWriter
object’sWrite
method and passing the byte array.
- Create a
See also
Invoking AEM Forms using SwaRef
Removing Password Encryption
Password-based encryption can be removed from a PDF document so that users can open the PDF document in Adobe Reader or Acrobat without having to specify a password. After password-based encryption is removed from a PDF document, the document is no longer secure.
Summary of steps
To remove password-based encryption from a PDF document, perform the following steps:
- Include project files
- Create an encryption service client.
- Get the encrypted PDF document.
- Remove the password.
- Save the PDF document as a PDF file.
Include project files
Include the necessary files into your development project. If you are creating a client application using Java, include the necessary JAR files. If you are using web services, make sure that you include the proxy files.
The following JAR files must be added to your project’s class path:
- adobe-livecycle-client.jar
- adobe-usermanager-client.jar
- adobe-encryption-client.jar
- adobe-utilities.jar (required if AEM Forms is deployed on JBoss)
- jbossall-client.jar (required if AEM Forms is deployed on JBoss)
Create an encryption service client
To programmatically perform an Encryption service operation, you must create an Encryption service client. If you are using the Java Encryption Service API, create an EncrytionServiceClient
object. If you are using the web service Encryption Service API, create an EncryptionServiceService
object.
Get the encrypted PDF document
You must obtain an encrypted PDF document to remove password-based encryption. If you attempt to remove encryption from a PDF document that is not encrypted, an exception is thrown.
Remove the password
To remove password-based encryption from an encrypted PDF document, you require both an encrypted PDF document and a master password value that is used to remove encryption from the PDF document. The password that is used to open a password-encrypted PDF document cannot be used to remove encryption. A master password is specified when the PDF document is encrypted with a password. (See Encrypting PDF Documents with a Password.)
Save the PDF document
After the Encryption service removes password-based encryption from a PDF document, you can save the PDF document as a PDF file. Users can open the PDF document in Adobe Reader or Acrobat without specifying a password.
See also
Including AEM Forms Java library files
Encryption Service API Quick Starts
Encrypting PDF Documents with a Password
Remove password-based encryption using the Java API
Remove password-based encryption from a PDF document by using the Encryption API (Java):
-
Include project files.
Include client JAR files, such as the adobe-encryption-client.jar, in your Java project’s class path.
-
Create an encryption service client.
- Create a
ServiceClientFactory
object that contains connection properties. - Create an
EncryptionServiceClient
object by using its constructor and passing theServiceClientFactory
object.
- Create a
-
Get the encrypted PDF document.
- Create a
java.io.FileInputStream
object that represents the encrypted PDF document by using its constructor and passing a string value that specifies the location of the PDF document. - Create a
com.adobe.idp.Document
object by using its constructor and passing thejava.io.FileInputStream
object.
- Create a
-
Remove the password.
Remove password-based encryption from the PDF document by invoking the
EncryptionServiceClient
object’sremovePDFPasswordSecurity
method and passing the following values:- A
com.adobe.idp.Document
object that contains the encrypted PDF document. - A string value that specifies the master password value that is used to remove encryption from the PDF document.
The
removePDFPasswordSecurity
method returns acom.adobe.idp.Document
object that contains an unsecured PDF document. - A
-
Save the PDF document.
- Create a
java.io.File
object and ensure that the file name extension is .pdf. - Invoke the
com.adobe.idp.Document
object’scopyToFile
method to copy the contents of theDocument
object to the file. Ensure that you use theDocument
object that was returned by theremovePDFPasswordSecurity
method.
- Create a
See also
Quick Start (SOAP mode): Removing password-based encryption using the Java API
Remove password-based encryption using the web service API
Remove password-based encryption by using the Encryption API (web service):
-
Include project files.
Create a Microsoft .NET project that uses MTOM. Ensure that you use the following WSDL definition:
http://localhost:8080/soap/services/EncryptionService?WSDL&lc_version=9.0.1
.NOTEReplacelocalhost
with the IP address of the server hosting AEM Forms. -
Create an encryption service client.
-
Create an
EncryptionServiceClient
object by using its default constructor. -
Create an
EncryptionServiceClient.Endpoint.Address
object by using theSystem.ServiceModel.EndpointAddress
constructor. Pass a string value that specifies the WSDL to the AEM Forms service (for example,http://localhost:8080/soap/services/EncryptionService?WSDL
.) You do not need to use thelc_version
attribute. This attribute is used when you create a service reference.) -
Create a
System.ServiceModel.BasicHttpBinding
object by getting the value of theEncryptionServiceClient.Endpoint.Binding
field. Cast the return value toBasicHttpBinding
. -
Set the
System.ServiceModel.BasicHttpBinding
object’sMessageEncoding
field toWSMessageEncoding.Mtom
. This value ensures that MTOM is used. -
Enable basic HTTP authentication by performing the following tasks:
- Assign the AEM forms user name to the field
EncryptionServiceClient.ClientCredentials.UserName.UserName
. - Assign the corresponding password value to the field
EncryptionServiceClient.ClientCredentials.UserName.Password
. - Assign the constant value
HttpClientCredentialType.Basic
to the fieldBasicHttpBindingSecurity.Transport.ClientCredentialType
. - Assign the constant value
BasicHttpSecurityMode.TransportCredentialOnly
to the fieldBasicHttpBindingSecurity.Security.Mode
.
- Assign the AEM forms user name to the field
-
-
Get the encrypted PDF document.
- Create a
BLOB
object by using its constructor. TheBLOB
object is used to store a password-encrypted PDF document. - Create a
System.IO.FileStream
object by invoking its constructor and passing a string value that represents the file location of the encrypted PDF document and the mode in which to open the file. - Create a byte array that stores the content of the
System.IO.FileStream
object. You can determine the size of the byte array by getting theSystem.IO.FileStream
object’sLength
property. - Populate the byte array with stream data by invoking the
System.IO.FileStream
object’sRead
method and passing the byte array, the starting position, and the stream length to read. - Populate the
BLOB
object by assigning the contents of the byte array to theBLOB
object’sMTOM
data member.
- Create a
-
Remove the password.
Invoke the
EncryptionServiceService
object’sremovePDFPasswordSecurity
method and pass the following values:- The
BLOB
object that contains file stream data that represents an encrypted PDF document. - A string value that specifies the password value that is used to remove encryption from the PDF document. This value is specified when encrypting the PDF document with a password.
The
removePDFPasswordSecurity
method returns aBLOB
object that contains an unsecured PDF document. - The
-
Save the PDF document.
- Create a
System.IO.FileStream
object by invoking its constructor and passing a string value that represents the file location of the unsecured PDF document. - Create a byte array that stores the content of the
BLOB
object that was returned by theremovePDFPasswordSecurity
method. Populate the byte array by getting the value of theBLOB
object’sMTOM
data member. - Create a
System.IO.BinaryWriter
object by invoking its constructor and passing theSystem.IO.FileStream
object. - Write the contents of the byte array to a PDF file by invoking the
System.IO.BinaryWriter
object’sWrite
method and passing the byte array.
- Create a
See also
Invoking AEM Forms using SwaRef
Unlocking Encrypted PDF Documents
A password-encrypted or certificate-encrypted PDF document must be unlocked before another AEM Forms operation can be performed on it. If you attempt to perform an operation on an encrypted PDF document, you will generate an exception. After you unlock an encrypted PDF document, you can perform one or more operations on it. These operations can belong to other services, such as the Acrobat Reader DC extensions Service.
Summary of steps
To unlock an encrypted PDF document, perform the following steps:
- Include project files.
- Create an encryption service client.
- Get the encrypted PDF document.
- Unlock the document.
- Perform an AEM Forms operation.
Include project files
Include necessary files into your development project. If you are creating a client application using Java, include the necessary JAR files. If you are using web services, make sure that you include the proxy files.
The following JAR files must be added to your project’s class path:
- adobe-livecycle-client.jar
- adobe-usermanager-client.jar
- adobe-encryption-client.jar
- adobe-utilities.jar (required if AEM Forms is deployed on JBoss Application Server)
- jbossall-client.jar (required if AEM Forms is deployed on JBoss Application Server)
Create an encryption service client
To programmatically perform an Encryption service operation, you must create an Encryption service client. If you are using the Java Encryption Service API, create an EncrytionServiceClient
object. If you are using the web service Encryption Service API, create an EncryptionServiceService
object.
Get the encrypted PDF document
You must obtain an encrypted PDF document in order to unlock it. If you attempt to unlock a PDF document that is not encrypted, an exception is thrown.
Unlock the document
To unlock a password-encrypted PDF document, you require both an encrypted PDF document and a password value that is used to open a password-encrypted PDF document. This value is specified when encrypting the PDF document with a password. (See Encrypting PDF Documents with a Password.)
To unlock a certificate-encrypted PDF document, you require both an encrypted PDF document and the alias value of the public key that corresponds to the private key that was used to encrypt the PDF document.
Perform an AEM Forms operation
After an encrypted PDF document is unlocked, you can perform another service operation on it, such as applying usage rights to it. This operation belongs to the Acrobat Reader DC Extensions service.
See also
Unlock an encrypted PDF document using the Java API
Unlock an encrypted PDF document using the web service API
Including AEM Forms Java library files
Encryption Service API Quick Starts
Unlock an encrypted PDF document using the Java API
Unlock an encrypted PDF document by using the Encryption API (Java):
-
Include project files.
Include client JAR files, such as adobe-encryption-client.jar, in your Java project’s class path.
-
Create an encryption service client.
- Create a
ServiceClientFactory
object that contains connection properties. - Create an
EncryptionServiceClient
object by using its constructor and passing theServiceClientFactory
object.
- Create a
-
Get the encrypted PDF document.
- Create a
java.io.FileInputStream
object that represents the encrypted PDF document by using its constructor and passing a string value that specifies the location of the encrypted PDF document. - Create a
com.adobe.idp.Document
object by using its constructor and passing thejava.io.FileInputStream
object.
- Create a
-
Unlock the document.
Unlock an encrypted PDF document by invoking the
EncryptionServiceClient
object’sunlockPDFUsingPassword
orunlockPDFUsingCredential
method.To unlock a PDF document that is encrypted with a password, invoke the
unlockPDFUsingPassword
method and pass the following values:- A
com.adobe.idp.Document
object that contains the password-encrypted PDF document. - A string value that specifies the password value that is used to open a password-encrypted PDF document. This value is specified when encrypting the PDF document with a password.
To unlock a PDF document that is encrypted with a certificate, invoke the
unlockPDFUsingCredential
method and pass the following values:- A
com.adobe.idp.Document
object that contains the certificate-encrypted PDF document. - A string value that specifies the alias name of the public key that corresponds to the private key used to encrypt the PDF document.
The
unlockPDFUsingPassword
andunlockPDFUsingCredential
methods both return acom.adobe.idp.Document
object that you pass to another AEM Forms Java method to perform an operation. - A
-
Perform a AEM Forms operation.
Perform a AEM Forms operation on the unlocked PDF document to meet your business requirements. For example, assuming that you want to apply usage rights to an unlocked PDF document, pass the
com.adobe.idp.Document
object that was returned by either theunlockPDFUsingPassword
orunlockPDFUsingCredential
methods to theReaderExtensionsServiceClient
object’sapplyUsageRights
method.
See also
Quick Start (SOAP mode): Unlocking an encrypted PDF document using the Java API (SOAP mode)
Applying Usage Rights to PDF Documents
Including AEM Forms Java library files
Unlock an encrypted PDF document using the web service API
Unlock an encrypted PDF document by using the Encryption API (web service):
-
Include project files.
Create a Microsoft .NET project that uses MTOM. Ensure that you use the following WSDL definition:
http://localhost:8080/soap/services/EncryptionService?WSDL&lc_version=9.0.1
.NOTEReplacelocalhost
with the IP address of the server hosting AEM Forms. -
Create an encryption service client.
-
Create an
EncryptionServiceClient
object by using its default constructor. -
Create an
EncryptionServiceClient.Endpoint.Address
object by using theSystem.ServiceModel.EndpointAddress
constructor. Pass a string value that specifies the WSDL to the AEM Forms service (for example,http://localhost:8080/soap/services/EncryptionService?WSDL
.) You do not need to use thelc_version
attribute. This attribute is used when you create a service reference.) -
Create a
System.ServiceModel.BasicHttpBinding
object by getting the value of theEncryptionServiceClient.Endpoint.Binding
field. Cast the return value toBasicHttpBinding
. -
Set the
System.ServiceModel.BasicHttpBinding
object’sMessageEncoding
field toWSMessageEncoding.Mtom
. This value ensures that MTOM is used. -
Enable basic HTTP authentication by performing the following tasks:
- Assign the AEM forms user name to the field
EncryptionServiceClient.ClientCredentials.UserName.UserName
. - Assign the corresponding password value to the field
EncryptionServiceClient.ClientCredentials.UserName.Password
. - Assign the constant value
HttpClientCredentialType.Basic
to the fieldBasicHttpBindingSecurity.Transport.ClientCredentialType
. - Assign the constant value
BasicHttpSecurityMode.TransportCredentialOnly
to the fieldBasicHttpBindingSecurity.Security.Mode
.
- Assign the AEM forms user name to the field
-
-
Get an encrypted PDF document.
- Create a
BLOB
object by using its constructor. - Create a
System.IO.FileStream
object by invoking its constructor and passing a string value that represents the file location of the encrypted PDF document and the mode in which to open the file. - Create a byte array that stores the content of the
System.IO.FileStream
object. You can determine the size of the byte array by getting theSystem.IO.FileStream
object’sLength
property. - Populate the byte array with stream data by invoking the
System.IO.FileStream
object’sRead
method and passing the byte array, the starting position, and the stream length to read. - Populate the
BLOB
object by assigning the contents of the byte array to theBLOB
object’sMTOM
data member.
- Create a
-
Unlock the document.
Unlock an encrypted PDF document by invoking the
EncryptionServiceClient
object’sunlockPDFUsingPassword
orunlockPDFUsingCredential
method.To unlock a PDF document that is encrypted with a password, invoke the
unlockPDFUsingPassword
method and pass the following values:- A
BLOB
object that contains the password-encrypted PDF document. - A string value that specifies the password value that is used to open a password-encrypted PDF document. This value is specified when encrypting the PDF document with a password.
To unlock a PDF document that is encrypted with a certificate, invoke the
unlockPDFUsingCredential
method and pass the following values:- A
BLOB
object that contains the certificate-encrypted PDF document. - A string value that specifies the alias name of the public key that corresponds to the private key used to encrypt the PDf document.
The
unlockPDFUsingPassword
andunlockPDFUsingCredential
methods both return acom.adobe.idp.Document
object that you pass to another AEM Forms method to perform an operation. - A
-
Perform a AEM Forms operation.
Perform a AEM Forms operation on the unlocked PDF document to meet your business requirements. For example, assuming that you want to apply usage rights to the unlocked PDF document, pass the
BLOB
object that was returned by either theunlockPDFUsingPassword
orunlockPDFUsingCredential
methods to theReaderExtensionsServiceClient
object’sapplyUsageRights
method.
See also
Invoking AEM Forms using SwaRef
Determining Encryption Type
You can programmatically determine the type of encryption that is protecting a PDF document by using the Java Encryption Service API or the web service Encryption Service API. Sometimes it is necessary to dynamically determine whether a PDF document is encrypted and, if so, the encryption type. For example, you can determine whether a PDF document is protected with password-based encryption or a Rights Management policy.
A PDF document can be protected by the following encryption types:
- Password-based encryption
- Certificate-based encryption
- A policy that is created by the Rights Management service
- Another type of encryption
Summary of steps
To determine the type of encryption that is protecting a PDF document, perform the following steps:
- Include project files.
- Create an encryption service client.
- Get the encrypted PDF document.
- Determine the encryption type.
Include project files
Include necessary files into your development project. If you are creating a client application using Java, include the necessary JAR files. If you are using web services, ensure that you include the proxy files.
The following JAR files must be added to your project’s class path:
- adobe-livecycle-client.jar
- adobe-usermanager-client.jar
- adobe-encryption-client.jar
- adobe-utilities.jar (required if AEM Forms is deployed on JBoss Application Server)
- jbossall-client.jar (required if AEM Forms is deployed on JBoss Application Server)
Create a service client
To programmatically perform an Encryption service operation, you must create an Encryption service client. If you are using the Java Encryption Service API, create an EncrytionServiceClient
object. If you are using the web service Encryption Service API, create an EncryptionServiceService
object.
Get the encrypted PDF document
You must obtain a PDF document to determine the type of encryption that is protecting it.
Determine the encryption type
You can determine the type of encryption that is protecting a PDF document. If the PDF document is not protected, then the Encryption service informs you that the PDF document is not secured.
See also
Determine the encryption type using the Java API
Determine the encryption type using the web service API
Including AEM Forms Java library files
Encryption Service API Quick Starts
Protecting Documents with Policies
Determine the encryption type using the Java API
Determine the type of encryption that is protecting a PDF document by using the Encryption API (Java):
-
Include project files.
Include client JAR files, such as adobe-encryption-client.jar, in your Java project’s class path.
-
Create a service client.
- Create a
ServiceClientFactory
object that contains connection properties. - Create an
EncryptionServiceClient
object by using its constructor and passing theServiceClientFactory
object.
- Create a
-
Get the encrypted PDF document.
- Create a
java.io.FileInputStream
object that represents the PDF document by using its constructor and passing a string value that specifies the location of the PDF document. - Create a
com.adobe.idp.Document
object by using its constructor and passing thejava.io.FileInputStream
object.
- Create a
-
Determine the encryption type.
- Determine the encryption type by invoking the
EncryptionServiceClient
object’sgetPDFEncryption
method and passing thecom.adobe.idp.Document
object that contains the PDF document. This method returns anEncryptionTypeResult
object. - Invoke the
EncryptionTypeResult
object’sgetEncryptionType
method. This method returns anEncryptionType
enum value that specifies the encryption type. For example, if the PDF document is protected with password-based encryption, this method returnsEncryptionType.PASSWORD
.
- Determine the encryption type by invoking the
See also
Quick Start (SOAP mode): Determining encryption type using the Java API
Including AEM Forms Java library files
Determine the encryption type using the web service API
Determine the type of encryption that is protecting a PDF document by using the Encryption API (web service):
-
Include project files.
Create a Microsoft .NET project that uses MTOM. Ensure that you use the following WSDL definition:
http://localhost:8080/soap/services/EncryptionService?WSDL&lc_version=9.0.1
.NOTEReplacelocalhost
with the IP address of the server hosting AEM Forms. -
Create a service client.
-
Create an
EncryptionServiceClient
object by using its default constructor. -
Create an
EncryptionServiceClient.Endpoint.Address
object by using theSystem.ServiceModel.EndpointAddress
constructor. Pass a string value that specifies the WSDL to the AEM Forms service (for example,http://localhost:8080/soap/services/EncryptionService?WSDL
.) You do not need to use thelc_version
attribute. This attribute is used when you create a service reference.) -
Create a
System.ServiceModel.BasicHttpBinding
object by getting the value of theEncryptionServiceClient.Endpoint.Binding
field. Cast the return value toBasicHttpBinding
. -
Set the
System.ServiceModel.BasicHttpBinding
object’sMessageEncoding
field toWSMessageEncoding.Mtom
. This value ensures that MTOM is used. -
Enable basic HTTP authentication by performing the following tasks:
- Assign the AEM forms user name to the field
EncryptionServiceClient.ClientCredentials.UserName.UserName
. - Assign the corresponding password value to the field
EncryptionServiceClient.ClientCredentials.UserName.Password
. - Assign the constant value
HttpClientCredentialType.Basic
to the fieldBasicHttpBindingSecurity.Transport.ClientCredentialType
. - Assign the constant value
BasicHttpSecurityMode.TransportCredentialOnly
to the fieldBasicHttpBindingSecurity.Security.Mode
.
- Assign the AEM forms user name to the field
-
-
Get the encrypted PDF document.
- Create a
BLOB
object by using its constructor. - Create a
System.IO.FileStream
object by invoking its constructor and passing a string value that represents the file location of the encrypted PDF document and the mode in which to open the file. - Create a byte array that stores the content of the
System.IO.FileStream
object. You can determine the size of the byte array by getting theSystem.IO.FileStream
object’sLength
property. - Populate the byte array with stream data by invoking the
System.IO.FileStream
object’sRead
method and passing the byte array, the starting position, and the stream length to read. - Populate the
BLOB
object by assigning the contents of the byte array to theBLOB
object’sMTOM
data member.
- Create a
-
Determine the encryption type.
- Invoke the
EncryptionServiceClient
object’sgetPDFEncryption
method and pass theBLOB
object that contains the PDF document. This method returns anEncryptionTypeResult
object. - Get the value of the
EncryptionTypeResult
object’sencryptionType
data method. For example, if the PDF document is protected with password-based encryption, the value of this data member isEncryptionType.PASSWORD
.
- Invoke the