Re: чтение чужих файлов.
Igor Sysoev
igor на sysoev.ru
Пт Ноя 25 10:27:22 UTC 2011
On Fri, Nov 25, 2011 at 01:46:23PM +0400, Igor Sysoev wrote:
> On Fri, Nov 25, 2011 at 01:42:58PM +0400, Igor Sysoev wrote:
> > On Fri, Nov 25, 2011 at 01:34:18PM +0400, Anton Yuzhaninov wrote:
> > > On 11/25/11 13:25, Igor Sysoev wrote:
> > > > http://httpd.apache.org/docs/2.2/mod/core.html#options
> > > >
> > > > FollowSymLinks
> > > > SymLinksIfOwnerMatch
> > > >
> > > > This option should not be considered a security restriction,
> > > > since symlink testing is subject to race conditions that
> > > > make it circumventable.
> > > >
> > > > Отсюда возникает вопрос: имеет ли смысл тестировать каждый элемент
> > > > пути при каждом запросе, если это не даёт 100% гарантии ?
> > >
> > > В апаче сначала делают stat, потом open?
> > >
> > > А если сначала открыть файл, потом сделать fstat(), не позволит ли это избежать
> > > race?
> >
> > Нет, симлинк можно поставить в середину пути.
> > И O_NOFOLLOW похоже тоже не поможет, потому что:
> >
> > O_NOFOLLOW
> > If pathname is a symbolic link, then the open fails. This is a FreeBSD
> > extension, which was added to Linux in version 2.1.126. Symbolic links
> > in earlier components of the pathname will still be followed.
>
> Единственная 100% гарантия - mount -o nosymfollow.
Solaris 10 в этмо месте выглядит интереснее:
O_NOFOLLOW
If the path names a symbolic link, open() fails and sets errno to
ELOOP.
O_NOLINKS
If the link count of the named file is greater than 1, open() fails
and sets errno to EMLINK.
--
Игорь Сысоев
http://sysoev.ru
Подробная информация о списке рассылки nginx-ru