• [开源]用MQL4实现MD5加密


    本文转载自博客园:混沌的世界

    原文地址: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  改一下,就变成一种新的加密算法了。

    这就是你自己写算法的好处。

  • 相关阅读:
    前端安全【面试】
    防xss攻击
    前端工程化
    前端项目构建——运维
    react入门
    OpenGL Windows 窗口程序环境搭建
    Django 列的自定义显示
    设计模式之 SOA面向服务的体系
    设计模式之Builder建造者模式 代码初见
    设计模式之Factory工厂模式的好处
  • 原文地址:https://www.cnblogs.com/yangwujun/p/4442434.html
Copyright © 2020-2023  润新知