AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / ubuntu / 问题 / 1546455
Accepted
lensboard
lensboard
Asked: 2025-04-25 07:01:08 +0800 CST2025-04-25 07:01:08 +0800 CST 2025-04-25 07:01:08 +0800 CST

如何在 Ubuntu 24.04 中自动为 ./easyrsa gen-req 提供密码?

  • 772

原始问题:

我花了几个小时阅读手册并寻找答案,但所有的解决方案都已过时或不起作用。

我正在使用 Ubuntu 24.04.2 LTS

我想在 bash 脚本中执行此命令,并提前在文件或变量中提供密码,无需用户干预:

./easyrsa gen-req 客户端名称

如果您今天能给出一个可行的答案,我将不胜感激。

EasyRSA 版本信息 版本:3.1.7

文档/手册

GitHub

openvpn
  • 2 2 个回答
  • 143 Views

2 个回答

  • Voted
  1. muru
    2025-04-25T22:36:11+08:002025-04-25T22:36:11+08:00

    Easy RSA 本质上是 的包装器openssl,因此请查找如何避免 的密码提示openssl。正如一些明智的用户在那篇超级用户帖子中 指出的那样,设置输出文件密码的选项是--passout,这是脚本接受的全局选项之一easyrsa。

    因此尝试一下:

    ./easyrsa --passout=pass:abc gen-req client-name
    

    abc密码在哪。

    • 3
  2. Best Answer
    lensboard
    2025-04-25T23:52:22+08:002025-04-25T23:52:22+08:00

    已验证的解决方案

    我从 切换到gen-req,build-client-full以便能够在一个命令中自动完成完整的客户端构建,而无需随后对请求进行签名。该--batch选项不再要求输入通用名称,而是使用输入名称作为通用名称。该build-client-full命令还会创建一个位于 的内联文件,/etc/openvpn/easy-rsa/pki/inline/其中包含证书、密钥和 CA。

    否则,如果您在 EasyRSA 中未使用--batch输入的名称作为通用名称 (CN) 的选项,则需要修改 vars 文件,然后--req-cn在生成证书请求时使用该标志。varsset_var EASYRSA_REQ_CN "your_common_name"文件中的命令将设置默认 CN,而 --req-cn 标志允许您针对特定请求(例如生成服务器或客户端证书时)覆盖该 CN。

    这两个命令已在实际 OpenVPN 设置中验证有效。其中一个命令以文件为选项,另一个命令以内联密码为选项:

    root@ubuntu:/etc/openvpn/easy-rsa# ./easyrsa --batch --passout=file:passfile build-client-full client_name
    root@ubuntu:/etc/openvpn/easy-rsa# ./easyrsa --batch --passout=pass:password build-client-full client_name
    

    注意:您必须位于 /etc/openvpn/easy-rsa/ 目录中,或者 easy-rsa 所在的任何位置,命令才能起作用。

    这是无需用户干预的输出:

    Notice
    ------
    Private-Key and Public-Certificate-Request files created.
    Your files are:
    * req: /etc/openvpn/easy-rsa/pki/reqs/client_name.req
    * key: /etc/openvpn/easy-rsa/pki/private/client_name.key 
    
    Using configuration from /etc/openvpn/easy-rsa/pki/openssl-easyrsa.cnf
    Check that the request matches the signature
    Signature ok
    The Subject's Distinguished Name is as follows
    commonName            :ASN.1 12:'client_name'
    Certificate is to be certified until Oct 22 14:36:17 2025 GMT (180 days)
    
    Write out database with 1 new entries
    Database updated
    
    Notice
    ------
    Certificate created at:
    * /etc/openvpn/easy-rsa/pki/issued/client_name.crt
    
    Notice
    ------
    Inline file created:
    * /etc/openvpn/easy-rsa/pki/inline/client_name.inline
    
    • 3

相关问题

  • 如何更改 OpenVPN 服务器地址?

  • Wireshark 在 OpenVPN 中显示没有加密

  • 连接 VPN 时无法访问互联网

  • 学习如何在 Amazon EC2/a VPS 上设置 OpenVPN 的最佳方式?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    如何运行 .sh 脚本?

    • 16 个回答
  • Marko Smith

    如何安装 .tar.gz(或 .tar.bz2)文件?

    • 14 个回答
  • Marko Smith

    如何列出所有已安装的软件包

    • 24 个回答
  • Marko Smith

    无法锁定管理目录 (/var/lib/dpkg/) 是另一个进程在使用它吗?

    • 25 个回答
  • Martin Hope
    Flimm 如何在没有 sudo 的情况下使用 docker? 2014-06-07 00:17:43 +0800 CST
  • Martin Hope
    Ivan 如何列出所有已安装的软件包 2010-12-17 18:08:49 +0800 CST
  • Martin Hope
    La Ode Adam Saputra 无法锁定管理目录 (/var/lib/dpkg/) 是另一个进程在使用它吗? 2010-11-30 18:12:48 +0800 CST
  • Martin Hope
    David Barry 如何从命令行确定目录(文件夹)的总大小? 2010-08-06 10:20:23 +0800 CST
  • Martin Hope
    jfoucher “以下软件包已被保留:”为什么以及如何解决? 2010-08-01 13:59:22 +0800 CST
  • Martin Hope
    David Ashford 如何删除 PPA? 2010-07-30 01:09:42 +0800 CST

热门标签

10.10 10.04 gnome networking server command-line package-management software-recommendation sound xorg

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve