往期知识点记录:
- 鸿蒙(HarmonyOS)应用层开发(北向)知识点汇总
- OpenHarmony分布式调度详解|dmslite.c
- OpenHarmony分布式调度详解|dmslite_feature.c 源码阅读
- OpenHarmony分布式调度详解|dmslite_session.c
- OpenHarmony分布式调度详解|dmslite_tlv_common.c
- OpenHarmony分布式调度详解|dmslite_famgr.c
- OpenHarmony分布式调度详解|dmslite_msg_handler.c
- OpenHarmony分布式调度详解|dmslite_pack.c
- OpenHarmony分布式调度详解|dmslite_permission.c
- OpenHarmony分布式调度详解|Service和Feature的定义和注册(1)
- OpenHarmony分布式调度详解|Service和Feature的定义和注册(2)
- OpenHarmony之分布式软总线coap头文件& coap组包分析
- OpenHarmony之分布式软总线discovery/coap/source/coap_socket.c
- 持续更新中……
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;
}
写在最后
如果你觉得这篇内容对你还蛮有帮助,我想邀请你帮我三个小忙:
- 点赞,转发,有你们的 『点赞和评论』,才是我创造的动力。
- 关注小编,同时可以期待后续文章ing🚀,不定期分享原创知识。
- 想要获取更多完整鸿蒙最新学习资源,请看下图提示: