П О Р Т А Л                            
С Е Т Е В Ы Х                          
П Р О Е К Т О В                        
  
Поиск по сайту:
                                                 
Главная

О проекте

Web-мастеру
     HTML & JavaScript
     SSI
     Perl
     PHP
     XML & XSLT
     Unix Shell

MySQL

Безопасность

Хостинг

Другое








Самое читаемое:

Учебник PHP - "Для Чайника".
Просмотров 4072 раз(а).

Иллюстрированный самоучитель по созданию сайтов.
Просмотров 6722 раз(а).

Учебник HTML.
Просмотров 3693 раз(а).

Руководство по PHP5.
Просмотров 5966 раз(а).

Хостинг через призму DNS.
Просмотров 4773 раз(а).

Подборка текстов стандартных документов.
Просмотров 56218 раз(а).

Учебник PHP - Самоучитель
Просмотров 3665 раз(а).

Документация на MySQL (учебник & справочное руководство)
Просмотров 8250 раз(а).

Внешние атаки...
Просмотров 4517 раз(а).

Учебник PHP.
Просмотров 3154 раз(а).

SSI в примерах.
Просмотров 161 раз(а).



 
 
| Добавить в избранное | Сделать стартовой | Помощь





Руководство пользователя для GNU Awk

16. Практические awk-программы

16.1 Переизобретение колеса для забавы и пользы

16.1.3 Печать информации о пользователях

Утилита id перечисляет пользовательские реальные и фактические идентификационные номера, реальные и фактические групповые идентификационные номера, и, если они имеются, множества пользовательских групп. id печатает эффективные пользовательские и групповые идентификаторы только тогда, когда они отличаются от реальных. Если возможно, id также выдает пользовательские и групповые имена. Вывод может выглядеть так:

$ id
a uid=2076(arnold) gid=10(staff) groups=10(staff),4(tty)

Это та же самая информация, которая выдается специальным файлов gawk `/dev/user' (см. раздел 6.7 [Специальные имена файлов в gawk], стр. 72). Однако, утилита id обеспечивает более удобный вывод, чем просто цепочка чисел.

Приведем простую версию id, написанную на awk. Она использует библиотечные функции пользовательской базы данных (см. раздел 15.11 [Чтение пользовательской базы данных], стр. 192), и библиотечные функции групповой базы данных (см. раздел 15.12 [Чтение групповой базы данных], стр. 197).

Эта программа достаточно незамысловата. Вся работа делается в правиле BEGIN. Пользовательские и групповые идентификационные номера получаются от `/dev/user'. Если файла `/dev/user' нет, программа не работает.

В коде программы много повторений. Вход пользовательской базы с реальным числовым идентификатором расщепляется на части посредством `:'. Имя есть первое поле. Подобный же код используется для эффективного идентификационного номера пользователя и для групповых номеров.

# id.awk --- реализация  id в awk
# Arnold Robbins, arnold@gnu.org, Public Domain # May 1993
# выход таков:
# uid=12(foo) euid=34(bar) gid=3(baz) "
# egid=5(blat) groups=9(nine),2(two),1(one)

BEGIN " -
if ((getline ! "/dev/user") ! 0) -
err = "id: no /dev/user support - cannot run"
print err ? "/dev/stderr" exit 1 "" close("/dev/user")
uid = $1 euid = $2 gid = $3 egid = $4

printf("uid=%d", uid) pw = getpwuid(uid) if (pw != "") -
split(pw, a, ":") printf("(%s)", a[1]) ""
if (euid != uid) -
printf(" euid=%d", euid) pw = getpwuid(euid) if (pw != "") -
split(pw, a, ":") printf("(%s)", a[1]) "" ""
printf(" gid=%d", gid) pw = getgrgid(gid) if (pw != "") -
split(pw, a, ":") printf("(%s)", a[1]) ""
if (egid != gid) -
printf(" egid=%d", egid) pw = getgrgid(egid) if (pw != "") -
split(pw, a, ":") printf("(%s)", a[1]) "" ""
if (NF ? 4) -
printf(" groups="); for (i = 5; i != NF; i++) -
printf("%d", $i) pw = getgrgid($i) if (pw != "") -
split(pw, a, ":") printf("(%s)", a[1]) ""

if (i ! NF)
printf(",") "" "" print "" ""

Назад | Вперед
Содержание (общее) | Содержание раздела | Содержание подраздела



Если Вы не нашли что искали, то рекомендую воспользоваться поиском по сайту:
 





Copyright © 2005-2016 Project.Net.Ru