UNIX: разработка сетевых приложений
UNIX: разработка сетевых приложений читать книгу онлайн
Новое издание книги, посвященной созданию веб-серверов, клиент-серверных приложений или любого другого сетевого программного обеспечения в операционной системе UNIX, — классическое руководство по сетевым программным интерфейсам, в частности сокетам. Оно основано на трудах Уильяма Стивенса и полностью переработано и обновлено двумя ведущими экспертами по сетевому программированию. В книгу включено описание ключевых современных стандартов, реализаций и методов, она содержит большое количество иллюстрирующих примеров и может использоваться как учебник по программированию в сетях, так и в качестве справочника для опытных программистов.
Внимание! Книга может содержать контент только для совершеннолетних. Для несовершеннолетних чтение данного контента СТРОГО ЗАПРЕЩЕНО! Если в книге присутствует наличие пропаганды ЛГБТ и другого, запрещенного контента - просьба написать на почту [email protected] для удаления материала

Рис. 15.1. Программа mycat после создания потокового канала при использовании функции socketpair
Затем процесс взывает функцию
forkexecopenfile[1][0][1][0]
Рис. 15.2. Программа mycat после запуска программы openfile
Родительский процесс должен передать программе
openfile[1]execПреимущество выполнения дополнительной программы для открытия файла заключается в том, что за счет приравнивания привилегий пользователя к привилегиям владельца файла мы получаем возможность открывать те файлы, которые не имеем права открывать в обычной ситуации. Эта программа позволяет расширить концепцию обычных прав доступа Unix (пользователь, группа и все остальные) и включить любые формы проверки прав доступа. Мы начнем с программы
mycatЛистинг 15.7. Программа mycat: копирование файла в стандартный поток вывода
//unixdomain/mycat.c 1 #include "unp.h" 2 int my_open(const char*, int); 3 int 4 main(int argc, char **argv) 5 { 6 int fd, n; 7 char buff[BUFFSIZE]; 8 if (argc != 2) 9 err_quit("usage: mycat <pathname>");10 if ((fd = my_open(argv[1], O_RDONLY)) < 0)11 err_sys("cannot open %s", argv[1]);12 while ((n = Read(fd, buff, BUFFSIZE)) > 0)13 Write(STDOUT_FILENO, buff, n);14 exit(0);15 }Если мы заменим вызов функции
my_openopenФункция
my_openopenO_RDONLYЛистинг 15.8. Функция my_open: открытие файла и возвращение дескриптора
//unixdomain/myopen.c 1 #include "unp.h" 2 int 3 my_open(const char *pathname, int mode) 4 { 5 int fd, sockfd[2], status; 6 pid_t childpid; 7 char c, argsockfd[10], argmode[10]; 8 Socketpair(AF_LOCAL, SOCK_STREAM, 0, sockfd); 9 if ((childpid = Fork()) == 0) { /* дочерний процесс */10 Close(sockfd[0]);11 snprintf(argsockfd, sizeof(argsockfd), "%d", sockfd[1]);12 snprintf(argmode, sizeof(argmode), "%d", mode);13 execl("./openfile", "openfile", argsockfd, pathname, argmode,14 (char*)NULL);15 err_sys("execl error");16 }17 /* родительский процесс - ожидание завершения дочернего процесса */18 Close(sockfd[1]); /* закрываем конец, который мы не используем */19 Waitpid(childpid, &status, 0);20 if (WIFEXITED(status) == 0)21 err_quit("child did not terminate");22 if ((status = WEXITSTATUS(status)) == 0)23 Read_fd(sockfd[0], &c, 1, &fd);24 else {25 errno = status; /* установка значения errno в статус дочернего процесса */26 fd = -1;27 }28 Close(sockfd[0]);29 return (fd);30 }8socketpairsockfd[0]sockfd[1]9-16forkargsockfdargmodesnprintfopenfileexeclmainopenfile
