加密、解密、openssl的基本应用 及CA的实现过程

加密、解密技术

对称加密

 同一个钥匙可以对文件进行解密和加密。
 比如PC01对file文件进行加密传输给PC02,PC用key对file文件进行加密,然后通过网络传输给了PC02,PC02可以用key对文件进行解密

这里写图片描述

常见的对称加密算法有:
 DES:使用56位的密钥,2000年的时候被人破解了,所以现在基本不再使用
 AES:高级加密标准,可以使用128,129,256三种长度密钥
 其它:blowfish,Twofish和RC6,IDEA(商业算法),CAST5等

非对称加密

 需要两对秘钥,分别是公钥与私钥,她们是一对,如果用公开密钥对数据进行加密,只有用对应的私有密钥才能解密;如果用私有密钥对数据进行加密,那么只有用对应的公开密钥才能解密。
比如PC01要对file01加密传输给PC02,PC01用公钥加密file01文件,通过网路传输给PC02,PC02拿到文件后对私有私钥进行解密

非对称加密

常见的非对称加密算法有:
         RSA     加密和签名
         DSA     签名
         ElGamal  

openssl应用详解

1、安装openssl (默认已经安装)
2、子命令应用
   enc对称加密,des3加密方法, -in指定要加密的文件,-e表示加密,-out指定加密后要保存的位置, -salt 使加密过程更安全, -a 表示输出的结果保存为base64的文本编码格式,不指定会保存为二进制, -d 解密

用openssl实现自建CA

 1.准备两台PC 一台当服务端,一台当作客户端
服务器端
  1)生成秘钥对

             #openssl genrsa -out private/cakey.pem 2048如果想查看公钥:
            #openssl rsa -in private/cakey.pem -pubout -text -noout
 3.生成自签证书
   # openssl req -new -x509 -key private/cakey.pem -out cacert.pem -days 3655
 4.创建需要的文件:
    # touch index.txt serial crlnumber
 5.做好前面四步之后,接受客户端发来的httpd.csr后,进行签署
       1)CA签署证书
           # openssl ca -in /path/to/somefile.csr -out /path/to/somefile.crt -days DAYS
       2)发给客户端(请求者)
吊销证书:
    # openssl ca -revoke /path/to/somefile.crt 
客户端
 1)在主机上生成密钥,保存至应用此证书的服务的配置文件目录下, 例如:

        # mkdir /etc/httpd/ssl
        # cd /etc/httpd/ssl
        # openssl genrsa -out httpd.key 1024s
 2)生成证书签署请求:
        # openssl req -new -key httpd.key -out httpd.csr 
 3)将请求文件发往CA;
面向工程应用:市面上的一些密码学课程和密码学的书籍,很多都是从考证出发,讲解算法原理并不面向工程应用,而我们现在缺少的是工程应用相关的知识,本课程从工程应用出发,每种技术都主要讲解其在工程中的使用,并演示工程应用的代码。 从零实现部分算法: 课程中实现了base16编解码 ,XOR对称加解密算法,PKCS7 pading数据填充算法,通过对一些简单算法的实现,从而加深对密码学的理解。理论与实践结合: 课程如果只是讲代码,同学并不能理解接口背后的原理,在项目设计中就会留下隐患,出现错误也不容易排查出问题。如果只讲理论,比如对密码学的一些研究,对于大部分从事工程应用的同学并没有必要,而是理论与实践结合,一切为了工程实践。代码现场打出: 代码不放在ppt而是现场打出,更好的让学员理解代码编写的逻辑,老师现场敲出代码正是展示出了工程项目的思考,每个步骤为什么要这么做,考虑了哪些异常,易学不枯燥: 课程为了确保大部分人开发者都学得会,理解算法原理(才能真正理解算法特性),学会工程应用(接口调用,但不局限接口调用,理解接口背后的机制,并能解决工程中会出现的问题),阅读算法源码但不实现密码算法,,并能将密码学投入到实际工程中,如果是想学习具体的加密算法实现,请关注我后面的课程。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值