Ir para o conteúdo

Funções Criptográficas

As funções criptográficas são usadas para realizar criptografia e descriptografia básicas usando algoritmos e funções padrão.

Ler e Gravar Arquivos Usando Base64

As funções Base64 podem ser usadas ao ler e gravar arquivos, seguindo estes cenários comuns:

Um cenário é ler um arquivo existente (talvez um PDF) usando o Base64EncodeFile função e, em seguida, grave o conteúdo desse arquivo em um endpoint, como Salesforce.

Para fazer isso, crie um script que leia o arquivo de uma origem e defina variáveis globais apropriadas. Em seguida, você criaria uma transformação que pegaria essas variáveis globais e as usaria em um mapeamento para gravar no Salesforce:

// Read a PDF File
$docName = "Test.pdf";
$fileContents = Base64EncodeFile("<TAG>activity:ftp/FTP Endpoint/ftp_read/FTP Files</TAG>", $docName);
$docLength = Length($fileContents);
$docType = "pdf";
$mimeType = "application/pdf";

Um segundo cenário é ler um arquivo, colocar o conteúdo em uma variável e então usar o Base64Encode função no conteúdo antes de salvar em um novo arquivo de texto.

AESDecryption

Declaração

string AESDecryption(string encryptedText, string passphrase, [string salt, int keyLength, int iterations])

Sintaxe

AESDecryption(<encryptedText>, <passphrase>[, <salt>, <keyLength>, <iterations>])

Parâmetros Obrigatórios

  • encryptedText: Um valor criptografado AES codificado em base64
  • passphrase: Senha usada para criptografar a string com a função AESEncryption

Parâmetros Opcionais

  • salt: Sal de string hexadecimal usado para criptografar a string com a função AESEncryption
  • keyLength: Comprimento da chave usada para criptografar a string com a função AESEncryption
  • iterations: Número de iterações usadas para criptografar a string com a função AESEncryption

Descrição

Esta função descriptografa uma string criptografada com o algoritmo AES.

A saída descriptografada é retornada como uma string. Ver AESEncryption para obter detalhes adicionais.

Exemplos

// Encrypting a string
encrypted = AESEncryption("Hello world!", "password");
// Decrypted as "Hello world!"
decrypted = AESDecryption(encrypted, "password");

// Encrypting (and decrypting) a string using
// a passphrase and salt, 256-bit key, and 1024 iterations
encrypted = AESEncryption("Hello world!", "password", "00FFAE01", 256, 1024);
decrypted = AESDecryption(encrypted, "password", "00FFAE01", 256, 1024);

AESEncryption

Declaração

string AESEncryption(string plainText, string passphrase[, string salt, int keyLength, int iterations])

Sintaxe

AESEncryption(<plainText>, <passphrase>[, <salt>, <keyLength>, <iterations>])

Parâmetros Obrigatórios

  • plainText: Uma string a ser criptografada
  • passphrase: Senha a ser usada para criptografar a string

Parâmetros Opcionais

  • salt: Sal de string hexadecimal usado para criptografar a string; se especificado, o valor deve ser fornecido em formato hexadecimal (como "A034DD")
  • keyLength: O comprimento da chave a ser usada para criptografar a string e deve ser 128, 192 ou 256; o padrão é 256
  • iterations: Número de iterações usadas para gerar a chave; o padrão é 1

Descrição

Esta função criptografa uma string usando o algoritmo AES. A chave é gerada de acordo com Especificação de criptografia baseada em senha versão 2.0 (PKCS5S2).

A saída criptografada é uma string codificada em base64. A saída de AESEncryption pode ser passado diretamente para a função AESDecryption para descriptografia, usando os mesmos parâmetros de quando a string de texto simples foi criptografada.

Exemplos

// Encrypting a string
encrypted = AESEncryption("Hello world!", "password");
// Decrypted as "Hello world!"
decrypted = AESDecryption(encrypted, "password");

// Encrypting (and decrypting) a string using
// a passphrase and salt, 256-bit key, and 1024 iterations
encrypted = AESEncryption("Hello world!", "password", "00FFAE01", 256, 1024);
decrypted = AESDecryption(encrypted, "password", "00FFAE01", 256, 1024);

Base64Decode

Declaração

binary Base64Decode(string encryptedText)

Sintaxe

Base64Decode(<encryptedText>)

Parâmetros Obrigatórios

  • encryptedText: Uma string codificada em base64

Descrição

Decodifica uma string codificada em base64, retornando dados binários. Veja também Base64Encode.

Exemplos

// Encrypting a string after first converting it to binary
binary = HexToBinary(StringToHex("Hello world!"));
encrypted = Base64Encode(binary);

decrypted = Base64Decode(encrypted);
result = HexToString(BinaryToHex(decrypted));
// Returns original string "Hello world!"

Base64Encode

Declaração

string Base64Encode(type arg)

Sintaxe

Base64Encode(<arg>)

Parâmetros Obrigatórios

  • arg: Valor a ser codificado

Descrição

Codifica os dados do argumento, tratando os caracteres em uma string como dados binários, a menos que a entrada já seja binária. Se o tipo do argumento não for binário ou uma string, o valor do argumento será primeiro convertido em uma string antes da criptografia.

Um caractere de nova linha (\n) é adicionado após cada 64 caracteres da sequência de resultados codificada. Como muitas implementações de Base64 incluem novas linhas para limitar o comprimento máximo da linha do resultado codificado, isso deve ser explicitamente desabilitado apenas quando necessário. Para desativar isso, defina o jitterbit.base64.encoded.string.no.wrap Variável Jitterbit para true antes de chamar esta função. Essa variável é suportada com dados de sequência ao usar agentes 10.49 e posteriores e com dados binários ao usar agentes 10.x 10.66 e posteriores e agentes 11.x 11.4 e posteriores.

Veja também Base64Decode.

Exemplos

// Encrypting a string after first converting it to binary
binary = HexToBinary(StringToHex("Hello world!"));
encrypted = Base64Encode(binary);

decrypted = Base64Decode(encrypted);
result = HexToString(BinaryToHex(decrypted));
// Returns original string "Hello world!"

encrypted = Base64Encode(Now());
decrypted = Base64Decode(encrypted);
result = HexToString(BinaryToHex(decrypted));
// Returns a date string such as "2017-12-14 01:25:31"

// Encrypting credentials for use in an HTTP header
Base64Encode("exampleuser"+":"+"examplepassword")

Base64EncodeFile

Declaração

string Base64EncodeFile(string sourceId[, string filename])

Sintaxe

Base64EncodeFile(<sourceId>[, <filename>])

Parâmetros Obrigatórios

  • sourceId: Um caminho de referência de string para uma atividade associada a um endpoint de tipo de arquivo no projeto atual que retorna um arquivo binário. Se uma matriz de nomes de arquivos for retornada, o primeiro será usado.

Parâmetros Opcionais

  • filename: Um nome de arquivo de string usado para substituir o valor retornado pelo sourceId fonte

Descrição

Lê um arquivo binário da atividade de origem especificada e retorna o conteúdo como uma string codificada em base64. Este método geralmente é usado para arquivos que podem ser binários. Para ler um arquivo de texto, use a função ReadFile em vez de.

A fonte usada nesta função deve ser definida como uma atividade associada a um endpoint de tipo de arquivo no projeto atual. Isso inclui atividades configuradas de compartilhamento de arquivos, FTP, HTTP, armazenamento local e armazenamento temporário. Para obter mais informações, consulte as instruções sobre como inserir endpoints em Endpoints seção em Jitterbit Script.

Este método retorna o conteúdo do arquivo apontado pela fonte especificada. Caso o filtro de origem selecione mais de um arquivo, o primeiro será utilizado. Recomenda-se especificar uma fonte que identifique exclusivamente um único arquivo.

O segundo parâmetro, filename, é opcional e pode ser usado para substituir o nome do arquivo retornado na configuração da atividade. Alternativamente, uma variável global pode ser usada para substituir o nome do arquivo na configuração da atividade. Variáveis globais são referenciadas como [de_name] na configuração da atividade.

Se um arquivo não for encontrado, um erro será gerado.

Um caractere de nova linha (\n) é adicionado após cada 64 caracteres da sequência de resultados codificada. Como muitas implementações de Base64 incluem novas linhas para limitar o comprimento máximo da linha do resultado codificado, isso deve ser explicitamente desabilitado apenas quando necessário. Para desativar isso, defina o jitterbit.base64.encoded.string.no.wrap Variável Jitterbit para true antes de chamar esta função. Essa variável é suportada com dados de sequência ao usar agentes 10.49 e posteriores e com dados binários ao usar agentes 10.x 10.66 e posteriores e agentes 11.x 11.4 e posteriores.

Veja também Base64Decode.

Exemplos

// Reads the first file found at the source
// "FTP Files" and returns it as a base64-encoded string
fileContents1 = Base64EncodeFile("<TAG>activity:ftp/FTP Endpoint/ftp_read/FTP Files</TAG>");

// Reads the binary file called
// "requirements.doc" from the FTP directory
// defined by the source "FTP Files"
fileContents2 = Base64EncodeFile("<TAG>activity:ftp/FTP Endpoint/ftp_read/FTP Files</TAG>", "requirements.doc");

// Decodes the file contents; they can now be
// re-written as a binary file to another target
fileContents2Decoded = Base64Decode(fileContents2);

MD5

Declaração

string MD5(type arg)

Sintaxe

MD5(<arg>)

Parâmetros Obrigatórios

  • arg: Valor a ser hash

Descrição

Aplica a função hash MD5 ao argumento fornecido. O hash é retornado como uma sequência de números hexadecimais de 64 bits. Os dados que não são de string serão primeiro convertidos em uma string.

Cuidado

Quando usada com agentes versão 10.63 e anteriores ou 11.1 e anteriores, esta função não gera os valores corretos para arquivos binários, como ZIP ou PDF. Este comportamento pode ser aplicado a versões posteriores do agente usando a variável Jitterbit $jitterbit.md5.hash.use.file.mode.string.only.

Exemplos

MD5("hello world!");
// Returns "fc3ff98e8c6a0d3087d515c0473f8677"

MD5AsTwoNumbers

Declaração

array MD5AsTwoNumbers(type arg)

Sintaxe

MD5AsTwoNumbers(<arg>)

Parâmetros Obrigatórios

  • arg: Valor a ser hash

Descrição

Aplica a função hash MD5 a uma string de entrada e retorna o resultado como uma matriz com dois números de 64 bits. Os dados que não são de string serão primeiro convertidos em uma string.

Exemplos

MD5AsTwoNumbers("hello world!");
// Returns "{8612640914790536583, 3462540840444444668}"

SHA256

Declaração

string SHA256(type arg)

Sintaxe

SHA256(<arg>)

Parâmetros Obrigatórios

  • arg: Valor a ser hash

Descrição

Aplica a função hash SHA-256 a uma string de entrada. O hash retornado é uma sequência de 64 números hexadecimais.

Se a entrada for uma string, ela será primeiro convertida para a representação de bytes UTF-8. Os dados que não são de string serão primeiro convertidos em uma string.

Cuidado

Quando usada com agentes versão 10.63 e anteriores ou 11.1 e anteriores, esta função não gera os valores corretos para arquivos binários, como ZIP ou PDF. Este comportamento pode ser aplicado a versões posteriores do agente usando a variável Jitterbit $jitterbit.md5.hash.use.file.mode.string.only.

Exemplos

SHA256("hello world!");
// Returns "7509e5bda0c762d2bac7f90d758b5b2263fa01ccbc542ab5e3df163be08e6ca9"