Há mais exemplos de AWS SDK disponíveis no repositório AWS Doc SDK Examples
As traduções são geradas por tradução automática. Em caso de conflito entre o conteúdo da tradução e da versão original em inglês, a versão em inglês prevalecerá.
AWS Payment Cryptography Exemplos de planos de dados usando AWS CLI
Os exemplos de código a seguir mostram como realizar ações e implementar cenários comuns usando o AWS Command Line Interface com AWS Payment Cryptography Data Plane.
Ações são trechos de código de programas maiores e devem ser executadas em contexto. Embora as ações mostrem como chamar perfis de serviço individuais, você pode ver as ações no contexto em seus cenários relacionados.
Cada exemplo inclui um link para o código-fonte completo, em que você pode encontrar instruções sobre como configurar e executar o código.
Tópicos
Ações
O código de exemplo a seguir mostra como usar decrypt-data.
- AWS CLI
-
Como descriptografar texto cifrado
O exemplo
decrypt-dataa seguir descriptografa dados de texto cifrado usando uma chave simétrica. Para essa operação, a chave deve terKeyModesOfUsedefinido comoDecrypteKeyUsagedefinido comoTR31_D0_SYMMETRIC_DATA_ENCRYPTION_KEY.aws payment-cryptography-data decrypt-data \ --key-identifierarn:aws:payment-cryptography:us-east-2:123456789012:key/kwapwa6qaifllw2h\ --cipher-text33612AB9D6929C3A828EB6030082B2BD\ --decryption-attributes 'Symmetric={Mode=CBC}'Saída:
{ "KeyArn": "arn:aws:payment-cryptography:us-east-2:123456789012:key/kwapwa6qaifllw2h", "KeyCheckValue": "71D7AE", "PlainText": "31323334313233343132333431323334" }Para obter mais informações, consulte Descriptografar dados no Guia do usuário do AWS Payment Cryptography.
-
Para obter detalhes da API, consulte DecryptData
em Referência de AWS CLI Comandos.
-
O código de exemplo a seguir mostra como usar encrypt-data.
- AWS CLI
-
Como criptografar dados
O exemplo
encrypt-dataa seguir criptografa dados de texto simples usando uma chave simétrica. Para essa operação, a chave deve terKeyModesOfUsedefinido comoEncrypteKeyUsagedefinido comoTR31_D0_SYMMETRIC_DATA_ENCRYPTION_KEY.aws payment-cryptography-data encrypt-data \ --key-identifierarn:aws:payment-cryptography:us-east-2:123456789012:key/kwapwa6qaifllw2h\ --plain-text31323334313233343132333431323334\ --encryption-attributes 'Symmetric={Mode=CBC}'Saída:
{ "KeyArn": "arn:aws:payment-cryptography:us-east-2:123456789012:key/kwapwa6qaifllw2h", "KeyCheckValue": "71D7AE", "CipherText": "33612AB9D6929C3A828EB6030082B2BD" }Para obter mais informações, consulte Criptografar dados no Guia do usuário do AWS Payment Cryptography.
-
Para obter detalhes da API, consulte EncryptData
em Referência de AWS CLI Comandos.
-
O código de exemplo a seguir mostra como usar generate-card-validation-data.
- AWS CLI
-
Como gerar um CVV
O
generate-card-validation-dataexemplo a seguir gera um CVV/CVV2.aws payment-cryptography-data generate-card-validation-data \ --key-identifierarn:aws:payment-cryptography:us-east-2:123456789012:key/kwapwa6qaifllw2h\ --primary-account-number=171234567890123 \ --generation-attributesCardVerificationValue2={CardExpiryDate=0123}Saída:
{ "KeyArn": "arn:aws:payment-cryptography:us-east-2:123456789012:key/kwapwa6qaifllw2h", "KeyCheckValue": "CADDA1", "ValidationData": "801" }Para obter mais informações, consulte Gerar dados de cartões no Guia do usuário do AWS Payment Cryptography.
-
Para obter detalhes da API, consulte GenerateCardValidationData
em Referência de AWS CLI Comandos.
-
O código de exemplo a seguir mostra como usar generate-mac.
- AWS CLI
-
Como gerar um MAC
O
generate-card-validation-dataexemplo a seguir gera um Código de Autenticação de Mensagens Baseado em Hash (HMAC) para autenticação de dados do cartão usando o algoritmo HMAC_ SHA256 e uma chave de criptografia HMAC. A chave deve terKeyUsagedefinido comoTR31_M7_HMAC_KEYeKeyModesOfUsecomoGenerate.aws payment-cryptography-data generate-mac \ --key-identifierarn:aws:payment-cryptography:us-east-2:123456789012:key/kwapwa6qaifllw2h\ --message-data"3b313038383439303031303733393431353d32343038323236303030373030303f33"\ --generation-attributesAlgorithm=HMAC_SHA256Saída:
{ "KeyArn": "arn:aws:payment-cryptography:us-east-2:123456789012:key/kwapwa6qaifllw2h, "KeyCheckValue": "2976E7", "Mac": "ED87F26E961C6D0DDB78DA5038AA2BDDEA0DCE03E5B5E96BDDD494F4A7AA470C" }Para obter mais informações, consulte Gerar MAC no Guia do usuário do AWS Payment Cryptography.
-
Para obter detalhes da API, consulte GenerateMac
em Referência de AWS CLI Comandos.
-
O código de exemplo a seguir mostra como usar generate-pin-data.
- AWS CLI
-
Como gerar um PIN
O exemplo
generate-card-validation-dataa seguir gera um novo PIN aleatório usando o esquema de PIN Visa.aws payment-cryptography-data generate-pin-data \ --generation-key-identifierarn:aws:payment-cryptography:us-east-2:111122223333:key/37y2tsl45p5zjbh2\ --encryption-key-identifierarn:aws:payment-cryptography:us-east-2:111122223333:key/ivi5ksfsuplneuyt\ --primary-account-number171234567890123\ --pin-block-formatISO_FORMAT_0\ --generation-attributesVisaPin={PinVerificationKeyIndex=1}Saída:
{ "GenerationKeyArn": "arn:aws:payment-cryptography:us-east-2:111122223333:key/37y2tsl45p5zjbh2", "GenerationKeyCheckValue": "7F2363", "EncryptionKeyArn": "arn:aws:payment-cryptography:us-east-2:111122223333:key/ivi5ksfsuplneuyt", "EncryptionKeyCheckValue": "7CC9E2", "EncryptedPinBlock": "AC17DC148BDA645E", "PinData": { "VerificationValue": "5507" } }Para obter mais informações, consulte Gerar dados de PIN no Guia do usuário do AWS Payment Cryptography.
-
Para obter detalhes da API, consulte GeneratePinData
em Referência de AWS CLI Comandos.
-
O código de exemplo a seguir mostra como usar re-encrypt-data.
- AWS CLI
-
Como recriptografar dados com uma chave diferente
O exemplo
re-encrypt-dataa seguir descriptografa o texto cifrado que foi criptografado usando uma chave simétrica AES e o recriptografa usando uma chave do tipo DUKPT (Chave Derivada Exclusiva por Transação).aws payment-cryptography-data re-encrypt-data \ --incoming-key-identifierarn:aws:payment-cryptography:us-west-2:111122223333:key/hyvv7ymboitd4vfy\ --outgoing-key-identifierarn:aws:payment-cryptography:us-west-2:111122223333:key/jl6ythkcvzesbxen\ --cipher-text4D2B0BDBA192D5AEFEAA5B3EC28E4A65383C313FFA25140101560F75FE1B99F27192A90980AB9334\ --incoming-encryption-attributes"Dukpt={Mode=ECB,KeySerialNumber=0123456789111111}"\ --outgoing-encryption-attributes '{"Symmetric": {"Mode": "ECB"}}'Saída:
{ "CipherText": "F94959DA30EEFF0C035483C6067667CF6796E3C1AD28C2B61F9CFEB772A8DD41C0D6822931E0D3B1", "KeyArn": "arn:aws:payment-cryptography:us-west-2:111122223333:key/jl6ythkcvzesbxen", "KeyCheckValue": "2E8CD9" }Para obter mais informações, consulte Criptografar e descriptografar dados no Guia do usuário do AWS Payment Cryptography.
-
Para obter detalhes da API, consulte ReEncryptData
em Referência de AWS CLI Comandos.
-
O código de exemplo a seguir mostra como usar translate-pin-data.
- AWS CLI
-
Como traduzir dados de PIN
O exemplo
translate-pin-dataa seguir traduz um PIN da criptografia PEK TDES usando um bloco de PIN ISO 0 para um bloco de PIN ISO 4 AES usando o algoritmo DUKPT.aws payment-cryptography-data translate-pin-data \ --encrypted-pin-block"AC17DC148BDA645E"\ --incoming-translation-attributes=IsoFormat0='{PrimaryAccountNumber=171234567890123}' \ --incoming-key-identifierarn:aws:payment-cryptography:us-east-2:111122223333:key/ivi5ksfsuplneuyt\ --outgoing-key-identifierarn:aws:payment-cryptography:us-east-2:111122223333:key/4pmyquwjs3yj4vwe\ --outgoing-translation-attributes IsoFormat4="{PrimaryAccountNumber=171234567890123}" \ --outgoing-dukpt-attributes KeySerialNumber="FFFF9876543210E00008"Saída:
{ "PinBlock": "1F4209C670E49F83E75CC72E81B787D9", "KeyArn": "arn:aws:payment-cryptography:us-east-2:111122223333:key/ivi5ksfsuplneuyt "KeyCheckValue": "7CC9E2" }Para obter mais informações, consulte Traduzir dados de PIN no Guia do usuário do AWS Payment Cryptography.
-
Para obter detalhes da API, consulte TranslatePinData
em Referência de AWS CLI Comandos.
-
O código de exemplo a seguir mostra como usar verify-auth-request-cryptogram.
- AWS CLI
-
Como verificar uma solicitação de autenticação
O exemplo
verify-auth-request-cryptograma seguir verifica um criptograma de solicitação de autorização (ARQC).aws payment-cryptography-data verify-auth-request-cryptogram \ --auth-request-cryptogramF6E1BD1E6037FB3E\ --auth-response-attributes '{"ArpcMethod1": {"AuthResponseCode": "1111"}}' \ --key-identifierarn:aws:payment-cryptography:us-west-2:111122223333:key/pboipdfzd4mdklya\ --major-key-derivation-mode"EMV_OPTION_A"\ --session-key-derivation-attributes '{"EmvCommon": {"ApplicationTransactionCounter": "1234","PanSequenceNumber": "01","PrimaryAccountNumber": "471234567890123"}}' \ --transaction-data"123456789ABCDEF"Saída:
{ "AuthResponseValue": "D899B8C6FBF971AA", "KeyArn": "arn:aws:payment-cryptography:us-west-2:111122223333:key/pboipdfzd4mdklya", "KeyCheckValue": "985792" }Para obter mais informações, consulte verificar um criptograma de solicitação de autorização (ARQC) no Guia do usuário do AWS Payment Cryptography.
-
Para obter detalhes da API, consulte VerifyAuthRequestCryptogram
em Referência de AWS CLI Comandos.
-
O código de exemplo a seguir mostra como usar verify-card-validation-data.
- AWS CLI
-
Para validar um CVV
O
verify-card-validation-dataexemplo a seguir valida um CVV/ CVV2 para um PAN.aws payment-cryptography-data verify-card-validation-data \ --key-identifierarn:aws:payment-cryptography:us-east-2:111122223333:key/tqv5yij6wtxx64pi\ --primary-account-number=171234567890123 \ --verification-attributesCardVerificationValue2={CardExpiryDate=0123}\ --validation-data801Saída:
{ "KeyArn": "arn:aws:payment-cryptography:us-east-2:111122223333:key/tqv5yij6wtxx64pi", "KeyCheckValue": "CADDA1" }Para obter mais informações, consulte Verificar dados de cartões no Guia do usuário do AWS Payment Cryptography.
-
Para obter detalhes da API, consulte VerifyCardValidationData
em Referência de AWS CLI Comandos.
-
O código de exemplo a seguir mostra como usar verify-mac.
- AWS CLI
-
Como verificar um MAC
O
verify-macexemplo a seguir verifica um Código de Autenticação de Mensagens Baseado em Hash (HMAC) para autenticação de dados do cartão usando o algoritmo HMAC_ SHA256 e uma chave de criptografia HMAC.aws payment-cryptography-data verify-mac \ --key-identifierarn:aws:payment-cryptography:us-east-2:111122223333:key/qnobl5lghrzunce6\ --message-data"3b343038383439303031303733393431353d32343038323236303030373030303f33"\ --verification-attributes='Algorithm=HMAC_SHA256' \ --macED87F26E961C6D0DDB78DA5038AA2BDDEA0DCE03E5B5E96BDDD494F4A7AA470CSaída:
{ "KeyArn": "arn:aws:payment-cryptography:us-east-2:111122223333:key/qnobl5lghrzunce6, "KeyCheckValue": "2976E7", }Para obter mais informações, consulte Verificar MAC no Guia do usuário do AWS Payment Cryptography.
-
Para obter detalhes da API, consulte VerifyMac
em Referência de AWS CLI Comandos.
-
O código de exemplo a seguir mostra como usar verify-pin-data.
- AWS CLI
-
Como verificar um PIN
O exemplo
verify-pin-dataa seguir valida um PIN para um PAN.aws payment-cryptography-data verify-pin-data \ --verification-key-identifierarn:aws:payment-cryptography:us-east-2:111122223333:key/37y2tsl45p5zjbh2\ --encryption-key-identifierarn:aws:payment-cryptography:us-east-2:111122223333:key/ivi5ksfsuplneuyt\ --primary-account-number171234567890123\ --pin-block-formatISO_FORMAT_0\ --verification-attributes VisaPin="{PinVerificationKeyIndex=1,VerificationValue=5507}" \ --encrypted-pin-blockAC17DC148BDA645ESaída:
{ "VerificationKeyArn": "arn:aws:payment-cryptography:us-east-2:111122223333:key/37y2tsl45p5zjbh2", "VerificationKeyCheckValue": "7F2363", "EncryptionKeyArn": "arn:aws:payment-cryptography:us-east-2:111122223333:key/ivi5ksfsuplneuyt", "EncryptionKeyCheckValue": "7CC9E2", }Para obter mais informações, consulte Verificar dados de PIN no Guia do usuário do AWS Payment Cryptography.
-
Para obter detalhes da API, consulte VerifyPinData
em Referência de AWS CLI Comandos.
-