• 算法系列7《CVN》


    计算CVN时使用二个64位的验证密钥,KeyA和KeyB。

     

     

    1) 计算CVN 的数据源包含: 主账号(PAN)、卡失效期和服务代码,从左至右顺序编排。

    4123456789012345+8701+111

     

    2) 将上述数据源扩展成128 位二进制数据(不足128 位右补二进制0)。

    41234567890123458701111+000000000

     

    3) 将128 位二进制数据分成两个64 位的数据块。最左边的64 位为Block1,最右边的64 位为 Block2。

    KeyA=0123456789ABCDEF ,Block1=4123456789012345

     

    4) 使用KeyA 对Block1 进行加密。

    3DES_ENC(Block1, KEYA, ENCA)

    ENCA = B76ADDCE71CCC6BE

     

    5) 将Block1 的加密结果与Block2 进行异或。使用KeyA 对异或结果进行加密。

    Block2=8701111000000000

    ENCB=XOR(Block2, ENCA)

    ENCB=306BCCDE71CCC6BE

    3DES_ENC(ENCB, KEYA, ENCC)

    ENCC=BAE6746F6DE1F0E6

    KEYB=FEDCBA9876543210

     

    6) 使用KeyB 对加密结果进行解密。

    3DES_DE(ENCC, KEYB, ENCD)

    ENCD = B262ABCB9DE99A63

     

    7) 使用KeyA 对解密结果进行加密。

    3DES_ENC(ENCD, KEYA, ENCE)

    ENCE=8D5625FA78011A0C

     

    8) 从左至右将加密结果中的数字(0-9)抽出,组成一组数字。

    CCRSN=85625780110

     

    9) 从左至右将加密结果中的字符(A-F)抽出,减10 后将余数组成一组数字,排列在步骤(8) 的数字之后。

    CCRSA=DFAAC

    CCRSA-10=35002//每一位分别减10

    RST=85625780110 35002

     

    10)步骤(9)的左边第一组三位数即为CVN 值。

    CVN=856

     

  • 相关阅读:
    mybatis返回map类型数据空值字段不显示(三种解决方法)
    linux各种资源查看
    ssh代理
    python 自定义ping编写
    python 备忘(协程,多进程)
    python 控制电源模块for循环写法
    XPath 语法
    python 自定义去掉特殊字符串
    ssh证书登陆vpc/并且反向代理
    cmder设置
  • 原文地址:https://www.cnblogs.com/zfyouxi/p/4031937.html
Copyright © 2020-2023  润新知