int nKeyLen = strKey.GetLength();
if (nKeyLen == 0)
strKey = _T("xxsswww");
srand((unsigned)time(NULL));
int nRange = 256;
int nOffset = (rand() % nRange);
CString strDest = _T("");
strDest.Format(_T("%1.2x"), nOffset);
int nSrcAsc = 0;
int nKeyPos = 0;
for (int nSrcPos = 0; nSrcPos < strSrc.GetLength(); nSrcPos++)
{
int n = strSrc[nSrcPos];
nSrcAsc = (strSrc[nSrcPos] + nOffset) % 255;
if (nKeyPos < nKeyLen - 1)
nKeyPos += 1;
else
nKeyPos = 1;
nSrcAsc = nSrcAsc ^ strKey[nKeyPos];
CString strTemp = _T("");
strTemp.Format(_T("%1.2x"), nSrcAsc);
strDest += strTemp;
nOffset = nSrcAsc;
}
return strDest;
请教如何将如下VC++代码转换成C#代码,谢谢
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答
- threenewbee 2016-03-23 23:00关注
int nKeyLen = strKey.Length; if (nKeyLen == 0) strKey = "xxsswww; Random rnd = new Random(); int nRange = 256; int nOffset = (rnd.NextInt() % nRange); string strDest = string.Format("{0:X2}", nOffset); int nSrcAsc = 0; int nKeyPos = 0; for (int nSrcPos = 0; nSrcPos < strSrc.Length; nSrcPos++) { int n = strSrc[nSrcPos]; nSrcAsc = (strSrc[nSrcPos] + nOffset) % 255; if (nKeyPos < nKeyLen - 1) nKeyPos += 1; else nKeyPos = 1; nSrcAsc = nSrcAsc ^ strKey[nKeyPos]; string strTemp = ""; strTemp = string.Format("{0:X2}", nSrcAsc); strDest += strTemp; nOffset = nSrcAsc; } return strDest;
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥30 这是哪个作者做的宝宝起名网站
- ¥60 版本过低apk如何修改可以兼容新的安卓系统
- ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏
- ¥50 有数据,怎么建立模型求影响全要素生产率的因素
- ¥50 有数据,怎么用matlab求全要素生产率
- ¥15 TI的insta-spin例程
- ¥15 完成下列问题完成下列问题
- ¥15 C#算法问题, 不知道怎么处理这个数据的转换
- ¥15 YoloV5 第三方库的版本对照问题
- ¥15 请完成下列相关问题!