简单加密

发布时间:2016-12-7 0:03:49 编辑:www.fx114.net 分享查询网我要评论
本篇文章主要介绍了"简单加密",主要涉及到简单加密方面的内容,对于简单加密感兴趣的同学可以参考一下。

将整形加密成字符串后存放在文件中,从文件读取字符串还原整形。可以防篡改。 加密部分可以完善一下,用循环。还可以增加一些参数:如位数。 // 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_)

上一篇:Hadoop分布式文件系统和OpenStack对象存储有何不同
下一篇:今日学Oracle心得

相关文章

关键词: 简单加密

相关评论