C#中实现空间的登录加密密码脚本里的方法

近来想做一个数据采集器,考虑到一些网站需要登录才能查看信息,于是研究起了WebRequest中如何获得登陆的cookie。正好也打算把技术群里的聊天记录采集下来发布在空间,以便搜索。于是测试时研究的对象锁定为的精华帖页面。过程中遇到一个问题,空间登陆时会对提交的数据加密,是一个js脚本(http://imgcache.qq.com/ptlogin/js/comm.js),通过分析找到如下方法可以实现与该js脚本一样的加密方法:

public class QQPassword
{
    public static string binl2hex(byte[] buffer)
    { 
        StringBuilder builder = new StringBuilder();
        for (int i = 0; i < buffer.Length; i++)
        {
            builder.Append(buffer[i].ToString("x2"));
        }
        return builder.ToString();
    }
    public static string md5_3(string input)
    {
        MD5 md = MD5.Create();
        byte[] buffer = md.ComputeHash(Encoding.Default.GetBytes(input));
        buffer = md.ComputeHash(buffer);
        buffer = md.ComputeHash(buffer);
        return binl2hex(buffer);
    }

    public static string md5(string input)
    {
        byte[] buffer = MD5.Create().ComputeHash(Encoding.Default.GetBytes(input));
        return binl2hex(buffer);
    }

    public static string getPassword(string password, string verifycode)
    {
        return md5(md5_3(password).ToUpper() + verifycode.ToUpper()).ToUpper();
    }
}

你可能感兴趣的:(C++,c,qq,脚本,C#)