test_rtp.cpp 2.89 KB
Newer Older
1
/*
xiongziliang committed
2
 * Copyright (c) 2016 The ZLMediaKit project authors. All Rights Reserved.
3
 *
4
 * This file is part of ZLMediaKit(https://github.com/xia-chu/ZLMediaKit).
5
 *
xiongziliang committed
6 7 8
 * Use of this source code is governed by MIT license that can be found in the
 * LICENSE file in the root of the source tree. All contributing project authors
 * may be found in the AUTHORS file in the root of the source tree.
9 10 11 12 13 14 15 16 17 18 19 20 21 22
 */

#include <map>
#include <iostream>
#include "Util/MD5.h"
#include "Util/File.h"
#include "Util/logger.h"
#include "Util/SSLBox.h"
#include "Util/util.h"
#include "Network/TcpServer.h"
#include "Common/config.h"
#include "Rtsp/RtspSession.h"
#include "Rtmp/RtmpSession.h"
#include "Http/HttpSession.h"
23
#include "Rtp/RtpSelector.h"
24 25 26 27 28

using namespace std;
using namespace toolkit;
using namespace mediakit;

29 30
#if defined(ENABLE_RTPPROXY)
static bool loadFile(const char *path){
xiongziliang committed
31
    FILE *fp = fopen(path, "rb");
32 33 34
    if (!fp) {
        WarnL << "open file failed:" << path;
        return false;
35
    }
36

ziyue committed
37
    uint64_t timeStamp_last = 0;
xiongziliang committed
38
    uint16_t len;
39
    char rtp[0xFFFF];
40 41
    struct sockaddr_storage addr;
    memset(&addr, 0, sizeof(addr));
42
    addr.ss_family = AF_INET;
xia-chu committed
43
    auto sock = Socket::createSocket();
xiongziliang committed
44 45 46
    size_t total_size = 0;
    while (true) {
        if (2 != fread(&len, 1, 2, fp)) {
47
            WarnL;
xiongziliang committed
48
            break;
49 50 51 52
        }
        len = ntohs(len);
        if (len < 12 || len > sizeof(rtp)) {
            WarnL << len;
xiongziliang committed
53
            break;
54 55
        }

xiongziliang committed
56
        if (len != fread(rtp, 1, len, fp)) {
57
            WarnL;
xiongziliang committed
58
            break;
59
        }
xiongziliang committed
60
        total_size += len;
ziyue committed
61
        uint64_t timeStamp;
xiongziliang committed
62

xiongziliang committed
63
        RtpSelector::Instance().inputRtp(sock, rtp, len, (struct sockaddr *)&addr, &timeStamp);
xiongziliang committed
64 65 66 67 68
        auto diff = timeStamp - timeStamp_last;
        if (diff > 0 && diff < 500) {
            usleep(diff * 1000);
        } else {
            usleep(1 * 1000);
69 70
        }
        timeStamp_last = timeStamp;
xiongziliang committed
71 72 73
    }
    WarnL << total_size / 1024 << "KB";
    fclose(fp);
74
    return true;
75
}
76
#endif//#if defined(ENABLE_RTPPROXY)
77

78 79 80 81 82 83 84 85 86 87 88 89 90
int main(int argc,char *argv[]) {
    //设置日志
    Logger::Instance().add(std::make_shared<ConsoleChannel>("ConsoleChannel"));
#if defined(ENABLE_RTPPROXY)
    //启动异步日志线程
    Logger::Instance().setWriter(std::make_shared<AsyncLogWriter>());
    loadIniConfig((exeDir() + "config.ini").data());
    TcpServer::Ptr rtspSrv(new TcpServer());
    TcpServer::Ptr rtmpSrv(new TcpServer());
    TcpServer::Ptr httpSrv(new TcpServer());
    rtspSrv->start<RtspSession>(554);//默认554
    rtmpSrv->start<RtmpSession>(1935);//默认1935
    httpSrv->start<HttpSession>(80);//默认80
91 92 93
    //此处选择是否导出调试文件
//    mINI::Instance()[RtpProxy::kDumpDir] = "/Users/xzl/Desktop/";

xiongziliang committed
94 95 96 97
    if (argc == 2)
      loadFile(argv[1]);
    else
      ErrorL << "parameter error.";
98 99 100 101 102
#else
    ErrorL << "please ENABLE_RTPPROXY and then test";
#endif//#if defined(ENABLE_RTPPROXY)
    return 0;
}
103 104