tcp_echo_server.c 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. /*
  2. * tcp echo server
  3. *
  4. * @build make examples
  5. * @server bin/tcp_echo_server 1234
  6. * @client bin/nc 127.0.0.1 1234
  7. * nc 127.0.0.1 1234
  8. * telnet 127.0.0.1 1234
  9. */
  10. #include "hloop.h"
  11. #include "hsocket.h"
  12. #include "hssl.h"
  13. /*
  14. * @test ssl_server
  15. * #define TEST_SSL 1
  16. *
  17. * @build ./configure --with-openssl && make clean && make
  18. *
  19. */
  20. #define TEST_SSL 0
  21. // hloop_create_tcp_server -> on_accept -> hio_read -> on_recv -> hio_write
  22. static void on_close(hio_t* io) {
  23. printf("on_close fd=%d error=%d\n", hio_fd(io), hio_error(io));
  24. }
  25. static void on_recv(hio_t* io, void* buf, int readbytes) {
  26. printf("on_recv fd=%d readbytes=%d\n", hio_fd(io), readbytes);
  27. char localaddrstr[SOCKADDR_STRLEN] = {0};
  28. char peeraddrstr[SOCKADDR_STRLEN] = {0};
  29. printf("[%s] <=> [%s]\n",
  30. SOCKADDR_STR(hio_localaddr(io), localaddrstr),
  31. SOCKADDR_STR(hio_peeraddr(io), peeraddrstr));
  32. printf("< %.*s", readbytes, (char*)buf);
  33. // echo
  34. printf("> %.*s", readbytes, (char*)buf);
  35. hio_write(io, buf, readbytes);
  36. }
  37. static void on_accept(hio_t* io) {
  38. printf("on_accept connfd=%d\n", hio_fd(io));
  39. char localaddrstr[SOCKADDR_STRLEN] = {0};
  40. char peeraddrstr[SOCKADDR_STRLEN] = {0};
  41. printf("accept connfd=%d [%s] <= [%s]\n", hio_fd(io),
  42. SOCKADDR_STR(hio_localaddr(io), localaddrstr),
  43. SOCKADDR_STR(hio_peeraddr(io), peeraddrstr));
  44. hio_setcb_close(io, on_close);
  45. hio_setcb_read(io, on_recv);
  46. hio_read(io);
  47. }
  48. int main(int argc, char** argv) {
  49. if (argc < 2) {
  50. printf("Usage: %s port\n", argv[0]);
  51. return -10;
  52. }
  53. int port = atoi(argv[1]);
  54. #if TEST_SSL
  55. {
  56. hssl_ctx_init_param_t param;
  57. memset(&param, 0, sizeof(param));
  58. param.crt_file = "cert/server.crt";
  59. param.key_file = "cert/server.key";
  60. if (hssl_ctx_init(&param) == NULL) {
  61. fprintf(stderr, "SSL certificate verify failed!\n");
  62. return -30;
  63. }
  64. }
  65. #endif
  66. hloop_t* loop = hloop_new(0);
  67. #if TEST_SSL
  68. hio_t* listenio = hloop_create_ssl_server(loop, "0.0.0.0", port, on_accept);
  69. #else
  70. hio_t* listenio = hloop_create_tcp_server(loop, "0.0.0.0", port, on_accept);
  71. #endif
  72. if (listenio == NULL) {
  73. return -20;
  74. }
  75. printf("listenfd=%d\n", hio_fd(listenio));
  76. hloop_run(loop);
  77. hloop_free(&loop);
  78. return 0;
  79. }