草庐IT

stream_socket_enable_crypto

全部标签

socket 客户端——登录、注册

socket客户端——登录、注册新增登录、注册、上传头像接口src/api/user/index.js/***@authorWuner*@date2022/9/2714:08*@descriptionuser用户模块*/import{post}from'@/utils/http';/***登录*@paramdata*@paramdata.username=>用户名*@paramdata.password=>密码*@returns*/consturl='/socket-chat-back/user';exportconstlogin=(data)=>{returnpost(`${url}/log

c++ - 为什么调用closesock后socket accept函数不释放?

我有一个服务器应用程序打开套接字并监听连接。在应用程序中,我有一个单独的线程创建一个套接字,绑定(bind)它并调用它的监听和接受函数。当应用程序关闭时,我在创建的套接字上调用closesocket,然后等待套接字线程关闭。但是,如果线程正在等待接受函数,则线程永远不会完成。我以为调用cloasesocket后accept函数会返回。这是一个正确的想法吗?如果是这样,为什么接受函数不返回?是否有其他方法可以使accept函数返回? 最佳答案 除非select表示可以,否则不要调用accept。在那种情况下,accept永远不会阻塞。

c++ - 生成的加密字符串在 PyCrypto 和 Crypto++ 中的大小不同

我最近使用了一个Python脚本来加密一个字符串。但无法使用Crypto++在C++中解密它。我只是比较了生成的加密字符串,发现它们并不相同。有人可以帮忙吗?这是我的Python代码:key="0123456789abcdef"data="ccccccccccccccccdddddddddddddddd"iv="aaaaaaaaaaaaaaaa"encryptor=AES.new(key,AES.MODE_CBC,iv)enc=encryptor.encrypt(data)printenc这是我的C++代码:std::stringkey="0123456789abcdef";std::

c++ - 在创建的 QThread 中运行所需的 Qt Socket 阻塞函数。有办法过去吗?

标题很隐晦,就这样吧!我正在编写一个以非常同步的方式运行的客户端。由于协议(protocol)和服务器的设计,一切都必须按顺序发生(发送请求、等待回复、服务回复等),所以我使用阻塞套接字。这就是Qt的用武之地。在我的应用程序中,我有一个GUI线程、一个命令处理线程和一个脚本引擎线程。我在命令处理线程中创建QTcpSocket,作为我的Client类的一部分。Client类有各种方法,归结为写入套接字、读回特定数量的字节并返回结果。当我尝试从脚本引擎线程直接调用客户端方法时出现问题。Qt套接字随机超时,当使用Qt的调试版本时,我收到以下警告:QSocketNotifier:socketn

c++ - 文件 basic_socket.hpp 中的 lib boost asio 1.47.0 出错

当我尝试编译时,以下代码出现错误:voidServer::accept(void){Network::ptrconnection=Network::initialize(this->my_acceptor.get_io_service());this->my_acceptor.async_accept(connection->socket(),bind(&Server::endCmd,this,*connection,placeholders::error));}voidServer::endCmd(Networkconnection,constboost::system::error

c++ - HMAC-SHA1 Crypto++实现中如何使用自定义 key

我想在我的C++项目中实现OAuth1.0协议(protocol)。为了创建OAuth签名,我需要实现HMAC-SHA1算法,其中key和text将是根据OAuth规范创建的一些字符串。我想使用Crypto++库来实现HMAC-SHA1。我在项目的wiki上找到了这个HMAC-SHA1示例:AutoSeededRandomPoolprng;SecByteBlockkey(16);prng.GenerateBlock(key,key.size());stringplain="HMACTest";stringmac,encoded;/****************************

c++ - Crypto++ 对称算法和经过身份验证的 block 模式组合

我已经为Crypto++实现了一个C++包装器库v5.6.2并对对称算法(例如Blowfish)和block模式(例如GCM)的组合有疑问。我可以通过Blowfish/EAX加密和解密数据,但我无法通过使用Blowfish/GCM实现同样的目的。AES/EAX和AES/GCM都有效。下面的简单应用演示了我的问题:#include#include#include"cryptopp/blowfish.h"#include"cryptopp/filters.h"#include"cryptopp/eax.h"#include"cryptopp/gcm.h"#include"cryptopp/

c++ - 警告 : non-static data member initializers only available with -std=c++11 or -std=gnu++11 [enabled by default]

这个问题在这里已经有了答案:C++ArrayInitializersWarnings(2个答案)关闭8年前。我刚刚在我的机器上安装了最新版本的cygwin和eclipseluna。它工作正常,我能够运行我的项目。但是,当我构建它们时,我收到了我不明白的警告。例如,这是我从“c++Primer”一书的网站上获得的头文件“Sales_item.h”的警告:warning:defaultedanddeletedfunctionsonlyavailablewith-std=c++11or-std=gnu++11[enabledbydefault]Sales_item()=default;^..

c++ - enable_if 用于没有返回类型的函数

我最近遇到了一个有趣的enable_if用法版本,它用于有条件地启用具有更好可读性的函数,因为该函数的返回类型不是enable_if的一部分(请参阅cleaner_usage):#includeusingmaybe_integral=int/*=orfloat--thenwon'tcompile*/;usingreturn_type=int;typenamestd::enable_if::value,return_type>::typetraditional_usage(){return1;}template::value,int>::type=0>return_typecleaner

c++ - Boost Asio SSL Stream lowest_layer() 和 next_layer() 之间的区别

文档似乎并没有说明太多:lowest_layer(),next_layer().它们之间有什么区别以及何时使用它们? 最佳答案 要回答这个问题,首先要记住的是boost::asio::ssl::stream是一个模板类。通常它看起来像boost::asio::ssl::stream.因此使用boost::asio::ip::tcp::socket实现.这将是boost::asio::ssl::stream的下一层.另一方面,lowest_layer始终是basic_socket(它在docs中有描述)。它有点模棱两可,尤其是当您在标