场景:使用c程序调用openssl在windows上进行加密,加密之后的结果放到linux环境中使用
问题:发现在windows中加密之后的密码,在linux环境中使用openssl进行解密得到的结果与加密之前不符
原因:发现是windows中echo会在打印的结果之后添加" \r\n",即一个空格和一个windows环境的换行符,因此在加密之前,原始密码就已经与预想的有所不同
解决:我在windows环境中采用了先将需要加密的字符串写入到文件中(不带换行符),使用openssl对文件进行加密,再读取加密之后的文件就可以在linux环境上进行解密操作并得到正确的结果。PS:需要注意一个情况,发现在windows环境加密文件过程中,在将原始字符串写入到文件时不能带换行符,但是后面必须多加一个空格,否则在解密后会发现密码减少一位。这应该是windows环境的openssl加密文件的机制所导致的,文件行最后一位不会被加密。