Есть ли способ создавать запросы сертификатов SSL, указав все необходимые параметры в начальной команде? Я пишу Панель управления веб-сервером на основе интерфейса командной строки и я бы хотел избежать использования ожидать при выполнении openssl
если возможно.
Это типичный способ создания запроса на сертификат:
$ openssl req -new -newkey rsa:2048 -nodes -sha256 -keyout foobar.com.key -out foobar.com.csr
Generating a 2048 bit RSA private key
.................................................+++
........................................+++
writing new private key to 'foobar.com.key'
-----
You are about to be asked to enter information that will be incorporated
into your certificate request.
What you are about to enter is what is called a Distinguished Name or a DN.
There are quite a few fields but you can leave some blank
For some fields there will be a default value,
If you enter '.', the field will be left blank.
-----
Country Name (2 letter code) [AU]:US
State or Province Name (full name) [Some-State]:New Sweden
Locality Name (eg, city) []:Stockholm
Organization Name (eg, company) [Internet Widgits Pty Ltd]:Scandanavian Ventures, Inc.
Organizational Unit Name (eg, section) []:
Common Name (e.g. server FQDN or YOUR name) []:foobar.com
Email Address []:gustav@foobar.com
Please enter the following 'extra' attributes
to be sent with your certificate request
A challenge password []:
An optional company name []:FooBar
Я надеюсь увидеть что-то вроде этого: (неработающий пример)
$ openssl req -new -newkey rsa:2048 -nodes -sha256 -keyout foobar.com.key -out foobar.com.csr \
-Country US \
-State "New Sweden" \
-Locality Stockholm \
-Organization "Scandanavian Ventures, Inc." \
-CommonName foobar.com \
-EmailAddress gustav@foobar.com \
-Company FooBar
На прекрасной странице руководства не было ничего по этому поводу, и я не смог найти ничего через Google. Должно ли создание запроса сертификата SSL быть интерактивным процессом или есть способ указать все параметры в одной команде?
Это производный от Debian дистрибутив Linux, работающий openssl 1.0.1
.
вам не хватает двух частей:
строку темы, которую можно назвать
-subj "/C=US/ST=New Sweden/L=Stockholm /O=.../OU=.../CN=.../emailAddress=..."
X=
код X509 (Оорганизация /ОорганизацияUгнида / и т.д ...)значение пароля, которое можно назвать
-passout pass:client11
-passin pass:client11
мой призыв к новому ключу выглядит как
openssl genrsa -aes256 -out lib/client1.key -passout pass:client11 1024
openssl rsa -in lib/client1.key -passin pass:client11 -out lib/client1-nokey.key
openssl req -new -key lib/client1.key -subj req -new \
-passin pass:client11 -out lib/client1.csr \
-subj "/C=US/ST=New Sweden/L=Stockholm/O=.../OU=.../CN=.../emailAddress=..."
(теперь, когда я это вижу, есть два -new
...)
Проверить -batch
вариант, как описано в официальные документы.
Я добавляю к своей обычной команде openssl:
openssl req -x509 -nodes -days 7300 -newkey rsa: 2048 -keyout /etc/ssl/private/key.pem -out /etc/ssl/private/cert.pem
Эта строка:
-subj "/C=PE/ST=Lima/L=Lima/O=Acme Inc. /OU=IT Department/CN=acme.com"
Описание:
Используйте "/" как разделитель.