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;
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 请问一下这个运行结果是怎么来的
- ¥15 这个复选框什么作用?
- ¥15 单通道放大电路的工作原理
- ¥30 YOLO检测微调结果p为1
- ¥20 求快手直播间榜单匿名采集ID用户名简单能学会的
- ¥15 DS18B20内部ADC模数转换器
- ¥15 做个有关计算的小程序
- ¥15 MPI读取tif文件无法正常给各进程分配路径
- ¥15 如何用MATLAB实现以下三个公式(有相互嵌套)
- ¥30 关于#算法#的问题:运用EViews第九版本进行一系列计量经济学的时间数列数据回归分析预测问题 求各位帮我解答一下