关于使用vsftpd加密传输的问题调查

之前的工作中涉及到了linux系统下使用vsftpd向安卓sdk传输文件的功能,server端为linux 系统,client端为安卓系统,该项目针对不同的产品,使用了两款不同的厂商提供的安卓产品,安卓系统也不同,

之后甲方出于数据安全的考虑,要求添加加密传输功能,于是利用vsftpd,中openssl 的相关配置,对vsftpd添加了相关配置如下:

ssl_enable=YES     #之前不需要加密该配置项为NO,启用ssl为YES

allow_anon_ssl=NO        #匿名用户不用ssl

force_local_data_ssl=YES         #强制数据传输加密

force_local_logins_ssl=YES            #强制本地用户登录时加密

ssl_tlsv1=YES                         #启用tlsv1版本

ssl_sslv2=NO                       #禁用sslv2

ssl_sslv3=NO                      #禁用sslv3

rsa_cert_file=/***/***/vsftpd/vsftpd.pem       #server端证书文件的位置,同时相关证书也同步到了client端

基于之前的不带加密功能的ftp流程是通的,这里就不做过多整理了,可以参考其他资料,上文也说到了两款安卓产品,在添加完上述配置之后进行调试,发现其中一个的ftps流程正常,而另一个则会失败,问题来了,存在差异,差异在哪里呢?

下图是正常的ftps传输流程:

 

openssl版本对比:

Linux server端的openssl版本为1.0.2h
安卓侧系统默认openss库为1.0.1e,我们测试用的client demo apk,强行打包了1.0.2k 版本ssl库,是不是版本差异造成的呢?
 
失败的安卓client,tcpdump截取了cap文件发现,认证 AUTH TLS认证完毕,TboxServer端回复234后,车机Client端TLS 1.2 协议发送 Client Hello,Server回复Alert,握手失败
 
server端response信息为 “ error:1408A0C1:SSL routines:ssl3_get_client_hello:no shared cipher” 没有共享的加密套件。client发送了Hello,server拒绝,client与server都通过TLS 1.2协议,协议版本是没有问题的。
 
使用Curl进行调试,Server端回复Serverhello的TCPdump信息:

使用TLS1.2协议,

加密套件Cipher Suite: TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384 (0xc030)

与安卓client 端发送的serverhello中使用的加密套件作比对,确实没有发现该套件。问题就在这里,就是通过安卓系统访问server 端时,候选的加密套件中没有server端要求的加密套件TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384

而另一款安卓系统的ssl信息中是包含该加密套件的,所以流程是通的,为什么两个安卓系统的加密套件会有如此差异?询问了位懂安卓系统的大能,对于发行的JDK版本,做了很多加密长度限制的裁剪,即只有强度低的加密,所以对于server端要求的加密套件是不支持的。

怎么解决?安卓client端修改JDK?还是自己搞吧,看了下vsftpd的相关配置,发现vsftpd默认的加密套件是可配置的,所以添加ssl_ciphers=LOW 这个配置,继续调试,果然支持了,两个安卓系统的client端都完美支持了加密传输,打完收工。

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值