dongshenyu4638 2017-11-12 09:07
浏览 32

wincrypt输出与其他语言不匹配

I've been attempting to play around with the wincrypt api, but can't seem to figure out why the output from CryptEncrypt doesn't match the output from a language like Go.

wincrypt code

BYTE *inBuffer = (BYTE*)"Hello World";
HCRYPTPROV phProv = NULL;
HCRYPTKEY key = NULL;
HCRYPTHASH hHash = NULL;
DWORD len = bufLen;

BYTE password[] = "password";
DWORD passLen = strlen((char*)password);

if (!CryptAcquireContext(&phProv, NULL, NULL, PROV_RSA_FULL, 0)) {
    DWORD dwStatus = GetLastError();
    error.Fatal("CryptAcquireContext error %d", dwStatus);
}

if (!CryptCreateHash(phProv, CALG_MD5, 0, 0, &hHash)) {
    DWORD dwStatus = GetLastError();
    error.Fatal("CryptCreateHash error %d", dwStatus);
}

if (!hHash)
    error.Fatal("Hash create fail");

if (!CryptHashData(hHash, password, passLen, 0)) {
    DWORD dwStatus = GetLastError();
    error.Fatal("CryptHashData error %d", dwStatus);
}

if (!CryptDeriveKey(phProv, CALG_RC4, hHash, CRYPT_EXPORTABLE, &key)) {
    DWORD dwStatus = GetLastError();
    error.Fatal("CryptDeriveKey error %d", dwStatus);
}

if (!CryptEncrypt(key, 0, TRUE, 0, NULL, &len, 0)) {
    DWORD dwStatus = GetLastError();
    error.Fatal("CryptEncrypt error %d", dwStatus);
}

outBuffLen = len;
BYTE *cipherBlock = (BYTE*)calloc(len, sizeof(BYTE));
memcpy_s(cipherBlock, len, inBuffer, len);
if (!CryptEncrypt(key, 0, TRUE, 0, cipherBlock, &len, outBuffLen)) {
    DWORD dwStatus = GetLastError();
    error.Fatal("CryptEncrypt error %d", dwStatus);
}


CryptDestroyKey(key);
CryptReleaseContext(phProv, 0);
CryptDestroyHash(hHash);

go code

package main

import (
    "crypto/rc4"
    "fmt"
    "log"
)

func main() {
    key := []byte("5f4dcc3b5aa765d61d8327deb882cf99")
    src := []byte("Hello World")
    c, err := rc4.NewCipher(key)
    if err != nil {
        log.Fatal(err)
    }
    dst := make([]byte, len(src))
    c.XORKeyStream(dst, src)
    for _, x := range dst {
        fmt.Printf("%02X ", x)
    }
}

If the key is "password" the output should be: B7 90 54 62 23 1E E3 C1 13 3D CF

If the key is md5 hash of "password" ("5f4dcc3b5aa765d61d8327deb882cf99") the output should be: E4 F9 36 64 83 8A 3F 78 41 82 15

The output I'm getting from wincrypt: a0 9d 47 51 1a 7b 32 8e 03 54 c3

Is there something simple I'm missing?

  • 写回答

0条回答 默认 最新

    报告相同问题?

    悬赏问题

    • ¥15 基于卷积神经网络的声纹识别
    • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
    • ¥100 为什么这个恒流源电路不能恒流?
    • ¥15 有偿求跨组件数据流路径图
    • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值
    • ¥15 我想咨询一下路面纹理三维点云数据处理的一些问题,上传的坐标文件里是怎么对无序点进行编号的,以及xy坐标在处理的时候是进行整体模型分片处理的吗
    • ¥15 CSAPPattacklab
    • ¥15 一直显示正在等待HID—ISP
    • ¥15 Python turtle 画图
    • ¥15 stm32开发clion时遇到的编译问题