Unix函数库中CrackLib原理及应用

系统 其他OS
我们在文章中,会讲解下Unix函数库中CrackLib原理及应用。CrackLib 字典可直接从网上下载,也可以用它提供的工具生成。

在Unix系统中,我们要学习的东西有很多。今天,我们就来学习下Unix函数库中CrackLib原理及应用。CrackLib是一个用于Unix函数库, 它可以用于编写和口令有关的程序。其基本思想就是通过限制用户使用使用过于简单、容易被猜测出来或容易被一些工具搜索到的密码,来提高系统的安全性。

CrackLib并不是一个可以直接运行使用的程序, 它只是一个Unix函数库, 可以利用其中的函数写自己的程序或是加入其它程序中以提高安全性,如可以改写passwd 使用户在选择密码时受到限制。

CrackLib使用一个字典, 它查找字典以判断用户所选密码是不是安全的密码。用户也可以加入其它信息, 使用自己的字典。CrackLib通过建立索引和二元查找,效率非常高,其字典大小通常只有同等字典数的一半。下面介绍如何运用CrackLib。

1、Unix函数库构建cracklib字典

CrackLib可以很容易的在Internet上找到, 现在使用的版本多是2.7, 首先要确定字典安装的路径,即给DICTPATH赋值,形式为:目录+字典文件名(不包括后缀),如:DICTPATH=/usr/local/lib/pw_dict.。该变量值将在所有调用CrackLib函数的程序中用到,字典文件通常包括 /usr/local/lib/pw_dict.pwd,/usr/local/lib/pw_dict.pwi,/usr/local/lib/pw_dict.hwm三个文件。

CrackLib 字典可直接从网上下载,也可以用它提供的工具生成。如果想加入其它信息, 使用自己的字典,可将含有新词的文件放到SOURCEDICT目录如"/usr/dict/words"下,CrackLib会将所有文件合并起来,删除多余的词,将其压缩成字典文件,通常只有原文件40%-60%的大小。

2、Unix函数库在程序中调用函数

CrackLib函数可以被应用于很多地方, 只需加入简单的几行源码, 就可以得到非常好的效果。 char *FascistCheck(char *pw, char *dictpath) 是CrackLib中最常用的函数。其中 pw是用户选择的密码, 将被验证是不是安全的,dictpath是字典所在路径。

FascistCheck() 返回一个空指针,说明口令很安全,否则返回诊断出的字符串。下面是一个口令设置的简单示例, 用以说明CrackLib函数用法. 
 

  1. #ifndef CRACKLIB_DICTPATH     
  2. #define CRACKLIB_DICTPATH "/usr/local/lib/pw_dict"    
  3. #endif     
  4. ...    
  5. ...    
  6. ...     
  7. char *msg;     
  8. while(1) {    
  9. passbuf = getpass("请设定新密码:");    
  10. if (!*passbuf) {    
  11. (void)printf("密码设定取消, 继续使用旧密码\n");    
  12. break;    
  13. }      
  14. if (strlen(pussbuf) <= 4 ││ !strcmp( passbuf, newuser.userid ) ) {    
  15. (void)printf("密码太短或与使用者代号相同, 请重新输入\n ");    
  16. continue;    
  17. }    
  18. if (msg = (char*) FascistCheck(passbuf, CRACKLIBPATH)) {    
  19. printf("请另选密码! (%s)\n",msg);    
  20. continue;    
  21. }    
  22. strncpy( newuser.passwd, passbuf, PASSLEN );    
  23. passbuf = getpass("请再输入一次你的密码 );    
  24. if( strncmp( passbuf, newuser.passwd, PASSLEN ) != 0 ) {    
  25. prints("密码输入错误, 请重新输入密码.\n") ;    
  26. continue;    
  27. }    
  28. passbuf[8] = '\0' ;    
  29. break;    

这样通过限制用户使用不安全的密码, 可以极大地提高系统的安全性。Unix函数库中的CrackLib原理及应用我们就讲解到这里了。

【编辑推荐】

  1. 8.1.3 UNIX口令散列
  2. Unix文件系统高级管理
  3. Unix文件系统备份概述
  4. Unix系统如何防止感染DOS系统病毒
  5. 鉴别Unix系统是否被入侵技巧
责任编辑:小霞
相关推荐

2009-09-17 13:15:12

NIS函数库

2011-08-23 15:02:59

LuaTable

2011-08-23 16:14:27

Lua函数库函数

2011-08-23 14:26:07

Lua字符串

2009-12-08 19:34:26

PHP拼写检查函数库

2009-09-16 10:43:22

PHP正则表达式函数

2020-11-16 12:40:55

Java开发机器学习

2010-06-13 10:18:08

MySQL 数据库函数

2009-11-16 15:07:23

PHP数组函数库

2021-07-10 07:41:20

Python中文函数库Python基础

2014-01-07 14:53:37

Android开发依赖注入Roboguice

2024-05-09 08:25:38

AndroidServiceLooper

2013-06-27 14:14:06

安卓开发经验安卓资源安卓UI

2016-02-17 16:04:42

2020-02-12 16:58:15

JavaScript前端技术

2010-05-11 13:16:21

Unix awk

2010-10-09 16:40:52

2017-03-16 14:37:05

LinuxShell函数

2024-02-05 22:53:59

前端开发

2023-05-26 08:02:11

工具函数库模块
点赞
收藏

51CTO技术栈公众号