加密的应用

加密的应用

一、实现对称加密

1、openssl enc

man enc

算法:3des, aes, blowfish, twofish

加密操作:openssl enc -e -des3 -a -salt -in testfile -out testfile.cipher

解密操作:openssl enc  -d -des3 -a  -salt -in testfile.cipher  -out testfile

2、gpg

 对称加密file 文件

gpg -c file

ls file.gpg

 在另一台主机上解密file

gpg -o file -d file.gpg

使用gpg实现公钥加密

1. 在 在hostB 主机上用公钥加密,在hostA 主机上解密

2. 在 在hostA 主机上生成公钥/ 私钥对

gpg –gen-key

3. 在hostA 主机上查看公钥

gpg –list-keys            此时的公钥文件为pubring.gpg,但是其为二进制文件。

1.jpg

4 .在 在hostA 主机上导出公钥到babyhanggege.pubkey,如上图。

gpg -a –export -o babyhanggege.pubkey

2.jpg

此时babyhanggege.pubkey中的文件已经是可读的符号了。

 5. 从hostA 主机上复制公钥文件到需加密的B主机上

scp babyhanggege.pubkey 10.1.44.3:

6.  在需加密数据的hostB 主机上生成公钥/ 私钥对

gpg –list-keys

gpg –gen-key

3.jpg

在生成随机数过程中尽量使用终端机来做,必要时需要多敲击键盘和移动鼠标。

7.在hostB 主机上导入公钥

gpg –import babyhanggege.pubkey   (导入密钥时要切换至A主机的密钥所在目录)

gpg –list-keys   (如图所示,此时就生成了两把密钥)

4.jpg

此时我查看B主机的密钥文件,发现并未看到babyhanggege.pubkey的文件,带着疑虑查看了pubring.gpg的二进制文件,在这里找到了答案,原来babyhanggege的公钥已经导进了B主机的pubring.gpg的文件中。(看下图的最后一行,便可找到答案)

5.jpg

8.用从A主机导入的公钥,加密hostB主机的文件file,生成file。gpg

命令:gpg -e -r babyhanggege f1

9.复制加密文件到hostA主机

scp f1.gpg 10.1.44.2:  默认拷贝至A主机的家目录下

10.在hostA主机解密文件

gpg -d f1.gpg (只能进行查看)

gpg -o f1 -d f1.gpg(可以将解密的文件保存下来)

6.jpg

11.删除公钥和私钥

A主机上

gpg –delete-secret-keys babyhanggege    

gpg –delete-keys babyhanggege

经试验要删除两个密钥,必须先删除私钥,才能删除公钥!

B主机上

gpg –delete-secret-keys hostB

gpg –delete-keys hostB

gpg –delete-keys babyhanggege (我们仅从A主机上导来了babyhanggege的公钥)

二、实现单向加密

1、openssl dgst

openssl dgst -md5[-hex]  /PATH/SOMEFILE

openssl dgst -md5 testfile

2、md5sum

md5sum /PATH/TO/SOMEFILE

3、sha1sum

4、sha224sum

5、sha256sum

三、生成密钥对儿

1、生成私钥

openssl genrsa -out /PATH/TO/PRIVATEKEY.FILE NUM_BITS

(umask 077;openssl genrsa -out key.pri -des 2048)

2、从私钥中提取出公钥

openssl rsa -in PRIVATEKEYFILE -pubout -out PUBLICKEYFILE

四、其他

 生成用户密码:

passwd 命令:man sslpasswd

openssl passwd -1 -salt SALT( 最多8 位)

openssl passwd -1 –salt centos

7.jpg

 生成随机数:man sslrand

openssl rand[-out file] [-randfile(s)] [-base64] [-hex]num

NUM:  表示字节数;-hex 时,每个字符4 位,出现的字符数为NUM*2

五、基于key验证

情形一、linux主机之间的ssh连接

A主机使用SSH去连接B主机

第一次连接时A主机会将B主机的/etc/ssh/ssh_host_rsa_key.pub中公钥拷贝至A主机自己的/root/.ssh/known_hosts,等下次连接时,B用自己私钥加密一个数据包给A时,A用此公钥去解密A用自己私钥加密的内容,如果能够解密,那么A会信任确实是之前的B。

1. 在客户端生成密钥对儿

ssh-keygen -t rsa [-P ''] [-f “/root/.ssh/id_rsa"]

#ssh-keygen –t rsa –P ‘’ -f “/root/.ssh/id_rsa”

我在centos7上直接ssh -keygen

8.jpg

2. 把公钥文件传输至远程服务器对应用户的家目录

ssh-copy-id [-i [identity_file]] [user@]host

ssh-copy-id -i ./sshd/id_rsa.pub babyhanggege@10.1.44.3

再次连接时就会发现已经不需要密码了。

只要将公钥文件任意传送给别的机器即可,实现连接任意机器无需密码。

3.添加口令

ssh-keygen -p

4.启用代理,让代理帮助记忆口令

情形二、Windows下xshell基于key验证

1、点击“工具”选项下,用户新建密钥生成向导

9.jpg

2、选择好密钥类型与密钥长度后,进行下一步。

10.jpg

3、名称信息的确认,该步是为私钥加密。

11.jpg

4、点击属性,点击公钥,保存公钥文件。

12.jpg

5.将公钥文件传给所想要连接的主机。

 cat id_rsa_1024.pub > /root/.ssh/authorized_keys

至此即可。

原创文章,作者:178babyhanggege,如若转载,请注明出处:http://www.178linux.com/48771

(0)
178babyhanggege178babyhanggege
上一篇 2016-09-26 07:44
下一篇 2016-09-26 07:44

相关推荐

  • samba

    Samba 简介:      Samba是一个能让Linux系统应用Microsoft网络通讯协议的软件,而SMB是Server Message Block的缩写,即为服务器消息块 ,SMB主要是作为Microsoft的网络通讯协议,后来Samba将SMB通信协议应用到了Linux系统上,就形成了现在的Samba软件。…

    系统运维 2016-11-01
  • N25期第七周作业

    创建一个10G分区,并格式为ext4文件系统   要求其block大小为2048, 预留空间百分比为2, 卷标为MYDATA, 默认挂载属性包含acl 挂载至/data/mydata目录,要求挂载时禁止程序自动运行,且不更新文件的访问时间戳 fdisk /dev/sdb # size 10G type 83 mke2fs -t ext4 -b 20…

    Linux干货 2017-02-28
  • 初学Linux文件目录结构

    /:根目录 /bin(binary):放置的是二进制文件。可执行的命令;非管理类的命令,通常是系统启动就需要的文件,供所有用户使用的基本命令;不能关联至独立分区, OS启动即会用到的程序。 /sbin:管理类的命令,通常只有管理员可以使用。 /lib:存放的是系统级别的库文件 /lib64:专用于x86_64系统上的辅助共享库文件存放位置  /ro…

    Linux干货 2017-07-13
  • Linux作业管理和并发执行

    概述 本章将为大家介绍一些进程管理的补充部分作业管理和任务的并发执行,同时也将介绍一下Linux系统上计划任务的相关内容,具体分为:1、Linux作业管理2、任务的并发执行 第一章 Linxu作业管理 1、前台作业和后台作业    前台作业:通过中断启动,且启动后一直占据终端    后台作业:可通过终端启动,但启动后即…

    Linux干货 2016-09-28
  • kickstart文件及引导镜像的制作流程

    kickstart文件及引导镜像的制作流程 kickstart文件制作流程 安装制作kickstart文件的图形界面工具 [root@slave1 ~]# yum install system-config-kickstart 开启工具 [root@slave1 ~]# system-config-kickstart 在打开的图形界面中通过file菜单选项选…

    Linux干货 2017-09-04
  • 0803权限管理作业练习

    0803权限管理作业练习 题目:创建组sales,gid 3000,passwd :centos,sales 的组管理员admins:user2 将用户user1,user2,user3加入到sales辅助组 希望user1创建新文件默认的所属组为sales user2将用户user3从sales组移除   答案:   &nbs…

    Linux干货 2016-08-05

评论列表(1条)

  • 马哥教育
    马哥教育 2016-09-26 13:23

    总结的很详细,操作性性很强,值得学习,