How can I bind() to a port number < 1024?



How can I bind() to a port number < 1024?..

Answer / chaitanya

The restriction on access to ports < 1024 is part of a (fairly weak) security scheme particular to UNIX. The intention is that servers (for example rlogind, rshd) can check the port number of the client, and if it is < 1024, assume the request has been properly authorised at the client end.

The practical upshot of this, is that binding a port number < 1024 is reserved to processes having an effective UID == root.

This can, occasionally, itself present a security problem, e.g. when a server process needs to bind a well-known port, but does not itself need root access (news servers, for example). This is often solved by creating a small program which simply binds the socket, then restores the real userid and exec()s the real server. This program can then be made setuid root.

Is This Answer Correct ?    0 Yes 0 No

Post New Answer

More Unix Socket Programming Interview Questions

How do I convert a string into an internet address?

0 Answers  


Is there any advantage to handling the signal, rather than just ignoring it and checking for the EPIPE error? Are there any useful parameters passed to the signal catching function?

0 Answers  


What exactly is a socket?

0 Answers  


Where is the socket located?

0 Answers  


What is the difference between a socket and a port?

0 Answers  






How is a socket created?

0 Answers  


What is LILO?

2 Answers  


How does unix socket work?

0 Answers  


Why do I get EPROTO from read()?

0 Answers  


How does a socket work?

0 Answers  


How should I choose a port number for my server?

1 Answers  


Can multiple sockets use the same port?

0 Answers  


Categories