本文转载自博客园:混沌的世界
原文地址:http://www.cnblogs.com/niniwzw/archive/2009/12/05/1617685.html
在用MQL4进行金融交易的时候,经常需要发送账号信息到服务器。这些密码一般用明文发送,很容易被拦截,如果真实的账户信息被盗,后果不堪设想。钱的问题都不是小问题。今天下午,我老婆去上海了,闲着没有事情,就贡献一个吧。
MD5 的算法非常的简单,如果想了解相关的算法请参考:RFC 1321。我的算法 基本上 遵照这个标准进行编写。
具体代码在: http://code.google.com/p/md5-in-mql4/
这个算法的效率简单测试了一下,大概是C原始版本的 1/10 的速度。
这个算法只是针对字符串的MD5 进行了优化,字符串可以支持 MQL4 中最长的字符串。如果是对大文件进行MD5 进行加密,请稍微改进一下这个算法,我在设计的时候,也做了考虑,你可以很快的转换过来。
对于脚本语言实现 MD5 加密,最麻烦的就是 右移的问题,请参考文章:用 int 类型实现 unsinged int 形式 的 右移操作 。PHP 中,可以类似的进行处理,但是JS 中,提供了 >>> 操作符,不需要用我的方法。
如果,你想用其他的脚本语言来实现,如JS,要注意 加法的安全性,我预留了一个函数:AddUnsigned 这个函数,对MQL4 可以直接加,但是对某些JS的解析器
可能会出现问题,但是修复的方法也很简单,就是把 前 16位相加,然后 把后16位进行相加。注意前16位的进位:
var lsw = (x & 0xFFFF) + (y & 0xFFFF);
var msw = (x >> 16) + (y >> 16) + (lsw >> 16);
(msw << 16) | (lsw & 0xFFFF);
还有,如果,你是网上下载过来的算法,还要注意测试 中文情况下的准确性,很多算法没有考虑 中文。
虽然,各种语言差别不大,但是,也要考虑语言的差异,做到性能最优化。
现在网上有一些字典破解MD5的网站,其实,现在你不要怕他们了,你把算法中 初始的 a, b ,c, d 改一下,就变成一种新的加密算法了。
这就是你自己写算法的好处。