Reader estendendo documentos PDF protegidos por política usando a Biblioteca Portable Protection reader-extending-policy-protected-pdf-documents-using-portable-protection-library

CAUTION
AEM 6.4 chegou ao fim do suporte estendido e esta documentação não é mais atualizada. Para obter mais detalhes, consulte nossa períodos de assistência técnica. Encontre as versões compatíveis here.

Familiarize-se com os conceitos de segurança de documentos, extensão de leitor e linguagem de programação Java para ler e estender os documentos PDF protegidos pela política de segurança de documentos.

Você pode usar a segurança do documento para restringir o acesso de documentos PDF específicos somente a usuários autorizados. Você também pode determinar como um destinatário pode usar um documento protegido. Por exemplo, você pode especificar se os destinatários podem imprimir, copiar ou editar o texto de um documento protegido por uma política de segurança de documento. Para saber mais sobre a segurança de documentos, consulte sobre segurança de documentos.

É possível usar extensões de leitor para ativar recursos interativos no documento Adobe PDF por meio do Acrobat Reader. Esses recursos interativos normalmente estão disponíveis apenas por meio do Adobe Acrobat Professional e Standard. Para saber mais sobre os recursos interativos que a extensão do leitor pode ativar, consulte Serviço Adobe Experience Manager Forms DocAssurance.

Você pode usar a biblioteca de proteção portátil para aplicar políticas no documento sem a necessidade de documento viajando pela rede. Somente as credenciais de segurança e os detalhes da política de proteção são transferidos pela rede. O documento real nunca deixa o cliente e as políticas de proteção são aplicadas localmente no cliente.

Reader estendendo documentos PDF protegidos pela política de segurança de documentos reader-extending-document-security-policy-protected-pdf-documents

Os documentos protegidos por política são documentos criptografados. Não é possível usar APIs de extensão de leitor padrão para aplicar, remover e recuperar direitos de uso de documentos PDF protegidos por política. Somente o serviço de extensões Reader da Biblioteca de Proteção Portátil fornece APIs para aplicar, remover e recuperar direitos de uso de documentos do PDF protegidos por política de segurança de documentos.

Serviço de extensões Reader reader-extensions-service

O serviço de extensão do leitor adiciona direitos de uso a um documento PDF protegido por política, ativando recursos que normalmente não estão disponíveis quando um documento do PDF é aberto usando o Adobe Acrobat Reader. Ele também tem APIs para remover e recuperar direitos de uso de um documento protegido por política.

O serviço de extensões Reader oferece suporte total a documentos PDF com base no PDF standard 1.6 e posterior. Além da Acrobat Reader, os usuários de terceiros não exigem software ou plug-ins adicionais para usar os documentos do PDF protegidos por políticas.

Você pode realizar as seguintes tarefas com o serviço Reader Extensions:

  • Aplicar direitos de uso a um documento PDF protegido por política.
  • Remova os direitos de uso de um documento PDF protegido por política.
  • Recuperar direitos de uso aplicados a um documento PDF protegido por política.

Aplicar direitos de uso a um documento PDF protegido por política de segurança de documento apply-usage-rights-to-a-document-security-policy-protected-pdf-document

Você pode usar o applyUsageRightsAPI Java para aplicar direitos de uso a documentos PDF protegidos por política. Os direitos de uso pertencem a uma funcionalidade que está disponível por padrão no Acrobat, mas não no Adobe Reader, como a capacidade de adicionar comentários a um formulário ou de preencher campos de formulário e salvar o formulário. Os documentos do PDF que têm direitos de uso aplicados a eles são chamados de documentos ativados por direitos. Um usuário que abra um documento com direitos ativados no Adobe Reader pode executar operações ativadas para esse documento específico.

Sintaxe: InputStream applyUsageRights(InputStream inputFile, File certFile, String credentialPassword, UsageRights usageRights)

Parâmetro
Descrição
inputFile
Especifique InputStream que representa o documento PDF ao qual os direitos de uso devem ser aplicados. Você pode usar o LiveCycle Rights Management ou documentos protegidos pela segurança de documentos do AEM Forms.
certFile
Especifique o objeto File que representa um arquivo .jks. O arquivo .jks é um arquivo de repositório de chaves. Ele aponta para um certificado que concede direitos de uso.
credentialPassword
Especifique a senha do repositório de chaves.
usageRights
Especifica um objeto do tipo UsageRights. O objeto usageRights representa direitos individuais que podem ser aplicados a um documento de PDF protegido por política.

Recuperar direitos de uso aplicados a um documento PDF protegido por política.   retrieve-usage-rights-applied-to-a-policy-protected-pdf-document-nbsp

Você pode usar o getDocumentUsageRightsAPI Java para recuperar os direitos de uso da extensão do leitor aplicados a um documento de PDF protegido por política. Ao recuperar informações sobre direitos de uso, você pode saber mais sobre os recursos que a extensão do leitor de leitores ativou para o documento PDF protegido por política.

Sintaxe: public GetUsageRightsResult getDocumentUsageRights(InputStream inDoc)

Parâmetro
Descrição
inDoc
Especifique InputStream que representa o documento PDF do qual os direitos de uso devem ser recuperados. Você pode usar o LiveCycle Rights Management ou documentos protegidos pela segurança de documentos do AEM Forms.

Amostra de código code-sample

//Create a ServiceClientFactory instance
ServiceClientFactory factory = ServiceClientFactory.createInstance(connectionProps);
//Create a RightsManagementClient object
RightsManagementClient2 rmClient2= new RightsManagementClient2(factory);

String inputFileName = "C:\\Sample\\protected.pdf"; //Input file can be RM protected or unprotected pdf file
File certFile = new File("C:\\Sample\\cert.jks"); //RE certificate file
String password = "password"; //password for RE certificate
UsageRights usageRights = getUsageRights(true,true,false,false,true,true,false,false,false,false,true);

//RE rights to be applied on the file : FormFillIn, FormDataImportExport, SubmitStandalone, OnlineForms, DynamicFormField, DynamicFormPages, BarcodeDecoding, DigitalSignatures, Comments, CommentsOnline, EmbeddedFiles

InputStream inputFileStream = new FileInputStream(inputFileName);
InputStream output = rmClient2.getRightsManagementReaderExtensionService().applyUsageRights(inputFileStream, certFile, credentialPassword, rights);

String outputFileName = "C:\\Sample\\ReAdded.pdf";
//Save the PDF document
File myFile = new File(outputFileName);
FileOutputStream outputStream = new FileOutputStream(myFile);

int read = 0;
byte[] bytes = new byte[1024];

while ((read = output.read(bytes)) != -1) {

    outputStream.write(bytes, 0, read);
}

System.out.println("UsageRights applied successfully to the document. ”);
 outputStream.close();
inputFileStream.close();

//Get Usage Rights for the output pdf document
InputStream fileWithRe = new FileInputStream(myFile);

GetUsageRightsResult usageRights = rmClient2.getRightsManagementReaderExtensionService().getDocumentUsageRights(fileWithRe);

UsageRights rights = usageRights.getRights();
String right1 = rights1.toString();
System.out.println("RE rights for the file are :\n"+right1);
 fileWithRe.close();

Remover direitos de uso de um documento PDF protegido por política remove-usage-rights-of-a-policy-protected-pdf-document

Você pode usar o removeUsageRightsAPI Java para remover direitos de uso de um documento protegido por política. A remoção de direitos de uso de um documento PDF protegido por política é necessária para executar outras operações do AEM Forms no documento. Por exemplo, você deve assinar digitalmente (ou certificar) um documento do PDF antes de definir direitos de uso. Portanto, se você deseja executar operações em um documento protegido por política, é necessário remover direitos de uso do documento do PDF, executar outras operações, como assinar digitalmente o documento e, em seguida, reaplicar direitos de uso ao documento.

Sintaxe: InputStream removeUsageRights(InputStream inputFile)

Parâmetro
Descrição
inputFile
Especificar InputStream que representa o documento de PDF a partir do qual o uso
os direitos devem ser removidos. Você pode usar o LiveCycle Rights Management ou documentos protegidos pela segurança de documentos do AEM Forms.

Amostra de código code-sample-1

//Create a ServiceClientFactory instance
ServiceClientFactory factory = ServiceClientFactory.createInstance(connectionProps);
//Create a RightsManagementClient object
RightsManagementClient2 rmClient2= new RightsManagementClient2(factory);

String inputFileName = "C:\\Sample\\fileWithRe.pdf"; //Input file can be RM protected or unprotected pdf file
InputStream inputFileStream = new FileInputStream(inputFileName);

InputStream fileStream = rmClient2.getRightsManagementReaderExtensionService().removeUsageRights(inputFileStream);

String outputFileName = "C:\\Sample\\ReRemoveded.pdf";
//Save the PDF document
File myFile = new File(outputFileName);
FileOutputStream outputStream = new FileOutputStream(myFile);

int read = 0;
byte[] bytes = new byte[1024];

while ((read = fileStream.read(bytes)) != -1) {

    outputStream.write(bytes, 0, read);
}
System.out.println("RE rights removed successfully from the document.”);
outputStream.close();
inputFileStream.close();
recommendation-more-help
a6ebf046-2b8b-4543-bd46-42a0d77792da