zoukankan      html  css  js  c++  java
  • Linux中pam认证详解(上)

    一、pam的简介

    PAM(Pluggable Authentication Modules)即可插拔式认证模块,它是一种高效而且灵活便利的用户级别的认证方式,它也是当前Linux服务器普遍使用的认证方式。当然,在不同版本的Linux统中部署PAM认证是有所不同的。 

     

     

    它提供了对所有服务进行认证的中央机制,适用于login,远程登录(telnet,rlogin,fsh,ftp,点对点协议(PPP)),su等应用程序中。系统管理员通过PAM配置文件来制定不同应用程序的不同认证策略;应用程序开发者通过在服务程序中使用PAM API(pam_xxxx( ))来实现对认证方法的调用;而PAM服务模块的开发者则利用PAM SPI来编写模块(主要是引出一些函数pam_sm_xxxx( )供PAM接口库调用),将不同的认证机制加入到系统中;PAM接口库(libpam)则读取配置文件,将应用程序和相应的PAM服务模块联系起来。PAM框架结构如图所示。 

     

       

       

     

    二、pam认证原理

    PAM认证一般遵循这样的顺序:Service(服务)→PAM(配置文件)→pam_*.so。PAM认证首先要确定那一项服务,然后加载相应的PAM的配置文件(位于/etc/pam.d下),最后调用认证文件(位于/lib/security下)进行安全认证。认证原理图如下图所示:

       

     

    用户访问服务器的时候,服务器的某一个服务程序把用户的谁请求发送到PAM模块进行认证。对于不同的服务器应用程序所对应的PAM模块也是不同的。如果想查看某个程序是否支持PAM认证,可以用ldd命令进行查看,例如查看查看sshd是不是支持PAM模块认证,如下图所示:

       

     

       

     

    三、PAM认证的构成 

    客观地说PAM认证还是比较复杂的,这里只简单地介绍它包括四种常见认证类型(module type):

     

    1、认证管理(authentication management)

     

    接受用户名和密码,进而对该用户的密码进行认证,并负责设置用户的一些秘密信息。

     

    2、帐户管理(account management)

     

    检查帐户是否被允许登录系统,帐号是否已经过期,帐号的登录是否有时间段的限制等等。

     

    3、密码管理(password management)

     

    主要是用来修改用户的密码。

     

    4、会话管理(session management)

     

    主要是提供对会话的管理和记账(accounting)。

     

    四、pam验证控制类型(Control Values)

    验证控制类型也可以称做Control Flags,用于PAM验证类型的返回结果,具体有以下四种:

     

    1、required验证失败时仍然继续,但返回Fail(用户不会知道哪里失败)。

     

    2、requisite验证失败则立即结束整个验证过程,返回Fail。

     

    3、sufficient验证成功则立即返回,不再继续,否则忽略结果并继续。

     

    4、optional无论验证结果如何,均不会影响(通常用于session类型)。

     

    PAM验证类型返回结果如下所示:

     

       

     

    为了方便大家理解举两个例子,如下图所示:

       

     

       

     

    从上面两个图可以看出当required失败后续还要继续,但最后仍是失败。requisite验证失败则立即结束。而sufficient则是验证成功则立即结束。

     

    转自https://blog.51cto.com/tyjhz/1436175

  • 相关阅读:
    使用IDEA创建SpringMVC项目
    Spring基于注解的配置——@Required、@Autowired、@Qualifier示例及与传统注入方法的对比
    Spring基于构造函数和设值函数的依赖注入
    Mysql——通配符和正则表达式的使用
    Spring Bean的生命周期、后置处理器、定义继承
    Spring Bean的定义及作用域
    MySql——使用where子句过滤数据
    MySql——创建数据表,查询数据,排序查询数据
    MySQL的安装+可视化工具+JDBC的增删改查
    slave_master_info和slave_relay_log_info中的Master_log_pos不一致
  • 原文地址:https://www.cnblogs.com/zcyy/p/15695398.html
Copyright © 2011-2022 走看看