将整形加密成字符串后存放在文件中,从文件读取字符串还原整形。可以防篡改。 加密部分可以完善一下,用循环。还可以增加一些参数:如位数。
// SimpleSec.h: interface for the CSimpleSec class.
//
//
#if !defined(AFX_SIMPLESEC_H__92C4A0C2_ACA8_4A03_A669_DEE9CC7F9A05__INCLUDED_)
#define AFX_SIMPLESEC_H__92C4A0C2_ACA8_4A03_A669_DEE9CC7F9A05__INCLUDED_
#if _MSC_VER > 1000
#pragma once
#endif // _MSC_VER > 1000
class CSimpleSec
{
public:
CSimpleSec();
virtual ~CSimpleSec();
public:
CString Encrypt(long n)
{
char sz[16];
memset(sz, 0, sizeof(sz));
CString strTemp;
strTemp.Format(_T("%05d"), n);
int j = 0;
sz[0] = strTemp[j++];
sz[1] = (sz[0] + 1 - '0')%10 + '0';
sz[2] = strTemp[j++];
sz[3] = (sz[0] + sz[1] +sz[2] + 1- '0'*3)%10 + '0';
sz[4] = strTemp[j++];
sz[5] = (sz[0] + sz[1] +sz[2] + sz[3] + sz[4] + 1 - '0'*5)%10 + '0';
sz[6] = strTemp[j++];
sz[7] = (sz[0] + sz[1] +sz[2] + sz[3] + sz[4] + sz[5] + sz[6] +1- '0'*7)%10 + '0';
sz[8] = strTemp[j++];
sz[9] = (sz[0] + sz[1] +sz[2] + sz[3] + sz[4] + sz[5] + sz[6] + sz[7] + sz[8] + 1- '0'*9)%10 + '0';
strTemp = sz;
return strTemp;
}
bool Decrypt(CString str, long &nReslt)
{
if (str.GetLength() != 10) {
AfxMessageBox(_T("篡改"));
return false;
}
long nAcc = 0;
for (int i=1; i<=9; i++) {
if (!(i%2)) {
continue;
}
nAcc = 0;
for (int j=0; j<i; j++) {
nAcc += (str[j] - '0');
}
nAcc += 1;
nAcc %= 10;
nAcc += '0';
if ((str[i]) != (char)nAcc) {
AfxMessageBox(_T("篡改"));
return false;
}
}
//提取
AfxMessageBox(_T("开始提取"));
}
};
#endif // !defined(AFX_SIMPLESEC_H__92C4A0C2_ACA8_4A03_A669_DEE9CC7F9A05__INCLUDED_)