Rechercher une page de manuel
getservent
Langue: ko
Version: 1996년 4월 22일 (fedora - 25/11/07)
Section: 3 (Bibliothèques de fonctions)
이름
getservent, getservbyname, getservbyport, setservent, endservent - 서비스 엔트리를 가져온다.사용법
#include <netdb.h> struct servent *getservent(void); struct servent *getservbyname(const char *name, const char *proto); struct servent *getservbyport(int port, const char *proto); void setservent(int stayopen); void endservent(void);
설명
getservent() 함수는 파일 /etc/services에서 다음 라인을 읽고 그 라인에서 뽑아낸 필드들을 포함하는 구조체 servent를 반한한다. /etc/services 파일은 필요하다면 열려진다.getservbyname() 함수는 /etc/services에서 프로토콜 proto을 사용하며 서비스 name 과 일치하는 라인에 해당하는 servent 구조체를 반환한다.
getservbyport() 함수는 프로토콜 proto을 사용하며 네트웍 바이트 순서로 주어진 포트 port과 일치하는 servent 구조체를 반환한다.
setservent() 함수는 /etc/services 파일을 열고 다시 원래대로 돌려놓는다. 만일 stayopen 가 참(1)이라면, 파일은 getservbyname() 과 getservbyport() 호출시 닫혀지지 않는다.
endservent() 함수는 /etc/services를 닫는다.
servent 구조체는 다음처럼 <netdb.h>에 정의되어 있다:
-
struct servent { char *s_name; /* 공식적인 서비스 이름 */ char **s_aliases; /* 별칭 리스트 */ int s_port; /* 포트 번호 */ char *s_proto; /* 사용하는 프로토콜 */ }
servent 구조체의 멤버는:
- s_name
- 서비스의 공식적인 이름.
- s_aliases
- 서비스를 위해 선택할수 있는 널로 종료된 리스트
- s_port
- 네트웍 바이트 순서로 주어진 서비스의 포트 번호
- s_proto
- 이 서비스에서 사용하는 프로토콜 이름
반환값
getservent(), getservbyname() 그리고 getservbyport() 함수는 servent 구조체를 반환하거나, 만일 에러가 일어나거나 파일의 끝에 도착한다면 NULL 포인터를 반환한다.파일
- /etc/services
- 서비스 데이터 파일
호환
BSD 4.3관련 항목
getprotoent(3), getnetent(3), services(5)역자
정강훈 <skyeyes@soback.kornet.net>, 2001년 4월 30일Contenus ©2006-2023 Benjamin Poulain
Design ©2006-2023 Maxime Vantorre