test.c 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. /*
  2. * @Author: jiejie
  3. * @Github: https://github.com/jiejieTop
  4. * @Date: 2019-12-11 21:53:07
  5. * @LastEditTime: 2020-06-08 20:38:41
  6. * @Description: the code belongs to jiejie, please keep the author information and source code according to the license.
  7. */
  8. #include <stdio.h>
  9. #include <unistd.h>
  10. #include <fcntl.h>
  11. #include <stdlib.h>
  12. #include <pthread.h>
  13. #include "mqttclient.h"
  14. // #define TEST_USEING_TLS
  15. static const char *test_baidu_ca_crt = {
  16. "-----BEGIN CERTIFICATE-----\r\n"
  17. "MIIDXzCCAkegAwIBAgILBAAAAAABIVhTCKIwDQYJKoZIhvcNAQELBQAwTDEgMB4G\r\n"
  18. "A1UECxMXR2xvYmFsU2lnbiBSb290IENBIC0gUjMxEzARBgNVBAoTCkdsb2JhbFNp\r\n"
  19. "Z24xEzARBgNVBAMTCkdsb2JhbFNpZ24wHhcNMDkwMzE4MTAwMDAwWhcNMjkwMzE4\r\n"
  20. "MTAwMDAwWjBMMSAwHgYDVQQLExdHbG9iYWxTaWduIFJvb3QgQ0EgLSBSMzETMBEG\r\n"
  21. "A1UEChMKR2xvYmFsU2lnbjETMBEGA1UEAxMKR2xvYmFsU2lnbjCCASIwDQYJKoZI\r\n"
  22. "hvcNAQEBBQADggEPADCCAQoCggEBAMwldpB5BngiFvXAg7aEyiie/QV2EcWtiHL8\r\n"
  23. "RgJDx7KKnQRfJMsuS+FggkbhUqsMgUdwbN1k0ev1LKMPgj0MK66X17YUhhB5uzsT\r\n"
  24. "gHeMCOFJ0mpiLx9e+pZo34knlTifBtc+ycsmWQ1z3rDI6SYOgxXG71uL0gRgykmm\r\n"
  25. "KPZpO/bLyCiR5Z2KYVc3rHQU3HTgOu5yLy6c+9C7v/U9AOEGM+iCK65TpjoWc4zd\r\n"
  26. "QQ4gOsC0p6Hpsk+QLjJg6VfLuQSSaGjlOCZgdbKfd/+RFO+uIEn8rUAVSNECMWEZ\r\n"
  27. "XriX7613t2Saer9fwRPvm2L7DWzgVGkWqQPabumDk3F2xmmFghcCAwEAAaNCMEAw\r\n"
  28. "DgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFI/wS3+o\r\n"
  29. "LkUkrk1Q+mOai97i3Ru8MA0GCSqGSIb3DQEBCwUAA4IBAQBLQNvAUKr+yAzv95ZU\r\n"
  30. "RUm7lgAJQayzE4aGKAczymvmdLm6AC2upArT9fHxD4q/c2dKg8dEe3jgr25sbwMp\r\n"
  31. "jjM5RcOO5LlXbKr8EpbsU8Yt5CRsuZRj+9xTaGdWPoO4zzUhw8lo/s7awlOqzJCK\r\n"
  32. "6fBdRoyV3XpYKBovHd7NADdBj+1EbddTKJd+82cEHhXXipa0095MJ6RMG3NzdvQX\r\n"
  33. "mcIfeg7jLQitChws/zyrVQ4PkX4268NXSb7hLi18YIvDQVETI53O9zJrlAGomecs\r\n"
  34. "Mx86OyXShkDOOyyGeMlhLxS67ttVb9+E7gUJTb0o2HLO02JQZR7rkpeDMdmztcpH\r\n"
  35. "WD9f\r\n"
  36. "-----END CERTIFICATE-----"
  37. };
  38. static void topic1_handler(void* client, message_data_t* msg)
  39. {
  40. (void) client;
  41. MQTT_LOG_I("-----------------------------------------------------------------------------------");
  42. MQTT_LOG_I("%s:%d %s()...\ntopic: %s\nmessage:%s", __FILE__, __LINE__, __FUNCTION__, msg->topic_name, (char*)msg->message->payload);
  43. MQTT_LOG_I("-----------------------------------------------------------------------------------");
  44. }
  45. void *mqtt_publish_thread(void *arg)
  46. {
  47. mqtt_client_t *client = (mqtt_client_t *)arg;
  48. char buf[100] = { 0 };
  49. mqtt_message_t msg;
  50. memset(&msg, 0, sizeof(msg));
  51. sprintf(buf, "welcome to mqttclient, this is a publish test...");
  52. sleep(2);
  53. mqtt_list_subscribe_topic(client);
  54. msg.payload = (void *) buf;
  55. msg.qos = 0;
  56. while(1) {
  57. sprintf(buf, "welcome to mqttclient, this is a publish test, a rand number: %d ...", random_number());
  58. mqtt_publish(client, "topic1", &msg);
  59. sleep(4);
  60. }
  61. }
  62. int main(void)
  63. {
  64. int res;
  65. pthread_t thread1;
  66. mqtt_client_t *client = NULL;
  67. printf("\nwelcome to mqttclient test...\n");
  68. mqtt_log_init();
  69. client = mqtt_lease();
  70. #ifdef TEST_USEING_TLS
  71. mqtt_set_port(client, "1884");
  72. mqtt_set_ca(client, (char*)test_baidu_ca_crt);
  73. #else
  74. mqtt_set_port(client, "1883");
  75. #endif
  76. mqtt_set_host(client, "j6npr4w.mqtt.iot.gz.baidubce.com");
  77. mqtt_set_client_id(client, random_string(10));
  78. mqtt_set_user_name(client, "j6npr4w/mqtt-client-dev");
  79. mqtt_set_password(client, "lcUhUs5VYLMSbrnB");
  80. mqtt_set_clean_session(client, 1);
  81. mqtt_connect(client);
  82. mqtt_subscribe(client, "topic1", QOS0, topic1_handler);
  83. res = pthread_create(&thread1, NULL, mqtt_publish_thread, client);
  84. if(res != 0) {
  85. MQTT_LOG_E("create mqtt publish thread fail");
  86. exit(res);
  87. }
  88. while (1) {
  89. sleep(100);
  90. }
  91. }