Чтобы помочь всем избежать путаницы, я переформулирую вопрос в двух частях.
Первое: "как сделать аутентифицированный HTTP-запрос с помощью браузера, используя BASIC-аутентификацию?" .
В браузере вы можете сначала выполнить базовую аутентификацию http, дождавшись появления приглашения или отредактировав URL, если вы придерживаетесь этого формата: http://myusername:mypassword@somesite.com
NB. Упомянутая в вопросе команда curl отлично подойдет, если у вас установлена командная строка и curl. ;)
Ссылки:
Также согласно странице руководства CURL https://curl.haxx.se/docs/manual.html
HTTP
Curl also supports user and password in HTTP URLs, thus you can pick a file
like:
curl http://name:passwd@machine.domain/full/path/to/file
or specify user and password separately like in
curl -u name:passwd http://machine.domain/full/path/to/file
HTTP offers many different methods of authentication and curl supports
several: Basic, Digest, NTLM and Negotiate (SPNEGO). Without telling which
method to use, curl defaults to Basic. You can also ask curl to pick the
most secure ones out of the ones that the server accepts for the given URL,
by using --anyauth.
NOTE! According to the URL specification, HTTP URLs can not contain a user
and password, so that style will not work when using curl via a proxy, even
though curl allows it at other times. When using a proxy, you _must_ use
the -u style for user and password.
Второй и реальный вопрос: "Однако на somesite.com я вообще не получаю приглашение на авторизацию, просто страница, на которой написано, что я не авторизован. Не реализован ли на некоторых сайтах рабочий процесс Basic Auth правильно, или мне нужно еще что-нибудь сделать? "
В документации по curl сказано, что опция -u
поддерживает множество методов аутентификации, по умолчанию используется Basic.