mirror of
https://github.com/ZLMediaKit/ZLMediaKit.git
synced 2024-12-03 08:41:06 +08:00
137 lines
5.9 KiB
C++
137 lines
5.9 KiB
C++
/*
|
||
* Copyright (c) 2016-present The ZLMediaKit project authors. All Rights Reserved.
|
||
*
|
||
* This file is part of ZLMediaKit(https://github.com/ZLMediaKit/ZLMediaKit).
|
||
*
|
||
* Use of this source code is governed by MIT-like 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.
|
||
*/
|
||
|
||
#include <map>
|
||
#include <signal.h>
|
||
#include <iostream>
|
||
#include "Util/SSLBox.h"
|
||
#include "Util/logger.h"
|
||
#include "Util/onceToken.h"
|
||
#include "Util/NoticeCenter.h"
|
||
#include "Network/TcpServer.h"
|
||
#include "Poller/EventPoller.h"
|
||
#include "Common/config.h"
|
||
#include "Http/WebSocketSession.h"
|
||
|
||
using namespace std;
|
||
using namespace toolkit;
|
||
using namespace mediakit;
|
||
|
||
namespace mediakit {
|
||
// //////////HTTP配置/////////// [AUTO-TRANSLATED:a281d694]
|
||
// //////////HTTP Configuration///////////
|
||
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([](){
|
||
mINI::Instance()[kPort] = HTTP_PORT;
|
||
mINI::Instance()[kSSLPort] = HTTPS_PORT;
|
||
},nullptr);
|
||
}//namespace Http
|
||
} // namespace mediakit
|
||
|
||
void initEventListener(){
|
||
static onceToken s_token([](){
|
||
NoticeCenter::Instance().addListener(nullptr,Broadcast::kBroadcastHttpRequest,[](BroadcastHttpRequestArgs){
|
||
//const Parser &parser,HttpSession::HttpResponseInvoker &invoker,bool &consumed
|
||
if(strstr(parser.url().data(),"/api/") != parser.url().data()){
|
||
return;
|
||
}
|
||
// url以"/api/起始,说明是http api" [AUTO-TRANSLATED:8af96c7e]
|
||
// URLs starting with "/api/" indicate HTTP API
|
||
consumed = true;//该http请求已被消费
|
||
|
||
_StrPrinter printer;
|
||
////////////////method////////////////////
|
||
printer << "\r\nmethod:\r\n\t" << parser.method();
|
||
////////////////url/////////////////
|
||
printer << "\r\nurl:\r\n\t" << parser.url();
|
||
////////////////protocol/////////////////
|
||
printer << "\r\nprotocol:\r\n\t" << parser.protocol();
|
||
///////////////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";
|
||
for(auto &pr : parser.getHeader()){
|
||
printer << "\t" << pr.first << " : " << pr.second << "\r\n";
|
||
}
|
||
////////////////content/////////////////
|
||
printer << "\r\ncontent:\r\n" << parser.content();
|
||
auto contentOut = printer << endl;
|
||
|
||
// //////////////我们测算异步回复,当然你也可以同步回复///////////////// [AUTO-TRANSLATED:5c112e50]
|
||
// //////////////We measure asynchronous responses, but you can also respond synchronously/////////////////
|
||
EventPollerPool::Instance().getPoller()->async([invoker,contentOut](){
|
||
HttpSession::KeyValue headerOut;
|
||
// 你可以自定义header,如果跟默认header重名,则会覆盖之 [AUTO-TRANSLATED:07b1ecfe]
|
||
// You can customize the header; if it has the same name as the default header, it will override it
|
||
// 默认header有:Server,Connection,Date,Content-Type,Content-Length [AUTO-TRANSLATED:ca0c35d2]
|
||
// Default headers include: Server, Connection, Date, Content-Type, Content-Length
|
||
// 请勿覆盖Connection、Content-Length键 [AUTO-TRANSLATED:ef188768]
|
||
// Please do not override the Connection and Content-Length keys
|
||
// 键名覆盖时不区分大小写 [AUTO-TRANSLATED:32147753]
|
||
// Key name overrides are case-insensitive
|
||
headerOut["TestHeader"] = "HeaderValue";
|
||
invoker(200,headerOut,contentOut);
|
||
});
|
||
});
|
||
}, nullptr);
|
||
}
|
||
|
||
int main(int argc,char *argv[]){
|
||
// 设置退出信号处理函数 [AUTO-TRANSLATED:4f047770]
|
||
// Set the exit signal processing function
|
||
static semaphore sem;
|
||
signal(SIGINT, [](int) { sem.post(); });// 设置退出信号
|
||
|
||
// 设置日志 [AUTO-TRANSLATED:50372045]
|
||
// Set the log
|
||
Logger::Instance().add(std::make_shared<ConsoleChannel>());
|
||
Logger::Instance().setWriter(std::make_shared<AsyncLogWriter>());
|
||
|
||
// 加载配置文件,如果配置文件不存在就创建一个 [AUTO-TRANSLATED:761e7479]
|
||
// Load the configuration file; if it does not exist, create one
|
||
loadIniConfig();
|
||
initEventListener();
|
||
|
||
// 加载证书,证书包含公钥和私钥 [AUTO-TRANSLATED:fce78641]
|
||
// Load the certificate, which includes the public and private keys
|
||
SSL_Initor::Instance().loadCertificate((exeDir() + "ssl.p12").data());
|
||
// 信任某个自签名证书 [AUTO-TRANSLATED:6815fc55]
|
||
// Trust a self-signed certificate
|
||
SSL_Initor::Instance().trustCertificate((exeDir() + "ssl.p12").data());
|
||
// 不忽略无效证书证书(例如自签名或过期证书) [AUTO-TRANSLATED:ee4a34c4]
|
||
// Do not ignore invalid certificates (e.g., self-signed or expired certificates)
|
||
SSL_Initor::Instance().ignoreInvalidCertificate(false);
|
||
|
||
|
||
// 开启http服务器 [AUTO-TRANSLATED:ffab30d4]
|
||
// Start the HTTP server
|
||
TcpServer::Ptr httpSrv(new TcpServer());
|
||
httpSrv->start<HttpSession>(mINI::Instance()[Http::kPort]);//默认80
|
||
|
||
// 如果支持ssl,还可以开启https服务器 [AUTO-TRANSLATED:8ef29f9c]
|
||
// If SSL is supported, you can also start the HTTPS server
|
||
TcpServer::Ptr httpsSrv(new TcpServer());
|
||
httpsSrv->start<HttpsSession>(mINI::Instance()[Http::kSSLPort]);//默认443
|
||
|
||
InfoL << "你可以在浏览器输入:http://127.0.0.1/api/my_api?key0=val0&key1=参数1";
|
||
|
||
sem.wait();
|
||
return 0;
|
||
}
|
||
|