ZLMediaKit/tests/test_httpApi.cpp

122 lines
4.5 KiB
C++
Raw Permalink Normal View History

2017-12-08 22:37:17 +08:00
/*
2020-04-04 20:30:09 +08:00
* Copyright (c) 2016 The ZLMediaKit project authors. All Rights Reserved.
2017-12-08 22:37:17 +08:00
*
* This file is part of ZLMediaKit(https://github.com/xia-chu/ZLMediaKit).
2017-12-08 22:37:17 +08:00
*
2020-04-04 20:30:09 +08:00
* 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.
2017-12-08 22:37:17 +08:00
*/
#include <map>
#include <signal.h>
#include <iostream>
2018-12-20 10:31:31 +08:00
#include "Util/SSLBox.h"
2017-12-08 22:37:17 +08:00
#include "Util/logger.h"
#include "Util/onceToken.h"
2018-12-20 10:31:31 +08:00
#include "Util/NoticeCenter.h"
2017-12-08 22:37:17 +08:00
#include "Network/TcpServer.h"
#include "Poller/EventPoller.h"
2018-12-20 10:31:31 +08:00
#include "Common/config.h"
#include "Http/WebSocketSession.h"
2017-12-08 22:37:17 +08:00
using namespace std;
2018-10-24 17:17:55 +08:00
using namespace toolkit;
using namespace mediakit;
2017-12-08 22:37:17 +08:00
2018-12-19 17:53:43 +08:00
namespace mediakit {
////////////HTTP配置///////////
namespace Http {
#define HTTP_FIELD "http."
#define HTTP_PORT 80
const char kPort[] = HTTP_FIELD"port";
#define HTTPS_PORT 443
extern const char kSSLPort[] = HTTP_FIELD"sslport";
onceToken token1([](){
2020-03-20 11:51:24 +08:00
mINI::Instance()[kPort] = HTTP_PORT;
mINI::Instance()[kSSLPort] = HTTPS_PORT;
2018-12-19 17:53:43 +08:00
},nullptr);
}//namespace Http
} // namespace mediakit
2019-07-20 20:37:52 +08:00
void initEventListener(){
2020-03-20 11:51:24 +08:00
static onceToken s_token([](){
NoticeCenter::Instance().addListener(nullptr,Broadcast::kBroadcastHttpRequest,[](BroadcastHttpRequestArgs){
//const Parser &parser,HttpSession::HttpResponseInvoker &invoker,bool &consumed
2023-06-10 11:04:52 +08:00
if(strstr(parser.url().data(),"/api/") != parser.url().data()){
2020-03-20 11:51:24 +08:00
return;
}
//url以"/api/起始说明是http api"
consumed = true;//该http请求已被消费
_StrPrinter printer;
////////////////method////////////////////
2023-06-10 11:04:52 +08:00
printer << "\r\nmethod:\r\n\t" << parser.method();
2020-03-20 11:51:24 +08:00
////////////////url/////////////////
2023-06-10 11:04:52 +08:00
printer << "\r\nurl:\r\n\t" << parser.url();
2020-03-20 11:51:24 +08:00
////////////////protocol/////////////////
2023-06-10 11:04:52 +08:00
printer << "\r\nprotocol:\r\n\t" << parser.protocol();
2020-03-20 11:51:24 +08:00
///////////////args//////////////////
printer << "\r\nargs:\r\n";
for(auto &pr : parser.getUrlArgs()){
printer << "\t" << pr.first << " : " << pr.second << "\r\n";
}
///////////////header//////////////////
printer << "\r\nheader:\r\n";
2020-04-20 18:13:45 +08:00
for(auto &pr : parser.getHeader()){
2020-03-20 11:51:24 +08:00
printer << "\t" << pr.first << " : " << pr.second << "\r\n";
}
////////////////content/////////////////
2023-06-10 11:04:52 +08:00
printer << "\r\ncontent:\r\n" << parser.content();
2020-03-20 11:51:24 +08:00
auto contentOut = printer << endl;
////////////////我们测算异步回复,当然你也可以同步回复/////////////////
EventPollerPool::Instance().getPoller()->async([invoker,contentOut](){
HttpSession::KeyValue headerOut;
//你可以自定义header,如果跟默认header重名则会覆盖之
//默认header有:Server,Connection,Date,Content-Type,Content-Length
//请勿覆盖Connection、Content-Length键
//键名覆盖时不区分大小写
headerOut["TestHeader"] = "HeaderValue";
invoker(200,headerOut,contentOut);
2020-03-20 11:51:24 +08:00
});
});
}, nullptr);
2019-07-20 20:37:52 +08:00
}
2017-12-08 22:37:17 +08:00
int main(int argc,char *argv[]){
2020-03-20 11:51:24 +08:00
//设置退出信号处理函数
static semaphore sem;
signal(SIGINT, [](int) { sem.post(); });// 设置退出信号
2020-03-20 11:51:24 +08:00
//设置日志
Logger::Instance().add(std::make_shared<ConsoleChannel>());
Logger::Instance().setWriter(std::make_shared<AsyncLogWriter>());
2020-03-20 11:51:24 +08:00
//加载配置文件,如果配置文件不存在就创建一个
loadIniConfig();
initEventListener();
2017-12-08 22:37:17 +08:00
2020-03-20 11:51:24 +08:00
//加载证书,证书包含公钥和私钥
SSL_Initor::Instance().loadCertificate((exeDir() + "ssl.p12").data());
//信任某个自签名证书
SSL_Initor::Instance().trustCertificate((exeDir() + "ssl.p12").data());
//不忽略无效证书证书(例如自签名或过期证书)
SSL_Initor::Instance().ignoreInvalidCertificate(false);
2019-04-16 17:25:19 +08:00
2017-12-08 22:37:17 +08:00
2020-03-20 11:51:24 +08:00
//开启http服务器
TcpServer::Ptr httpSrv(new TcpServer());
httpSrv->start<HttpSession>(mINI::Instance()[Http::kPort]);//默认80
2017-12-08 22:37:17 +08:00
//如果支持ssl还可以开启https服务器
2020-03-20 11:51:24 +08:00
TcpServer::Ptr httpsSrv(new TcpServer());
httpsSrv->start<HttpsSession>(mINI::Instance()[Http::kSSLPort]);//默认443
2017-12-08 22:37:17 +08:00
2023-06-10 11:04:52 +08:00
InfoL << "你可以在浏览器输入:http://127.0.0.1/api/my_api?key0=val0&key1=参数1";
2017-12-08 22:37:17 +08:00
2020-03-20 11:51:24 +08:00
sem.wait();
return 0;
2017-12-08 22:37:17 +08:00
}