AI automatically translates all comments in the code into English (#3917)

This commit is contained in:
alex
2024-09-19 14:53:50 +08:00
committed by GitHub
parent 046de691cb
commit 4152dcd409
279 changed files with 10602 additions and 3038 deletions

View File

@@ -25,7 +25,8 @@ using namespace toolkit;
using namespace mediakit;
namespace mediakit {
////////////HTTP配置///////////
// //////////HTTP配置/////////// [AUTO-TRANSLATED:a281d694]
// //////////HTTP Configuration///////////
namespace Http {
#define HTTP_FIELD "http."
#define HTTP_PORT 80
@@ -46,7 +47,8 @@ void initEventListener(){
if(strstr(parser.url().data(),"/api/") != parser.url().data()){
return;
}
//url以"/api/起始说明是http api"
// url以"/api/起始说明是http api" [AUTO-TRANSLATED:8af96c7e]
// URLs starting with "/api/" indicate HTTP API
consumed = true;//该http请求已被消费
_StrPrinter printer;
@@ -70,13 +72,18 @@ void initEventListener(){
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重名则会覆盖之
//默认header有:Server,Connection,Date,Content-Type,Content-Length
//请勿覆盖Connection、Content-Length键
//键名覆盖时不区分大小写
// 你可以自定义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);
});
@@ -85,31 +92,39 @@ void initEventListener(){
}
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服务器
// 开启http服务器 [AUTO-TRANSLATED:ffab30d4]
// Start the HTTP server
TcpServer::Ptr httpSrv(new TcpServer());
httpSrv->start<HttpSession>(mINI::Instance()[Http::kPort]);//默认80
//如果支持ssl还可以开启https服务器
// 如果支持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