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

О проекте

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

MySQL

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

Хостинг

Другое








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

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

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

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

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

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

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

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

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

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

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

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



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





Руководство пользователя для 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