Chinaunix首页 | 论坛 | 博客
  • 博客访问: 289073
  • 博文数量: 73
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 452
  • 用 户 组: 普通用户
  • 注册时间: 2014-09-22 17:07
个人简介

心态决定命运

文章分类

全部博文(73)

文章存档

2017年(21)

2016年(27)

2015年(21)

2014年(4)

我的朋友

分类: 系统运维

2016-09-23 11:46:01

谷歌身份验证器生成的是动态验证码,默认30秒更新。修改配置,SSH登录必须在输入密码之前输入动态验证码。即使账号和密码泄露,验证码输入错误,仍然无法登录。苹果或者安卓手机端可以安装身份验证器App读取验证码。

1.安装前准备

a)Git 地址:https://github.com/google/google-authenticator.git

b)关闭Selinux :setenforce 0  这个必须关掉,否则登录时候,不会提示输入google-authenticator验证码

c)安装依赖:yum -y install gcc make pam-devel libpng-devel libtool wget git
d)添加阿里云epel 源:

点击(此处)折叠或打开

  1. #RHEL 6/Centos 6
  2.   wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-6.repo
  3. #.RHEL 7/Centos 7
  4.   wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo

e)安装Qrencode,谷歌身份验证器需要调用该程序生成二维码并显示

yum install -y qrencode

2.安装谷歌身份验证器

点击(此处)折叠或打开

  1. git clone https://github.com/google/google-authenticator.git
  2. cd /root/google-authenticator/libpam

CentOS服务器使用Google二次验证登陆 第2张

编译并安装

[root@node1 libpam]# ./bootstrap.sh && ./configure && make && make install

复制google 身份验证器pam模块到系统下

cp /usr/local/lib/security/pam_google_authenticator.so /lib64/security/

3.配置/etc/pam.d/sshd

添加图中红色框内的一行内容

CentOS服务器使用Google二次验证登陆 第3张

4.修改SSH服务配置/etc/ssh/sshd_config

  1. ChallengeResponseAuthentication no->yes
  2. sed -i 's#^ChallengeResponseAuthentication no#ChallengeResponseAuthentication yes#' /etc/ssh/sshd_config

5.重启SSH服务

  1. a)RHEL 6 / Centos6
  2. Service sshd restart
  3. b)RHEL7 /Centos 7
  4. Systemctl resart sshd

6.安装完成,开始验证。

a)切换到需要验证的系统账户,本案例使用root用户。
b)运行程序

  1. [root@DevOps24h ~]# google-authenticator
  2. Do you want authentication tokens to be time-based (y/n) y
  3. https://|0&cht=qr&chl=otpauth://totp/root@DevOps24h%3Fsecret%3DJS57SLVUDEEA7SQ7LD6BEBWGAA%26issuer%3DDevOps24h

CentOS服务器使用Google二次验证登陆 第4张

  1. Your new secret key is: JS57SLVUDEEA7SQ7LD6BEBWGAA
  2. Your verification code is 225960
  3. Your emergency scratch codes are: ##后备验证码保存好
  4. 50434230
  5. 90718846
  6. 71391250
  7. 25890913
  8. 60265036
  9.  
  10. Do you want me to update your "/root/.google_authenticator" file (y/n) y
  11.  
  12. Do you want to disallow multiple uses of the same authentication
  13. token? This restricts you to one login about every 30s, but it increases
  14. your chances to notice or even prevent man-in-the-middle attacks (y/n)
  15.  
  16. Do you want to disallow multiple uses of the same authentication
  17. token? This restricts you to one login about every 30s, but it increases
  18. your chances to notice or even prevent man-in-the-middle attacks (y/n) y
  19.  
  20. By default, tokens are good for 30 seconds. In order to compensate for
  21. possible time-skew between the client and the server, we allow an extra
  22. token before and after the current time. If you experience problems with
  23. poor time synchronization, you can increase the window from its default
  24. size of +-1min (window size of 3) to about +-4min (window size of
  25. 17 acceptable tokens).
  26. Do you want to do so? (y/n) y
  27.  
  28. If the computer that you are logging into isn't hardened against brute-force
  29. login attempts, you can enable rate-limiting for the authentication module.
  30. By default, this limits attackers to no more than 3 login attempts every 30s.
  31. Do you want to enable rate-limiting (y/n) y

7.终端设置google 二次身份验证登陆

打开xshell(其他终端类似),选择登陆主机的属性。设置登陆方法为Keyboard Interactive

CentOS服务器使用Google二次验证登陆 第5张

用户名:root(根据实际情况填写)
密码为空就好(因为需要先二次验证,再填入密码)

CentOS服务器使用Google二次验证登陆 第6张

二次验证码输入

CentOS服务器使用Google二次验证登陆 第7张

系统用户密码输入

CentOS服务器使用Google二次验证登陆 第8张

8.完美登陆

CentOS服务器使用Google二次验证登陆 第9张

阅读(1849) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~