首页 | 资讯动态 | linux基础 | 系统管理 | 网络管理 | 编程开发 | linux数据库 | 服务器技术 | linux相关 | linux认证 | 嵌入式 | 下载中心 | 专题 | linux招聘 | HR | 镜像
OKLinux中文技术站
·设为首页
·加入收藏
·联系我们
系统管理: 中文环境 系统管理 桌面应用 内核技术 | Linux基础: 基础入门 安装配置 常用命令 经验技巧 软件应用 | Linux数据库: Mysql Postgre Oracle DB2 Sybase other
网络管理: 网络安全 网络应用 Linux服务器 环境配置 黑客安全 | 编程开发: PHP CC++ Python Perl Shell 嵌入式开发 java jsp | PHP技术: PHP基础 PHP技巧 PHP应用 PHP文摘
搜索中心 Linux招聘 Linux专题 Apache | Linux相关: 硬件相关 Linux解决方案 Linux认证 企业应用 其它Unix | 相关下载: 资料下载 参考手册 开发工具 服务器类 软路由 其它
 技术搜索:
会员中心 注册会员 高级搜索  
  → 当前位置:首页>系统管理>内核技术>正文

Linux 密钥保留服务入门

http://www.oklinux.cn  2007-07-14  IBM   会员收藏  游客收藏  【 】 
您查看的文章来源于http://www.oklinux.cn
Linux® 密钥保留服务是在 Linux 2.6 中引入的,这是在 Linux 平台上处理身份验证、密码学、跨域用户映射和其他安全问题的出色的新方法。了解 Linux 密钥保留服务的组件,并通过一个示例应用程序了解它的使用方法。

Linux 密钥保留服务(Linux key retention service)是在 Linux 2.6 中引入的,它的主要意图是在 Linux 内核中缓存身份验证数据。远程文件系统和其他内核服务可以使用这个服务来管理密码学、身份验证标记、跨域用户映射和其他安全问题。它还使 Linux 内核能够快速访问所需的密钥,并可以用来将密钥操作(比如添加、更新和删除)委托给用户空间。

本文将概述 Linux 密钥保留服务,定义它的术语,帮助您快速掌握 Linux 密钥的使用方法。您将通过示例代码了解如何在内核模块中使用 Linux 密钥保留服务。在编写本文时使用的内核版本是 2.6.20。

什么是密钥?

密钥(key)是一组密码学数据、身份验证标记或某些相似的元素,它在内核中由 struct key 表示。在 Linux 内核源代码中,struct key 是在 include/linux/key.h 下定义的。

清单 1 给出 struct key 中一些重要的字段。注意,为了支持密钥,已经修改了 task_structuser_structsignal_struct


清单 1. struct key 中的重要字段
                
struct key {
      atomic_t                 usage;       /* number of references */
      key_serial_t           serial;        /* key serial number */
      struct key_type      *type;        /* type of key */
      time_t                     expiry;  /* time at which key expires (or 0) */
      uid_t                       uid;           /* UID */
      gid_t                       gid;           /* GID */
      key_perm_t            perm;        /* access permissions */
      unsigned short       quotalen;   /* length added to quota */
      unsigned short       datalen;     /* payload data length
      char                      *description;
      union {
          unsigned long             value;
          void                            *data;
          struct keyring_list       *subscriptions;
      } payload;                                 /* Actual security data */
      ....
      ....
};

密钥的属性

密钥具有以下属性:

  • 序号(Serial number):一个惟一的 32 位非零正数。
  • 类型(Type):Linux 密钥保留服务定义两个标准密钥类型:user 和 keyring。要添加新的密钥类型,必须由一个内核服务注册它。用户空间程序不允许创建新的密钥类型。密钥类型在内核中由 struct key_type 表示,这是在 include/linux/key.h 中定义的。key_type 结构的一些重要字段见清单 2。

    清单 2. key_type 的重要字段
                            
    struct key_type {
        const char *name;
        size_t def_datalen;
        
    	/* Operations that can be defined for a key_type */
        int (*instantiate)(struct key *key, const void *data, size_t datalen);
        int (*update)(struct key *key, const void *data, size_t datalen);
        int (*match)(const struct key *key, const void *desc);
        void (*revoke)(struct key *key);
        void (*destroy)(struct key *key);
        void (*describe)(const struct key *key, struct seq_file *p);
        long (*read)(const struct key *key, char __user *buffer, size_t buflen);
        ....
        ....
    };
     
    

    还可以将一组操作与一个密钥类型相关联。key_type 可以定义以下操作:
    • instantiate 创建指定类型的一个新密钥。
    • describe 输出描述这个密钥的文本。
    • match 根据描述搜索密钥。
    • destroy 清除与一个密钥相关的所有数据。
    • request_key 搜索密钥。
    • revoke
      共8页: 上一页 1 [2] [3] [4] [5] [6] [7] [8] 下一页

上一篇:OProfile 对 POWER 的支持   下一篇:Linux 上的 WebSphere MQ 开发快速入门

收藏于收藏夹】 【评论】 【推荐】 【打印】 【关闭
相关文档
·OProfile 对 POWER 的支持
·基于S3C44B0微处理器的uClinux内核引导剖析
·Linux操作系统内核技术详细解读
·介绍Linux内核函数Start_kernel()的功能
·Linux操作系统内核开发者的一个实用技巧
·基于Linux操作系统上的C编程与内核导读
·减少Linux内核空循环来降低系统能耗技巧
·几个重要的RedHat Linux内核文件详细介绍
·Linux 2.6内核的编译步骤及模块的动态加载
·Linux系统内核中网络参数的意义及其应用
·Linux操作系统的内核编译步骤
·VMware环境下Linux内核编译过程详细解析
·Debian Linux系统下的内核编译详细讲解
·编译Linux操作系统内核的步骤
·通过Linux系统的内核观察/proc/pid/statm
·Linux操作系统的内核解读入门
发表评论
密码: 匿名评论
评论内容:

(不超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规)
 
  最新文档
·再来个源代码分析阅读器:LXR
·源代码阅读利器:Source Navigator
·Linux系统下的MySQL数据库开发技术
·Fedora在下一代用户群鼓励使用和参与开
·centos5.1下编译Linux内核
·Suse Linux系统下JAVA AWT界面乱码问题
·在Linux下发布程序需要注意版本的软件
·使用initrd文件系统 U-boot引导Linux方
·Linux系统下后台执行程序
·Linux如何在系统运行过程中修改内核参
·Linux系统进程的几个用户ID及其转换方
·Linux系统下安装phpmyadmin方法介绍
  阅读排行
· 深入理解LINUX内核中文版下载地址
·Linux操作系统源代码详细分析(一)
·Bochs 调试技术
· Linux下通用线程池的创建与使用(上)
·基于S3C44B0微处理器的uClinux内核引导
·软件产品发布流程
·Linux操作系统源代码详细分析(二)
·Linux操作系统的内核编译内幕详解
· Linux内核编程实战经验谈
·Linux系统线程同步:互斥量(mutex)
·Kernel command using Linux system ca
·linux 内核版本号
·推荐:Linux用户态与内核态的交互
·Linux 2.6内核的编译步骤及模块的动态
·解析Linux中的VFS文件系统机制
网摘收藏: