IC卡 CN\AN\BIN数据解析 代码参考

#define DT_ANS	1        //TLV格式 ANS
#define DT_CN	2        //TLV格式 CN
#define DT_BIN	3        //TLV格式 Binary
#define DT_LR_ANS	4	//ANS解析 NO TAG&LENGTH
#define DT_LR_CN	5	//CN解析  NO TAG&LENGTH
#define DT_LR_BIN	6	//Binary NO tag&length


//TLV VALUE
//将数据补值到TLV格式
int Padding(int iType, unsigned char* pszMsgTag, int iMsgLen, unsigned char* pszData, int& iRetLen)
{
	unsigned char szData[512] = { 0 };
	int iDataLen = 0;

	if (iType == DT_ANS)
	{//左对齐,右补0

		memset(szData, 0, sizeof(szData));
		iDataLen = (iMsgLen*2) > iRetLen ? iRetLen : (iMsgLen*2);
		sprintf_s((char*)szData, (iMsgLen+2) * 2, "%.02s%02x%.*s", pszMsgTag, iMsgLen, iDataLen, pszData);
		 
		iRetLen = iMsgLen + 2;
		memset(pszData, 0, iRetLen);
		Bin2Hex(pszData, szData, iRetLen);
		iRetLen *= 2;

		return 0;
	}
	else if (iType == DT_CN)
	{//左对齐, 右补F
		if (iRetLen < 0)
			return 1;

		for (int i = 0; i != iRetLen; ++i)
		{//压缩数字数据校验,规范可支持A-F字符,此处应用只支持数字
			if (pszData[i] > 0x39 || pszData[i] < 0x30)
				return 1;
		}

		iDataLen = (iMsgLen*2)>iRetLen?iRetLen:iMsgLen;
		sprintf_s((char*)szData, (iMsgLen+2) * 2, "%.02s%02x%.*s", pszMsgTag, iMsgLen, iDataLen, pszData);

		if(((iMsgLen*2)-iRetLen)>0)
			memset(szData + iRetLen + 4, 'F', iMsgLen*2 - iRetLen);
		
		iRetLen = (iMsgLen + 2) * 2;
		pszData[iRetLen] = 0x0;

		return 0;
	}
	else if (iType == DT_BIN)
	{
		memset(szData, 0, sizeof(szData));
		iDataLen = (iMsgLen * 2) >= iRetLen ? (iMsgLen * 2) : iRetLen;
		sprintf_s((char*)szData, (iMsgLen + 2) * 2, "%02s%02x%.*s", pszMsgTag, iMsgLen, iDataLen, pszData);

		iDataLen = (iMsgLen + 2) * 2;
		memcpy(szData, pszData, iDataLen);
		pszData[iDataLen] = 0x0;
		iRetLen = iDataLen;

		return 0;
	}
	else if (iType == DT_LR_ANS)
	{
		memset(szData, 0, sizeof(szData));
		iDataLen = (iMsgLen * 2) > iRetLen ? iRetLen : (iMsgLen * 2);
		sprintf_s((char*)szData, iDataLen + 1, "%.*s", iDataLen, pszData);

		iRetLen = iMsgLen;
		memset(pszData, 0, iRetLen);
		Bin2Hex(pszData, szData, iRetLen);
		iRetLen *= 2;

		return 0;
	}
	else if (iType == DT_LR_CN)
	{//左对齐, 右补F
		if (iRetLen < 0)
			return 1;

		for (int i = 0; i != iRetLen; ++i)
		{//压缩数字,只支持数字
			if (pszData[i] > 0x39 || pszData[i] < 0x30)
				return 1;
		}

		iDataLen = (iMsgLen * 2) > iRetLen ? iRetLen : (iMsgLen * 2);
		sprintf_s((char*)szData, (iMsgLen + 2) * 2, "%.*s", iDataLen, pszData);

		if (((iMsgLen * 2) - iRetLen)>0)
			memset(szData + iRetLen, 'F', iMsgLen * 2 - iRetLen);

		iRetLen = iMsgLen * 2;
		memcpy(pszData, szData, iRetLen);
		pszData[iRetLen] = 0x0;

		return 0;
	}
	else if (iType == DT_LR_BIN)
	{
		memset(szData, 0, sizeof(szData));
		iDataLen = (iMsgLen * 2) >= iRetLen ? (iMsgLen * 2) : iRetLen;
		sprintf_s((char*)szData, (iMsgLen + 2) * 2, "%.*s", iDataLen, pszData);

		iDataLen = iMsgLen * 2;
		memcpy(szData, pszData, iDataLen);
		pszData[iDataLen] = 0x0;
		iRetLen = iDataLen;

		return 0;
	}
	else
		return 1;

	return 0;
}

//TLV
int TrimPadding(int iType, unsigned char* pszData, int& iLen)
{
	unsigned char szData[512] = { 0 };
	int iDataLen = 0;
	int iOffsetR = 0;

	if (iType == DT_ANS)
	{//左对齐,右补0
		Hex2Bin(szData, pszData, iLen);
		iLen /= 2;
		iDataLen = szData[1];
		if (iDataLen >= (iLen - 2))
		{
			for (iOffsetR = iLen; iOffsetR != 0; iOffsetR--)
			{
				if (szData[iOffsetR -1] == 0x0)
					continue;
				else
				{
					iDataLen = iOffsetR - 2;
					break;
				}
			}
		}
		else
		{
			for (iOffsetR = iDataLen + 2; iOffsetR != 0; iOffsetR--)
			{
				if (szData[iOffsetR -1] == 0x0)
					continue;
				else
				{
					iDataLen = iOffsetR - 2;
					break;
				}
			}
		}

		memcpy(pszData, szData + 2, iDataLen);
		pszData[iDataLen] = 0x0;
		iLen = iDataLen;
		return 0;
	}
	else if (iType == DT_CN)
	{//左对齐, 右补F
		Hex2Bin(szData, pszData, 4);
		iDataLen = (szData[1]*2) > (iLen - 4) ? iLen - 4 : (szData[1]*2);

		memset(szData, 0, sizeof(szData));
		memcpy(szData, pszData + 4, iDataLen);
		for (iOffsetR = iDataLen; iOffsetR != 0; iOffsetR--)
		{
			if (szData[iOffsetR-1] == 'F')
				continue;
			else
				break;
		}
	    iDataLen = iOffsetR;

		memcpy(pszData, szData, iDataLen);
		pszData[iDataLen] = 0x0;
		iLen = iDataLen;

		return 0;
	}
	else if (iType == DT_BIN)
	{
		Hex2Bin(szData, pszData, 4);
		iDataLen = (szData[1]*2) > (iLen - 4) ? iLen - 4 : (szData[1]*2);

		memcpy(szData, pszData + 4, iDataLen);
		memcpy(pszData, szData, iDataLen);
		pszData[iDataLen] = 0x0;
		iLen = iDataLen;

		return 0;
	}
	else if (iType == DT_LR_ANS)
	{
		Hex2Bin(szData, pszData, iLen);
		iDataLen  = iLen / 2;

	for (iOffsetR = iDataLen; iOffsetR != 0; iOffsetR--)
	{
		if (szData[iOffsetR - 1] == 0x0)
			continue;
		else
			break;
	}
	iDataLen = iOffsetR;

		memcpy(pszData, szData, iDataLen);
		pszData[iDataLen] = 0x0;
		iLen = iDataLen;
		return 0;
	}
	else if (iType == DT_LR_CN)
	{//左对齐, 右补F
		iDataLen = iLen;

		memcpy(szData, pszData, iDataLen);
		for (iOffsetR = iDataLen; iOffsetR != 0; iOffsetR--)
		{
			if (szData[iOffsetR -1] == 'F')
				continue;
			else
				break;
		}
	    iDataLen = iOffsetR;

		memcpy(pszData, szData, iDataLen);
		pszData[iDataLen] = 0x0;
		iLen = iDataLen;

		return 0;
	}
	else if (iType == DT_LR_BIN)
	{
		return 0;
	}
	else
		return 1;

	return 0;
}


//二进制与ASCII码转换函数
enum DataType
{
	BIN2HEX,
	HEX2BIN
};

int Hex2Bin(unsigned char* outBin, unsigned char* inHex, long lPair_length)
{
	char src1,src2,factor1,factor2;
	long len;
	factor1 = '7';
	factor2 = '7';
    _strupr( (char *)inHex );

	for (len=0; len < lPair_length; len++) 
	{
		src1 = *(inHex+len*2);
		src2 = *(inHex+len*2+1);
		if ((src1>='0') && (src1<='9'))
		    factor1 = '0';
	    else if ((src1>='A') && (src1<='F'))
		    factor1 = '7';
	    else 
			return 1;
		if ((src2>='0') && (src2<='9'))
		    factor2 = '0';
	    else if ((src2>='A') && (src2<='F'))
		    factor2 = '7';
	    else 
			return 1;
		src1 = src1 - factor1;
		src2 = src2 - factor2;
		*outBin++ = (src1 << 4) | src2; 
	}
	return 0;
}

int Bin2Hex(unsigned char* outHex, unsigned char* inBin, long length)
{
	UCHAR hLowbit,hHighbit;
    long i;
	for(i=0;i<length*2;i=i+2)
	{
		hLowbit=inBin[i/2]&0x0f;
		hHighbit=inBin[i/2]/16;
		if(hHighbit>=10)
			outHex[i]=hHighbit+'7';
		else
			outHex[i]=hHighbit+'0';
		if(hLowbit>=10)
			outHex[i+1]=hLowbit+'7';
		else
			outHex[i+1]=hLowbit+'0';
	}
	outHex[length*2]='\0';

	return 0;
}

//HEX2BIN 为宏 数据不大于300 Bytes
int SwitchDataMode(unsigned char* pszData, int* iDataLen, int iSwitchMode)
{
	unsigned char szDataHex[600], szDataBin[300];
	if(!pszData)
		return -1;

	if(iSwitchMode == HEX2BIN)
	{
		Hex2Bin(szDataBin, pszData, *iDataLen);
		memcpy(pszData, szDataBin, *iDataLen/2);
		pszData[*iDataLen/2] = '\0';
		*iDataLen = *iDataLen/2;
		return -1;
	}
	
	if(iSwitchMode == BIN2HEX)
	{
		Bin2Hex(szDataHex, pszData, *iDataLen);
		memcpy(pszData, szDataHex, *iDataLen*2);
		pszData[*iDataLen*2] = '\0';
		*iDataLen = *iDataLen *2;
		return -1;
	}
	return 0;
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值