服务端代码
#include <iostream>
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <string.h>
#include <fcntl.h>
#include <event2/event.h>
#include <event2/bufferevent.h>
#include <event2/listener.h>
//读回调函数
void read_cb(struct bufferevent *bev,void *arg)
{
char buf[1024] = {0};
bufferevent_read(bev, buf, sizeof(buf));
printf("recv buf:%s\n",buf);
char* pt = "Get your data success!\n";
bufferevent_write(bev,pt,strlen(pt)+1);
printf("reply msg done!\n");
}
//写回调函数
void write_cb(struct bufferevent *bev, void *arg)
{
printf("msg has send done!\n");
}
//事件回调函数
void event_cb(struct bufferevent *bev, short events, void *arg)
{
if(events & BEV_EVENT_EOF)
{
std::cout<<"connection closed!"<<std::endl;
}
else if(events & BEV_EVENT_ERROR)
{
std::cout<<"some other error!"<<std::endl;
}
bufferevent_free(bev);
}
void listen_cb(struct evconnlistener *listener,
evutil_socket_t fd,
struct sockaddr *addr,
int len, void *ptr)
{
struct event_base* base = (event_base*)ptr;
struct bufferevent* bev = NULL;
bev = bufferevent_socket_new(base, fd, BEV_OPT_CLOSE_ON_FREE);
bufferevent_setcb(bev, read_cb, write_cb, event_cb, NULL);
bufferevent_enable(bev, EV_READ);
}
int main(int argc, char* argv[])
{
struct event_base* base = event_base_new();
struct sockaddr_in serv;
memset(&serv, 0, sizeof(serv));
serv.sin_family = AF_INET;
serv.sin_port = htons(8765);
serv.sin_addr.s_addr = htonl(INADDR_ANY);
struct evconnlistener* listen = NULL;
listen = evconnlistener_new_bind(base, listen_cb, base,
LEV_OPT_CLOSE_ON_FREE | LEV_OPT_REUSEABLE,
-1, (struct sockaddr*) &serv, sizeof(serv));
event_base_dispatch(base);
evconnlistener_free(listen);
event_base_free(base);
return 0;
}
客户端测试
在bash终端输入以下内容后回车,紧接着输入发给服务端的内容并回车,此时服务端接收数据后会打印数据并回复客户端。
root@RobotMan:/opt/Workspace/Toolkits/libeventClass# nc 127.1 8765
测试图片-客户端打印
测试图片-服务端打印