记录一下对接会话存档踩的坑,由于公司需要对接企业微信获取聊天记录,之前有使用SKIT.Flurl的sdk对接微信支付,自然就继续使用了;
对接按照SKIT.FlurlHttpClient.Wechat文档来即可;
主要问题:解密报错malformed sequence in RSA private key,在线验证公钥密钥是通过的;
原因是:密钥格式不正确,密钥格式需要PKCS#1格式,但实际是PKCS#8格式的,在线生成工具大多生成出来的都是PKCS#8格式,在线转换为PKCS#1格式大多也不对;
解决方案:使用openssl转换为PKCS#1
PKCS8 -> PKCS1
openssl rsa -in private_pkcs8.pem -out private_pkcs1.pem
特别需要注意的是openssl版本问题!!!
1.x运行没有问题;
3.x 需要显式增加一个参数 -traditional,否则转换后的密钥还是不可用
。
> openssl openssl rsa -in private_pkcs8.pem -out private_pkcs1.pem -traditional
另外记得把输入文件的开头结尾的 RSA 删掉。
PS:感谢SKIT.Flurl作者RHQYZ (fudiwei) 指导,顺带吐槽一下企业微信的官方api文档做得真的差;