往期推文全新看点(文中附带全新鸿蒙5.0全栈学习笔录)
✏️ 鸿蒙应用开发与鸿蒙系统开发哪个更有前景?
✏️ 嵌入式开发适不适合做鸿蒙南向开发?看完这篇你就了解了~
✏️ 对于大前端开发来说,转鸿蒙开发究竟是福还是祸?
✏️ 鸿蒙岗位需求突增!移动端、PC端、IoT到底该怎么选?
✏️ 记录一场鸿蒙开发岗位面试经历~
✏️ 持续更新中……
coap_socket.c封装了服务端与客户端之间的socket操作
coap_socket.c封装了服务端与客户端之间的socket操作
// 通过传入的地址信息,创建UDP服务端
int CoapCreateUdpServer(const struct sockaddr_in *sockAddr)
{
if (sockAddr == NULL) {
return NSTACKX_EINVAL;
}
struct sockaddr_in localAddr;
socklen_t len = sizeof(localAddr);
//创建套接字
int sockfd = socket(AF_INET, SOCK_DGRAM, 0);
if (sockfd < 0) {
return NSTACKX_OVERFLOW;
}
(void)memset_s(&localAddr, sizeof(localAddr), 0, sizeof(localAddr));
localAddr.sin_family = AF_INET;
localAddr.sin_port = sockAddr->sin_port;
if (sockAddr->sin_addr.s_addr != 0) {
localAddr.sin_addr.s_addr = sockAddr->sin_addr.s_addr;
} else {
localAddr.sin_addr.s_addr = htonl(INADDR_ANY); //0.0.0.0
}
//绑定
if (bind(sockfd, (struct sockaddr *)&localAddr, len) == -1) {
CloseSocket(&sockfd);
return NSTACKX_EFAILED;
}
//获取与套接字关联的本地协议地址
if (getsockname(sockfd, (struct sockaddr *)&localAddr, &len) == -1) {
CloseSocket(&sockfd);
return NSTACKX_EFAILED;
}
return sockfd;
}
//创建客户端socket
int CoapCreateUdpClient(const struct sockaddr_in *sockAddr)
{
if (sockAddr == NULL) {
return NSTACKX_EFAILED;
}
struct sockaddr_in tmpAddr;
int sockfd = socket(AF_INET, SOCK_DGRAM, 0);
if (sockfd < 0) {
return NSTACKX_EFAILED;
}
int ret = connect(sockfd, (struct sockaddr *)sockAddr, sizeof(struct sockaddr));
if (ret != 0) {
CloseSocket(&sockfd);
return NSTACKX_EFAILED;
}
socklen_t srcAddrLen = sizeof(struct sockaddr_in);
(void)memset_s(&tmpAddr, sizeof(tmpAddr), 0, sizeof(tmpAddr));
//获取与套接字关联的本地协议地址
ret = getsockname(sockfd, (struct sockaddr *)&tmpAddr, &srcAddrLen);
if (ret != 0) {
CloseSocket(&sockfd);
return NSTACKX_EFAILED;
}
//如果之前创建了,那么关闭之前的
CloseSocket(&g_clientFd);
g_clientFd = sockfd;
return NSTACKX_EOK;
}
socket send/recevice
//socket send
int CoapSocketSend(const SocketInfo *socket, const uint8_t *buffer, size_t length)
{
if (buffer == NULL || socket == NULL) {
return NSTACKX_EFAILED;
}
//目的地址
socklen_t dstAddrLen = sizeof(struct sockaddr_in);
int ret = sendto(socket->cliendFd, buffer, length, 0, (struct sockaddr *)&socket->dstAddr, dstAddrLen);
return ret;
}
// socket recevice
int CoapSocketRecv(int socketFd, uint8_t *buffer, size_t length)
{
if (buffer == NULL || socketFd < 0) {
return NSTACKX_EFAILED;
}
struct sockaddr_in addr;
socklen_t len = sizeof(struct sockaddr_in);
(void)memset_s(&addr, sizeof(addr), 0, sizeof(addr));
int ret = recvfrom(socketFd, buffer, length, 0, (struct sockaddr *)&addr, &len);
return ret;
}
socket send/recevice
//socket send
int CoapSocketSend(const SocketInfo *socket, const uint8_t *buffer, size_t length)
{
if (buffer == NULL || socket == NULL) {
return NSTACKX_EFAILED;
}
//目的地址
socklen_t dstAddrLen = sizeof(struct sockaddr_in);
int ret = sendto(socket->cliendFd, buffer, length, 0, (struct sockaddr *)&socket->dstAddr, dstAddrLen);
return ret;
}
// socket recevice
int CoapSocketRecv(int socketFd, uint8_t *buffer, size_t length)
{
if (buffer == NULL || socketFd < 0) {
return NSTACKX_EFAILED;
}
struct sockaddr_in addr;
socklen_t len = sizeof(struct sockaddr_in);
(void)memset_s(&addr, sizeof(addr), 0, sizeof(addr));
int ret = recvfrom(socketFd, buffer, length, 0, (struct sockaddr *)&addr, &len);
return ret;
}