带有SSL的libWebsocks服务器不输入PEM密码短语
libWebscokets server with SSL dont enter PEM pass phrase
我尝试使用libwebsockets库使用ssl开发webscocket服务器。
我可以在代码中对PEM密码短语进行硬编码吗?我阅读了libwebsockets的所有文档,但找不到这些。这是创建websocket服务器的代码:
struct lws_context_creation_info info;
memset(&info, 0, sizeof info);
info.port = 7681;
info.iface = interface1;
info.protocols = protocols;
info.ssl_cert_filepath = cert_path;
info.ssl_private_key_filepath = key_path;
info.ssl_cert_filepath = "./file.pem";
info.ssl_private_key_filepath ="./file.key.pem";
info.gid = -1;
info.uid = -1;
info.options = opts;
context = libwebsocket_create_context(&info);
我运行程序,我需要输入PEM通行证短语。
如果使用OpenSSL,有两种方法可以在libwebsockets会话上设置SSL上下文。(libwebsockets v2.0)
-
您可以使用OpenSSL API制作自己的SSL_CTX结构。
SSL_CTX* ssl_ctx;
/* set up ssl_ctx using OpenSSL APIs including below. */
SSL_CTX_set_default_passwd_cb_userdata(ssl_ctx, "passphrase");
SSL_CTX_set_default_passwd_cb(ssl_ctx, callback_function);
// ...
info.provided_ssl_ctx = ssl_ctx;
通过这种方式,您可以根据需要自定义SSL上下文。但是,如果provided_ssl_ctx设置为非NULL,那么libwebsockets就不承担任何有关ssl.ctx的责任。所以你必须在整个过程之后释放结构。
-
使libwebsockets在自己的进程中设置SSL_CTX。
info.ssl_private_key_password = "passphrase";
如果您想修改更多关于SSL_CTX的信息,可以在libwebsockets回调函数中根据原因LWS_callback_PENSSL_LOAD_EXTRA_SERVER_VERIFY_CERTS进行修改。SSL_CTX将作为
user
变量传递给回调函数
- 在C++程序中输入的文本文件将不起作用,除非文本被复制和粘贴
- 2D数组来自文本输入,中间有空格
- 如何使用 < 和 > 命令获取 c++ 中的输入和输出?
- 检查输入是否不是整数或数字
- 正在尝试了解输入验证循环
- 读取文件并输入到矢量中
- C++如何通过用户输入删除列表元素
- 用c++从输入文件中读取另一行
- 读取文件的最后一行并输入到链接列表时出错
- 创建一个函数以在输入为负数或零时输出字符串.第一次执行用户定义的函数
- 如何使用用户输入在C++中正确填充2D数组
- C++MySQL C api用户输入行
- 输入到文件并输出到另一个文件,并将流文件传递给函数
- 用户定义函数中的指针和输入
- 如何在C++中检查2D数组中负值的输入验证
- 如何只允许用户输入正整数
- 在while循环中输入带有std::cin的字符串后,控制台会输出大量胡言乱语
- 输入中的字符串数未知(以字母表示)
- 带有SSL的libWebsocks服务器不输入PEM密码短语
- 防止提示输入 PEM 密码