• HTTP协议手写服务器

HTTP协议手写服务器

2025-04-26 06:00:11 1 阅读

目录

一、请求的是Web根目录

二、GET方法通过URL传参

三、根据资源类型对应出Content-Type值

四、Http代码


项目完整源代码:Http · 周不才/cpp_linux study - 码云 - 开源中国

一、请求的是Web根目录

如果URL中请求的资源是Web根目录,则自动跳转到主页

例如QQ官网https://im.qq.com/,实际访问时会自动跳转到主页https://im.qq.com/index/

实现代码:

static const std::string homePage="index.html";//主页资源
//解析请求的资源路径path,如果请求的是web根目录
if(_path[_path.size()-1]=='/')
{
    _path+=homePage;
}

二、GET方法通过URL传参

GET方法和POST方法都可以通过表单等方式向服务器传递数据

GET方法会将表单的数据存放到URL中,再发送给服务器。符号?后面就是参数

https://fanyi.baidu.com/mtpe-individual/multimodal?query=%E5%8F%8D%E5%BA%8F%E5%88%97%E5%8C%96&lang=zh2en

POST方法会将表单的数据存放到请求正文中,再发送给服务器

  • POST传参的数据可以很大,因为存放在正文中;GET方法传参的数据一定很小,因为存放在URL中
  • POST传参比GET传参安全,因为GET传参的数据会直接暴露在URL中。但这两种传参方法都不安全,需要对参数加密,即Https协议

提取GET方法传递的参数代码:

static const std::string argSep="?";//URL中参数的位置标识
//解析URL中携带的参数(GET方法)
if(strcasecmp(_method.c_str(),"GET")==0)//请求方法是GET
{
    auto pos=_url.find(argSep);
    if(pos!=std::string::npos)//URL中携带参数
    {
        _reqContent=_url.substr(pos+argSep.size());//提取URL中的参数,存放到请求正文中
        _url.resize(pos);//URL中去除参数部分
    }
}

三、根据资源类型对应出Content-Type值

根据请求后缀,如.html   .jpg   .png   .gif等对应出Content-Type值

//--------------------------------------------------------
        //建立资源后缀和Http协议中的资源类型之间的映射关系
        //--------------------------------------------------------
        _resourceType.insert({".html", "text/html"});
        _resourceType.insert({".htm", "text/html"});
        _resourceType.insert({".css", "text/css"});
        _resourceType.insert({".txt", "text/plain"});
        _resourceType.insert({".md", "text/markdown"});
        // 脚本类
        _resourceType.insert({".js", "application/javascript"});
        _resourceType.insert({".mjs", "application/javascript"});
        // 图像类
        _resourceType.insert({".jpg", "image/jpeg"});
        _resourceType.insert({".jpeg", "image/jpeg"});
        _resourceType.insert({".png", "image/png"});
        _resourceType.insert({".gif", "image/gif"});
        _resourceType.insert({".webp", "image/webp"});
        _resourceType.insert({".svg", "image/svg+xml"});
        _resourceType.insert({".ico", "image/x-icon"});
        // 字体类
        _resourceType.insert({".woff", "font/woff"});
        _resourceType.insert({".woff2", "font/woff2"});
        _resourceType.insert({".ttf", "font/ttf"});
        // 多媒体类
        _resourceType.insert({".mp3", "audio/mpeg"});
        _resourceType.insert({".wav", "audio/wav"});
        _resourceType.insert({".mp4", "video/mp4"});
        _resourceType.insert({".webm", "video/webm"});
        // 文档类
        _resourceType.insert({".pdf", "application/pdf"});
        _resourceType.insert({".doc", "application/msword"});
        _resourceType.insert({".docx", "application/vnd.openxmlformats-officedocument.wordprocessingml.document"});
        _resourceType.insert({".xls", "application/vnd.ms-excel"});
        _resourceType.insert({".xlsx", "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"});
        _resourceType.insert({".ppt", "application/vnd.ms-powerpoint"});
        _resourceType.insert({".pptx", "application/vnd.openxmlformats-officedocument.presentationml.presentation"});
        // 压缩包类
        _resourceType.insert({".zip", "application/zip"});
        _resourceType.insert({".tar", "application/x-tar"});
        _resourceType.insert({".gz", "application/gzip"});
        // 数据格式类
        _resourceType.insert({".json", "application/json"});
        _resourceType.insert({".xml", "application/xml"});
        _resourceType.insert({".csv", "text/csv"});
        // 二进制流默认类型
        _resourceType.insert({".bin", "application/octet-stream"});
大类Content-Type值描述
文本类型text/plain纯文本,无格式(如TXT文件)
text/htmlHTML文档,用于网页
text/cssCSS样式表
text/javascriptJavaScript代码(旧标准,推荐使用 application/javascript
text/markdownMarkdown格式文本
图像类型image/jpegJPEG图像
image/pngPNG图像
image/gifGIF图像(支持动画)
image/webpWebP格式图像(现代高效压缩格式)
image/svg+xmlSVG矢量图(基于XML)
应用程序类型application/jsonJSON格式数据,常用于API交互
application/xmlXML数据
application/pdfPDF文档
application/octet-stream二进制流(如文件下载)
application/x-www-form-urlencoded表单提交的默认编码格式
application/zipZIP压缩文件
application/javascriptJavaScript代码(现代标准)
application/wasmWebAssembly模块(用于高性能Web应用)
多媒体类型audio/mpegMP3音频文件
audio/wavWAV音频文件
video/mp4MP4视频文件
video/webmWebM开放格式视频
多部分类型multipart/form-data表单文件上传(支持二进制数据)
multipart/byteranges分块传输响应(用于HTTP范围请求)
字体类型font/woffWeb开放字体格式(WOFF 1.0)
font/woff2WOFF 2.0字体(更高压缩率)
其他类型application/vnd.ms-excelExcel文件(旧版,如 .xls
application/vnd.openxmlformats-officedocument.spreadsheetml.sheet新版Excel文件(.xlsx

四、Http代码

//应用层协议:HTTP协议

#include 
#include 
#include 
#include 
#include 
#include //提供strcasecmp,忽略大小写比较字符串
#include //智能指针
#include //文件操作

static const std::string baseSep="
";//行与行之间的分隔符
static const std::string lineSep=" ";//请求行中各个属性的分隔符
static const std::string argSep="?";//URL中参数的位置标识
static const std::string homePage="index.html";//主页资源
static const std::string suffixSep=".";//资源后缀符号
static const std::string headerSep=": ";//单个报头属性之间的分隔符
static const std::string webRootDir="wwwroot";//Web根目录(path初始值即为web根目录)
static const std::string httpVersion="HTTP/1.0";//默认的Http协议版本(用于响应)

//Http请求
class HttpRequest
{
private:
    //Http协议请求的基本属性
    std::string _reqLine;//请求行
    std::vector _reqHeaders;//请求报头
    std::string _blankLine;//空行
    std::string _reqContent;//请求正文

    //Http协议请求的详细属性
    std::string _method;//请求方法
    std::string _url;//请求资源的路径URL
    std::string _version;//Http版本
    std::unordered_map _reqHeadersKV;//请求报头属性集合(请求报头的各种属性存储在哈希表中)
    std::string _path;//URL只是相对路径,要根据资源所在位置确定绝对路径
    std::string _suffix;//资源后缀,用于确定请求的资源是什么类型,以便填充请求报头中的Content-Type属性
public:
    //构造函数
    HttpRequest()
        :_blankLine(baseSep),
        _path(webRootDir)
    {}
    //析构函数
    ~HttpRequest()
    {}
private:
    //解析请求协议,获取单行数据(目的是将请求行、请求报头、请求正文拆分开)
    std::string GetLine(std::string& reqstr)
    {
        auto pos=reqstr.find(baseSep);//查找

        if(pos!=std::string::npos)
        {
            std::string line=reqstr.substr(0,pos);
            reqstr.erase(0,pos+baseSep.size());
            if(line.empty()) return baseSep;//如果获取一行的内容是空,说明该行是空行,返回

            else return line;//否则返回正常获取的一行数据
        }
        else
        {
            return std::string();
        }
    }
    //解析请求行
    void ParseReqLine()
    {
        //将请求行解析为请求方法、URL、http版本
        std::stringstream ss(_reqLine);//按空格为分隔符
        ss>>_method>>_url>>_version;

        //--------------------------------------------------------------
        //更详细地解析URL,以提取参数、初始化path、初始化资源后缀suffix

        //1.提取参数
        //解析URL中携带的参数(GET方法)
        if(strcasecmp(_method.c_str(),"GET")==0)//请求方法是GET
        {
            auto pos=_url.find(argSep);
            if(pos!=std::string::npos)//URL中携带参数
            {
                _reqContent=_url.substr(pos+argSep.size());//提取URL中的参数,存放到请求正文中
                _url.resize(pos);//URL中去除参数部分
            }
        }

        //2.初始化path
        //初始化请求的资源路径path(绝对路径)
        _path+=_url;
        //解析请求的资源路径path,如果请求的是web根目录
        if(_path[_path.size()-1]=='/')
        {
            _path+=homePage;
        }

        //3.初始化资源后缀suffix
        auto pos=_path.rfind(suffixSep);
        if(pos!=std::string::npos)
        {
            _suffix=_path.substr(pos);
        }
        else
        {
            _suffix=".default";
        }
    }
    //解析请求报头
    void ParseReqHeaders()
    {
        //将报头属性存储到哈希表中
        for(auto& reqHeader:_reqHeaders)
        {
            auto pos=reqHeader.find(headerSep);
            if(pos!=std::string::npos)
            {
                std::string k=reqHeader.substr(0,pos);
                std::string v=reqHeader.substr(pos+headerSep.size());
                if(k.empty()||v.empty()) continue;
                _reqHeadersKV[k]=v;
            }
            else
            {
                continue;
            }
        }
    }
public:
    //反序列化:序列化字符串➡基本属性➡详细属性
    void Deserialize(std::string& reqstr)
    {
        //基本的反序列化:拆分reqstr为请求行、请求报头、空行、请求正文

        //请求行
        _reqLine=GetLine(reqstr);
        //请求报头  todo1
        std::string reqHeader;
        while((reqHeader=GetLine(reqstr))!=baseSep)
        {
            _reqHeaders.emplace_back(reqHeader);
        }
        //空行
        _blankLine=baseSep;
        //请求正文  todo2
        _reqContent=reqstr;

        //---------------------------------------------
        //进一步反序列化:解析请求行、请求报头为更详细的属性
        ParseReqLine();
        ParseReqHeaders();
    }
    //获取路径
    std::string GetPath()
    {
        return _path;
    }
    //获取正文内容
    std::string GetReqContent()
    {
        return _reqContent;
    }
    //获取资源后缀
    std::string GetSuffix()
    {
        return _suffix;
    }
    //输出反序列化结果
    void Print()
    {
        std::cout<<"-----------------------------------------"< _resHeaders;//响应报头
    std::string _blankLine;//空行
    std::string _resContent;//响应正文

    //Http协议响应的详细属性
    std::string _version;//http版本
    int _statusCode;//状态码
    std::string _statusDescribe;//状态码描述
    std::unordered_map _resHeadersKV;//响应报头属性集合
public:
    //构造函数
    HttpResponse()
        :_blankLine(baseSep),
        _version(httpVersion)
    {}
    //析构函数
    ~HttpResponse()
    {}
public:
    //序列化
    std::string Serialize()
    {
        //构建状态行
        _statusLine+=_version+lineSep+std::to_string(_statusCode)+lineSep+_statusDescribe+baseSep;
        //构建应答报头
        for(auto& resHeader: _resHeadersKV)
        {
            _resHeaders.emplace_back(resHeader.first+headerSep+resHeader.second+baseSep);
        }
        
        //正式序列化:详细属性➡基本属性➡序列化字符串
        std::string responseStr=_statusLine;//加上状态行
        for(auto& resHeader:_resHeaders)//加上响应报头
        {
            responseStr+=resHeader;
        }
        responseStr+=_blankLine;//加上空行
        responseStr+=_resContent;//加上响应正文

        return responseStr;
    }
    //设置属性

    //设置状态码和状态码描述
    void AddStatusCodeAndDescribe(int statusCode, const std::string& statusDescribe)
    {
        _statusCode=statusCode;
        _statusDescribe=statusDescribe;
    }
    //添加报头属性
    void AddHeader(const std::string& k, const std::string& v)
    {
        _resHeadersKV[k]=v;
    }
    //添加应答正文
    void AddResContent(const std::string& resContent)
    {
        _resContent=resContent;
    }
}; 


//Http处理(将请求处理为应答)
class HttpServer
{
private:
    std::unordered_map _resourceType;//资源类型(根据后缀,判定资源类型)
    std::unordered_map _codeToDescribe;//状态码-状态码描述
    std::unordered_map> _serviceLists;//服务列表
public:
    //构造函数
    HttpServer()
    {
        //--------------------------------------------------------
        //建立资源后缀和Http协议中的资源类型之间的映射关系
        //--------------------------------------------------------
        _resourceType.insert({".html", "text/html"});
        _resourceType.insert({".htm", "text/html"});
        _resourceType.insert({".css", "text/css"});
        _resourceType.insert({".txt", "text/plain"});
        _resourceType.insert({".md", "text/markdown"});
        // 脚本类
        _resourceType.insert({".js", "application/javascript"});
        _resourceType.insert({".mjs", "application/javascript"});
        // 图像类
        _resourceType.insert({".jpg", "image/jpeg"});
        _resourceType.insert({".jpeg", "image/jpeg"});
        _resourceType.insert({".png", "image/png"});
        _resourceType.insert({".gif", "image/gif"});
        _resourceType.insert({".webp", "image/webp"});
        _resourceType.insert({".svg", "image/svg+xml"});
        _resourceType.insert({".ico", "image/x-icon"});
        // 字体类
        _resourceType.insert({".woff", "font/woff"});
        _resourceType.insert({".woff2", "font/woff2"});
        _resourceType.insert({".ttf", "font/ttf"});
        // 多媒体类
        _resourceType.insert({".mp3", "audio/mpeg"});
        _resourceType.insert({".wav", "audio/wav"});
        _resourceType.insert({".mp4", "video/mp4"});
        _resourceType.insert({".webm", "video/webm"});
        // 文档类
        _resourceType.insert({".pdf", "application/pdf"});
        _resourceType.insert({".doc", "application/msword"});
        _resourceType.insert({".docx", "application/vnd.openxmlformats-officedocument.wordprocessingml.document"});
        _resourceType.insert({".xls", "application/vnd.ms-excel"});
        _resourceType.insert({".xlsx", "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"});
        _resourceType.insert({".ppt", "application/vnd.ms-powerpoint"});
        _resourceType.insert({".pptx", "application/vnd.openxmlformats-officedocument.presentationml.presentation"});
        // 压缩包类
        _resourceType.insert({".zip", "application/zip"});
        _resourceType.insert({".tar", "application/x-tar"});
        _resourceType.insert({".gz", "application/gzip"});
        // 数据格式类
        _resourceType.insert({".json", "application/json"});
        _resourceType.insert({".xml", "application/xml"});
        _resourceType.insert({".csv", "text/csv"});
        // 二进制流默认类型
        _resourceType.insert({".bin", "application/octet-stream"});

        //--------------------------------------------------------
        // 建立状态码和状态码描述之间的映射关系
        //--------------------------------------------------------
        // 1xx 信息响应
        _codeToDescribe.insert(std::make_pair(100, "Continue"));
        _codeToDescribe.insert(std::make_pair(101, "Switching Protocols"));
        _codeToDescribe.insert(std::make_pair(102, "Processing"));
        // 2xx 成功
        _codeToDescribe.insert(std::make_pair(200, "OK"));
        _codeToDescribe.insert(std::make_pair(201, "Created"));
        _codeToDescribe.insert(std::make_pair(202, "Accepted"));
        _codeToDescribe.insert(std::make_pair(204, "No Content"));
        _codeToDescribe.insert(std::make_pair(206, "Partial Content"));
        // 3xx 重定向
        _codeToDescribe.insert(std::make_pair(300, "Multiple Choices"));
        _codeToDescribe.insert(std::make_pair(301, "Moved Permanently"));
        _codeToDescribe.insert(std::make_pair(302, "Found"));
        _codeToDescribe.insert(std::make_pair(304, "Not Modified"));
        _codeToDescribe.insert(std::make_pair(307, "Temporary Redirect"));
        _codeToDescribe.insert(std::make_pair(308, "Permanent Redirect"));
        // 4xx 客户端错误
        _codeToDescribe.insert(std::make_pair(400, "Bad Request"));
        _codeToDescribe.insert(std::make_pair(401, "Unauthorized"));
        _codeToDescribe.insert(std::make_pair(403, "Forbidden"));
        _codeToDescribe.insert(std::make_pair(404, "Not Found"));
        _codeToDescribe.insert(std::make_pair(405, "Method Not Allowed"));
        _codeToDescribe.insert(std::make_pair(408, "Request Timeout"));
        _codeToDescribe.insert(std::make_pair(413, "Payload Too Large"));
        _codeToDescribe.insert(std::make_pair(415, "Unsupported Media Type"));
        _codeToDescribe.insert(std::make_pair(429, "Too Many Requests"));
        // 5xx 服务端错误
        _codeToDescribe.insert(std::make_pair(500, "Internal Server Error"));
        _codeToDescribe.insert(std::make_pair(501, "Not Implemented"));
        _codeToDescribe.insert(std::make_pair(502, "Bad Gateway"));
        _codeToDescribe.insert(std::make_pair(503, "Service Unavailable"));
        _codeToDescribe.insert(std::make_pair(504, "Gateway Timeout"));
        _codeToDescribe.insert(std::make_pair(505, "HTTP Version Not Supported"));
    }
private:
    //获取文件资源
    std::string GetResource(const std::string& path)
    {
        std::ifstream file(path, std::ios::binary);//二进制方式打开path路径下的文件
        if(!file.is_open())//文件打开失败
        {
            return std::string();
        }
        file.seekg(0,file.end);//移动输入流指针到文件末尾
        int fileSize=file.tellg();//获取当前输入流指针位置,即获取文件大小
        file.seekg(0,file.beg);//回复输入流指针到文件开头

        std::string resource;
        resource.resize(fileSize);
        file.read((char *)resource.c_str(),fileSize);//读取文件资源内容存放到resource中
        file.close();//关闭文件
        return resource;
    }
public:
    //处理服务端接收到的Http请求,最后返回Http应答序列化后的字符串
    std::string Handle(std::string reqstr)
    {
        //参数说明:reqstr是客户端序列化过的Http请求

        HttpRequest req;
        req.Deserialize(reqstr);//反序列化


        //处理Http请求,转为Http应答
        HttpResponse res;

        if(req.GetPath()=="wwwroot/redir")//处理重定向,重定向到qq官网
        {
            std::string redirPath="https://www.qq.com";
            res.AddStatusCodeAndDescribe(301,_codeToDescribe[301]);
            res.AddHeader("Location",redirPath);
        }
        else if(!req.GetReqContent().empty())//处理参数,如果请求正文不为空,说明传递了参数,请求的不是资源,而是某个服务,要进行服务处理
        {
            if(_serviceLists.find(req.GetPath())!=_serviceLists.end())
            {
                res=_serviceLists[req.GetPath()](req);//该服务是一个处理函数,参数是req,返回值是res
            }
        }
        else//既没有重定向,也没有请求服务,那么直接进行序列化并返回请求的资源
        {
            std::string resource=GetResource(req.GetPath());//获取请求资源的内容
            if(resource.empty())//说明没有该资源,返回404.html资源
            {
                resource=GetResource("wwwroot/404.html");
                res.AddStatusCodeAndDescribe(404,_codeToDescribe[404]);
                res.AddHeader("Content-Length",std::to_string(resource.size()));
                res.AddHeader("Content-Type",_resourceType[".html"]);
                res.AddResContent(resource);
            }
            else
            {
                res.AddStatusCodeAndDescribe(200,_codeToDescribe[200]);
                res.AddHeader("Content-Length", std::to_string(resource.size()));
                res.AddHeader("Content-Type", _resourceType[req.GetSuffix()]);
                //res.AddHeader("Set-Cookie", "username=zhangsan");  //Cookie
                res.AddResContent(resource);
            }
        }

        return res.Serialize();//返回Http应答序列化后的字符串
    }

    //添加处理服务(当Http请求中携带参数时,说明其要请求的是某个服务,而不是资源)
    void InsertService(const std::string& serviceName, std::function service)
    {
        _serviceLists.insert(std::make_pair(serviceName+webRootDir,service));
    }
};

本文地址:https://www.vps345.com/1522.html

搜索文章

Tags

PV计算 带宽计算 流量带宽 服务器带宽 上行带宽 上行速率 什么是上行带宽? CC攻击 攻击怎么办 流量攻击 DDOS攻击 服务器被攻击怎么办 源IP 服务器 linux 运维 游戏 云计算 javascript 前端 chrome edge 进程 操作系统 进程控制 Ubuntu python MCP ssh 阿里云 网络 网络安全 网络协议 llama 算法 opencv 自然语言处理 神经网络 语言模型 deepseek Ollama 模型联网 API CherryStudio RTSP xop RTP RTSPServer 推流 视频 harmonyos 华为 开发语言 typescript 计算机网络 ubuntu 数据库 centos oracle 关系型 安全 分布式 c# Flask FastAPI Waitress Gunicorn uWSGI Uvicorn flutter Hyper-V WinRM TrustedHosts java 面试 性能优化 jdk intellij-idea 架构 GaN HEMT 氮化镓 单粒子烧毁 辐射损伤 辐照效应 udp unity macos adb php android 宝塔面板访问不了 宝塔面板网站访问不了 宝塔面板怎么配置网站能访问 宝塔面板配置ip访问 宝塔面板配置域名访问教程 宝塔面板配置教程 Dell R750XS vue.js audio vue音乐播放器 vue播放音频文件 Audio音频播放器自定义样式 播放暂停进度条音量调节快进快退 自定义audio覆盖默认样式 rust http ssl 深度学习 YOLO 目标检测 计算机视觉 人工智能 fastapi mcp mcp-proxy mcp-inspector fastapi-mcp agent sse HCIE 数通 filezilla 无法连接服务器 连接被服务器拒绝 vsftpd 331/530 numpy tcp/ip 鸿蒙 github 创意 社区 cpu 内存 实时 使用 golang vscode word图片自动上传 word一键转存 复制word图片 复制word图文 复制word公式 粘贴word图文 粘贴word公式 jenkins gitee spring boot C语言 c++ YOLOv8 NPU Atlas800 A300I pro asi_bench DigitalOcean GPU服务器购买 GPU服务器哪里有 GPU服务器 WSL2 pytorch transformer ddos c语言 qt stm32项目 单片机 stm32 debian PVE 开源 ide ai AI编程 物联网 iot 后端 websocket pycharm windows vim 安装教程 GPU环境配置 Ubuntu22 CUDA PyTorch Anaconda安装 react.js 前端面试题 node.js 持续部署 redis mybatis oceanbase rc.local 开机自启 systemd 麒麟 计算机外设 电脑 mac 软件需求 chatgpt 大模型 llama3 Chatglm 开源大模型 ping++ 运维开发 conda 机器学习 深度优先 图论 并集查找 换根法 树上倍增 docker 产品经理 agi microsoft ollama llm 科技 个人开发 容器 ffmpeg 音视频 学习方法 嵌入式硬件 温湿度数据上传到服务器 Arduino HTTP 微信 微信分享 Image wxopensdk 银河麒麟服务器操作系统 系统激活 博客 学习 AI Agent 数据结构 笔记 经验分享 负载均衡 uni-app ESP32 豆瓣 追剧助手 迅雷 nas tomcat YOLOv12 LDAP mysql aws googlecloud maven intellij idea Windsurf 实时音视频 git ansible nginx dubbo .netcore 智能路由器 外网访问 内网穿透 端口映射 大数据 大数据平台 .net C 环境变量 进程地址空间 cuda cudnn anaconda 微服务 springcloud 前端框架 Qwen2.5-coder 离线部署 嵌入式 linux驱动开发 arm开发 jmeter 软件测试 僵尸进程 pip 监控 自动化运维 DeepSeek-R1 API接口 ollama下载加速 sqlserver pillow live555 rtsp rtp json html5 firefox WSL win11 无法解析服务器的名称或地址 https django flask web3.py apache 小程序 微信小程序域名配置 微信小程序服务器域名 微信小程序合法域名 小程序配置业务域名 微信小程序需要域名吗 微信小程序添加域名 自动化 蓝耘科技 元生代平台工作流 ComfyUI web安全 Kali Linux 黑客 渗透测试 信息收集 vue3 HTML audio 控件组件 vue3 audio音乐播放器 Audio标签自定义样式默认 vue3播放音频文件音效音乐 自定义audio播放器样式 播放暂停调整声音大小下载文件 代码调试 ipdb asm selenium 测试工具 群晖 文件分享 WebDAV NPS 雨云服务器 雨云 1024程序员节 能力提升 面试宝典 技术 IT信息化 iftop 网络流量监控 环境迁移 服务器管理 宝塔面板 配置教程 服务器安装 网站管理 崖山数据库 YashanDB 华为od 源码剖析 rtsp实现步骤 流媒体开发 postgresql 大语言模型 make命令 makefile文件 Ubuntu 24.04.1 轻量级服务器 NFS redhat prometheus kubernetes 监控k8s 监控kubernetes shell rsyslog 客户端 java-ee 毕设 jar 程序人生 相差8小时 UTC 时间 Java 云原生 sqlite3 elasticsearch 鸿蒙系统 华为云 远程控制 远程看看 远程协助 并查集 leetcode kylin 银河麒麟操作系统 国产化 rpc 远程过程调用 Windows环境 Docker Hub docker pull 镜像源 daemon.json Linux Ubuntu 24 常用命令 Ubuntu 24 Ubuntu vi 异常处理 安卓 直播推流 爬虫 数据集 ipython svn 文件系统 路径解析 串口服务器 LLM 大模型面经 职场和发展 Deepseek 大模型学习 缓存 k8s WebUI DeepSeek V3 DeepSeek AI大模型 kvm 无桌面 命令行 gitea 媒体 微信公众平台 risc-v zabbix gpu算力 gitlab ci/cd 计算机 jupyter 编辑器 html css 系统架构 Invalid Host allowedHosts vue mongodb efficientVIT YOLOv8替换主干网络 TOLOv8 matlab bootstrap web Socket 统信UOS bonding 链路聚合 压力测试 命令 mount挂载磁盘 wrong fs type LVM挂载磁盘 Centos7.9 ecm bpm 压测 ECS RAGFLOW RAG 检索增强生成 文档解析 大模型垂直应用 宕机切换 服务器宕机 webrtc 远程工作 课程设计 监控k8s集群 集群内prometheus Playwright 自动化测试 VMware安装Ubuntu Ubuntu安装k8s 数据库架构 数据管理 数据治理 数据编织 数据虚拟化 protobuf 序列化和反序列化 安装 idm 游戏服务器 Minecraft AIGC gpt linux上传下载 webstorm 医疗APP开发 app开发 强制清理 强制删除 mac废纸篓 iDRAC R720xd bash k8s集群资源管理 云原生开发 freebsd hadoop 信息与通信 zotero 同步失败 代理模式 游戏程序 ios playbook thingsboard ai小智 语音助手 ai小智配网 ai小智教程 智能硬件 esp32语音助手 diy语音助手 磁盘监控 部署 服务器配置 Ark-TS语言 技能大赛 rabbitmq dell服务器 go 硬件架构 ros2 moveit 机器人运动 IIS .net core Hosting Bundle .NET Framework vs2022 eureka 虚拟机 VMware XFS xfs文件系统损坏 I_O error es jvm netty file server http server web server 驱动开发 mcu 集成学习 集成测试 okhttp eNSP 网络规划 VLAN 企业网络 wireshark 显示过滤器 ICMP Wireshark安装 生物信息学 openEuler pygame linux环境变量 状态管理的 UDP 服务器 Arduino RTOS DNS minio mariadb 腾讯云 VMware安装mocOS macOS系统安装 低代码 devops fpga开发 yum k8s资源监控 annotations自动化 自动化监控 监控service 监控jvm 灵办AI 交换机 硬件 设备 GPU PCI-Express 微信小程序 图形化界面 visual studio code jetty undertow UOS 统信操作系统 spring cloud spring Docker Compose docker compose docker-compose SysBench 基准测试 gcc ip wsl2 wsl 音乐服务器 Navidrome 音流 TRAE 系统开发 binder 车载系统 framework 源码环境 Samba NAS 智能手机 Termux GCC crosstool-ng Erlang OTP gen_server 热代码交换 事务语义 系统安全 dify hugo ESXi Dell HPE 联想 浪潮 Linux PID 远程桌面 ruoyi RAID RAID技术 磁盘 存储 MQTT协议 消息服务器 代码 多层架构 解耦 DeepSeek行业应用 Heroku 网站部署 测试用例 功能测试 Trae AI代码编辑器 kind virtualenv selete 高级IO AI写作 AI作画 程序员 react next.js 部署next.js QQ 聊天室 asp.net大文件上传 asp.net大文件上传源码 ASP.NET断点续传 asp.net上传文件夹 asp.net上传大文件 .net core断点续传 .net mvc断点续传 政务 分布式系统 监控运维 Prometheus Grafana 分析解读 思科模拟器 思科 Cisco nuxt3 ceph tcpdump 设计模式 软件工程 muduo X11 Xming rocketmq 其他 剧本 机器人 深度求索 私域 知识库 sql KingBase etcd 数据安全 RBAC 企业微信 Linux24.04 deepin MacMini Mac 迷你主机 mini Apple 弹性计算 虚拟化 KVM 计算虚拟化 弹性裸金属 金融 数据挖掘 腾讯云大模型知识引擎 网络用户购物行为分析可视化平台 大数据毕业设计 蓝桥杯 小艺 Pura X excel 微信开放平台 微信公众号配置 远程登录 telnet 安全威胁分析 vscode 1.86 grafana IPMI unix 网站搭建 serv00 报错 漏洞 unity3d 银河麒麟 kylin v10 麒麟 v10 docker搭建nacos详解 docker部署nacos docker安装nacos 腾讯云搭建nacos centos7搭建nacos 网络穿透 云服务器 HarmonyOS Next Nuxt.js SSH Xterminal springboot远程调试 java项目远程debug docker远程debug java项目远程调试 springboot远程 远程连接 VR手套 数据手套 动捕手套 动捕数据手套 JAVA Redis Desktop 裸金属服务器 弹性裸金属服务器 express p2p 命名管道 客户端与服务端通信 CPU 主板 电源 网卡 postman mock mock server 模拟服务器 mock服务器 Postman内置变量 Postman随机数据 CORS 跨域 Netty 即时通信 NIO av1 电视盒子 机顶盒ROM 魔百盒刷机 向日葵 3d 数学建模 边缘计算 多进程 远程 执行 sshpass 操作 micropython esp32 mqtt IIS服务器 IIS性能 日志监控 半虚拟化 硬件虚拟化 Hypervisor 田俊楠 safari 系统 sqlite MS Materials chrome devtools chromedriver openssl 密码学 gateway Clion Nova ResharperC++引擎 Centos7 远程开发 firewalld 业界资讯 模拟退火算法 code-server MQTT mosquitto 消息队列 ArcTS 登录 ArcUI GridItem arkUI r语言 数据可视化 数据分析 pgpool ecmascript 数据库系统 C# MQTTS 双向认证 emqx kafka hibernate Cursor kamailio sip VoIP echarts 信息可视化 网页设计 gradle 开机自启动 W5500 OLED u8g2 TCP服务器 chfs ubuntu 16.04 remote-ssh ip命令 新增网卡 新增IP 启动网卡 Portainer搭建 Portainer使用 Portainer使用详解 Portainer详解 Portainer portainer ue4 着色器 ue5 虚幻 rust腐蚀 统信 国产操作系统 虚拟机安装 目标跟踪 OpenVINO 推理应用 框架搭建 bot Docker 火绒安全 Reactor C++ DevEco Studio 小游戏 五子棋 vSphere vCenter 软件定义数据中心 sddc RTMP 应用层 孤岛惊魂4 threejs 3D uniapp nvidia OD机试真题 华为OD机试真题 服务器能耗统计 恒源云 传统数据库升级 银行 LLMs Dify 进程信号 CLion IDE IPMITOOL BMC 硬件管理 opcua opcda KEPServer安装 oneapi 大模型微调 open webui mysql离线安装 ubuntu22.04 mysql8.0 图像处理 服务器数据恢复 数据恢复 存储数据恢复 北亚数据恢复 oracle数据恢复 混合开发 环境安装 JDK 服务器繁忙 pdf VSCode 华为认证 网络工程师 多线程服务器 Linux网络编程 移动云 android studio springsecurity6 oauth2 授权服务器 token sas 基础入门 编程 FTP 服务器 XCC Lenovo 繁忙 解决办法 替代网站 汇总推荐 AI推理 dba curl wget centos-root /dev/mapper yum clean all df -h / du -sh Anolis nginx安装 linux插件下载 springboot 设置代理 实用教程 list raid5数据恢复 磁盘阵列数据恢复 skynet Ubuntu DeepSeek DeepSeek Ubuntu DeepSeek 本地部署 DeepSeek 知识库 DeepSeek 私有化知识库 本地部署 DeepSeek DeepSeek 私有化部署 visualstudio linux 命令 sed 命令 服务器部署ai模型 RoboVLM 通用机器人策略 VLA设计哲学 vlm fot robot 视觉语言动作模型 具身智能 SSL 域名 AI 原生集成开发环境 Trae AI SSH 服务 SSH Server OpenSSH Server ragflow 硬件工程 嵌入式实习 cnn nextjs reactjs RustDesk自建服务器 rustdesk服务器 docker rustdesk 黑客技术 流式接口 Ubuntu Server Ubuntu 22.04.5 本地部署 api pyqt Kylin-Server minicom 串口调试工具 飞牛NAS 飞牛OS MacBook Pro EasyConnect Cline 服务器主板 AI芯片 open Euler dde 交互 网工 opensearch helm 搜索引擎 ssrf 失效的访问控制 WebRTC openwrt ux 多线程 Google pay Apple pay adobe Linux awk awk函数 awk结构 awk内置变量 awk参数 awk脚本 awk详解 elk Python 网络编程 聊天服务器 套接字 TCP docker命令大全 xrdp 5G 3GPP 卫星通信 string模拟实现 深拷贝 浅拷贝 经典的string类问题 三个swap TrinityCore 魔兽世界 指令 mq 中间件 iis VMware创建虚拟机 性能测试 iphone odoo 服务器动作 Server action tidb GLIBC python3.11 bug Linux的权限 视频编解码 怎么卸载MySQL MySQL怎么卸载干净 MySQL卸载重新安装教程 MySQL5.7卸载 Linux卸载MySQL8.0 如何卸载MySQL教程 MySQL卸载与安装 rdp 远程服务 dash 正则表达式 视觉检测 高效日志打印 串口通信日志 服务器日志 系统状态监控日志 异常记录日志 UOS1070e 稳定性 看门狗 代码托管服务 Typore sentinel ruby 影刀 #影刀RPA# Claude npm c swoole AnythingLLM AnythingLLM安装 三级等保 服务器审计日志备份 FTP服务器 单例模式 wordpress 无法访问wordpess后台 打开网站页面错乱 linux宝塔面板 wordpress更换服务器 实习 架构与原理 交叉编译 信号处理 CrewAI 软考 qemu libvirt MacOS录屏软件 WebVM mamba Vmamba 联想开天P90Z装win10 流水线 脚本式流水线 多个客户端访问 IO多路复用 回显服务器 TCP相关API 反向代理 DenseNet Linux环境 GoogLeNet CH340 串口驱动 CH341 uart 485 camera Arduino 电子信息 tailscale derp derper 中转 triton 模型分析 矩阵 线性代数 电商平台 大文件分片上传断点续传及进度条 如何批量上传超大文件并显示进度 axios大文件切片上传详细教 node服务器合并切片 vue3大文件上传报错提示错误 大文件秒传跨域报错cors IDEA 互信 C++软件实战问题排查经验分享 0xfeeefeee 0xcdcdcdcd 动态库加载失败 程序启动失败 程序运行权限 标准用户权限与管理员权限 上传视频至服务器代码 vue3批量上传多个视频并预览 如何实现将本地视频上传到网页 element plu视频上传 ant design vue vue3本地上传视频及预览移除 can 线程池 网络攻击模型 bcompare Beyond Compare USB网络共享 模拟器 教程 ui cursor MCP server C/S aarch64 编译安装 HPC windows日志 无人机 DOIT 四博智联 iBMC UltraISO Unity Dedicated Server Host Client 无头主机 lua arm vue-i18n 国际化多语言 vue2中英文切换详细教程 如何动态加载i18n语言包 把语言json放到服务器调用 前端调用api获取语言配置文件 端口测试 输入法 ssh漏洞 ssh9.9p2 CVE-2025-23419 H3C docker run 数据卷挂载 交互模式 vmware 卡死 常用命令 文本命令 目录命令 自动化编程 自动驾驶 音乐库 飞牛 安防软件 etl kali 共享文件夹 lsb_release /etc/issue /proc/version uname -r 查看ubuntu版本 嵌入式Linux IPC 前后端分离 EMUI 回退 降级 升级 midjourney 服务器无法访问 ip地址无法访问 无法访问宝塔面板 宝塔面板打不开 linux安装配置 xml RAGFlow 本地知识库部署 DeepSeek R1 模型 FunASR ASR 佛山戴尔服务器维修 佛山三水服务器维修 TrueLicense 软件构建 虚拟显示器 apt cmos Jellyfin 链表 实战案例 Spring Security 重启 排查 系统重启 日志 原因 我的世界 我的世界联机 数码 perf rime 干货分享 黑客工具 密码爆破 hive DBeaver 数据仓库 kerberos 单元测试 实验 技术共享 我的世界服务器搭建 王者荣耀 Wi-Fi ros 超融合 产测工具框架 IMX6ULL 管理框架 Ubuntu共享文件夹 共享目录 Linux共享文件夹 eclipse openstack Xen 鲲鹏 昇腾 npu ISO镜像作为本地源 游戏开发 cfssl 执法记录仪 智能安全帽 smarteye edge浏览器 云电竞 云电脑 todesk MNN Qwen 备份SQL Server数据库 数据库备份 傲梅企业备份网络版 Logstash 日志采集 tensorflow trae nac 802.1 portal pppoe radius ROS 聚类 gaussdb 本地部署AI大模型 dns是什么 如何设置电脑dns dns应该如何设置 LInux xss 在线预览 xlsx xls文件 在浏览器直接打开解析xls表格 前端实现vue3打开excel 文件地址url或接口文档流二进 虚拟局域网 ocr prompt AI agent 网络结构图 yaml Ultralytics 可视化 IM即时通讯 剪切板对通 HTML FORMAT 云服务 saltstack 实时互动 Radius gpt-3 文心一言 uni-file-picker 拍摄从相册选择 uni.uploadFile H5上传图片 微信小程序上传图片 DIFY 国标28181 视频监控 监控接入 语音广播 流程 SIP SDP 可信计算技术 安全架构 显卡驱动 大模型应用 算力 OpenSSH 社交电子 序列化反序列化 高效远程协作 TrustViewer体验 跨设备操作便利 智能远程控制 IPv4 子网掩码 公网IP 私有IP 匿名管道 主从复制 EMQX 通信协议 VS Code frp 人工智能生成内容 工业4.0 宠物 毕业设计 免费学习 宠物领养 宠物平台 windwos防火墙 defender防火墙 win防火墙白名单 防火墙白名单效果 防火墙只允许指定应用上网 防火墙允许指定上网其它禁止 clickhouse composer 同步 备份 建站 阻塞队列 生产者消费者模型 服务器崩坏原因 laravel Linux无人智慧超市 LInux多线程服务器 QT项目 LInux项目 单片机项目 less 小智AI服务端 xiaozhi TTS 直流充电桩 充电桩 Linux的基础指令 junit AD 域管理 小番茄C盘清理 便捷易用C盘清理工具 小番茄C盘清理的优势尽显何处? 教你深度体验小番茄C盘清理 C盘变红?!不知所措? C盘瘦身后电脑会发生什么变化? 显示管理器 lightdm gdm 双系统 GRUB引导 Linux技巧 线程 程序员创富 P2P HDLC AD域 uv rclone AList webdav fnOS 致远OA OA服务器 服务器磁盘扩容 glibc tcp SWAT 配置文件 服务管理 网络共享 7z 游戏机 毕昇JDK HTTP 服务器控制 ESP32 DeepSeek minecraft 备选 网站 调用 示例 银河麒麟桌面操作系统 Kylin OS 软负载 AI-native Docker Desktop neo4j 数据库开发 database 查询数据库服务IP地址 SQL Server matplotlib yolov8 语音识别 AutoDL wps ubuntu24.04.1 keepalived 分布式训练 sonoma 自动更新 c/c++ 串口 xshell termius iterm2 IO模型 vasp安装 n8n 工作流 workflow qt项目 qt项目实战 qt教程 历史版本 下载 EtherNet/IP串口网关 EIP转RS485 EIP转Modbus EtherNet/IP网关协议 EIP转RS485网关 EIP串口服务器 xcode rnn 服务网格 istio arcgis AISphereButler outlook seatunnel 银河麒麟高级服务器 外接硬盘 Kylin g++ g++13 Cookie flink 根服务器 华为机试 UDP的API使用 语法 rag ragflow 源码启动 做raid 装系统 Java Applet URL操作 服务器建立 Socket编程 网络文件读取 运维监控 大模型入门 大模型教程 ukui 麒麟kylinos openeuler IMX317 MIPI H265 VCU pyautogui vpn 用户缓冲区 模拟实现 CVE-2024-7347 rustdesk 支付 微信支付 开放平台 ArkTs ArkUI VPS 图形渲染 内网服务器 内网代理 内网通信 EtherCAT转Modbus ECT转Modbus协议 EtherCAT转485网关 ECT转Modbus串口网关 EtherCAT转485协议 ECT转Modbus网关 VM搭建win2012 win2012应急响应靶机搭建 攻击者获取服务器权限 上传wakaung病毒 应急响应并溯源 挖矿病毒处置 应急响应综合性靶场 黑苹果 需求分析 规格说明书 代理 sdkman DeepSeek r1 Open WebUI dns cd 目录切换 Mac内存不够用怎么办 big data OpenManus alias unalias 别名 飞书 宝塔 web3 SenseVoice miniapp 真机调试 调试 debug 断点 网络API请求调试方法 单一职责原则 国内源 Kali 渗透 源码 游戏引擎 策略模式 自学笔记 小米 澎湃OS Android regedit 开机启动 版本 asp.net大文件上传下载 京东云 Hive环境搭建 hive3环境 Hive远程模式 spark HistoryServer Spark YARN jobhistory webgl CDN Headless Linux bat trea idea flash-attention 自定义客户端 SAS 僵尸世界大战 游戏服务器搭建 zookeeper AP配网 AK配网 小程序AP配网和AK配网教程 WIFI设备配网小程序UDP开 nfs Ubuntu22.04 开发人员主页 embedding epoll 自动化任务管理 Windows ai工具 v10 软件 easyui langchain ldap armbian u-boot 阿里云ECS 相机 权限 LORA NLP 邮件APP 免费软件 log4j yum源切换 更换国内yum源 URL 项目部署到linux服务器 项目部署过程 ftp 键盘 banner 移动魔百盒 fd 文件描述符 USB转串口 飞牛nas fnos 迁移指南 LLM Web APP Streamlit cpp-httplib MI300x vscode1.86 1.86版本 ssh远程连接 vr SSE 免费域名 域名解析 SRS 流媒体 直播 DocFlow 开发环境 SSL证书 sysctl.conf vm.nr_hugepages perl db 李心怡 粘包问题 镜像 信创 信创终端 中科方德 Python基础 Python教程 Python技巧 x64 SIGSEGV xmm0 WLAN 大模型部署 知识图谱 查看显卡进程 fuser navicat ArtTS zip unzip 软链接 硬链接 figma 基础环境 网络爬虫 visual studio nvm whistle Attention CentOS KylinV10 麒麟操作系统 Vmware word ranger MySQL8.0 问题解决 ubuntu24 vivado24 网络药理学 生信 gromacs 分子动力学模拟 MD 动力学模拟 kotlin Deepseek-R1 私有化部署 推理模型 ssh远程登录 虚幻引擎 virtualbox 防火墙 NAT转发 NAT Server 树莓派 VNC Sealos 域名服务 DHCP 符号链接 配置 浏览器开发 AI浏览器 嵌入式系统开发 hosts Unity插件 gnu iventoy VmWare OpenEuler css3 程序 烟花代码 烟花 元旦 性能调优 安全代理 多端开发 智慧分发 应用生态 鸿蒙OS 云桌面 微软 AD域控 证书服务器 powerpoint 环境配置 dity make 浏览器自动化 中兴光猫 换光猫 网络桥接 自己换光猫 性能分析 磁盘清理 searxng PPI String Cytoscape CytoHubba 加解密 Yakit yaklang Docker引擎已经停止 Docker无法使用 WSL进度一直是0 镜像加速地址 沙盒 UDP 带外管理 元服务 应用上架 换源 Debian HarmonyOS NEXT 原生鸿蒙 firewall 服务器时间 deekseek TCP协议 计算生物学 生物信息 基因组 抗锯齿 拓扑图 流量运营 milvus 健康医疗 互联网医院 大模型推理 fstab vu大文件秒传跨域报错cors MVS 海康威视相机 llama.cpp top Linux top top命令详解 top命令重点 top常用参数 ubuntu20.04 ros1 Noetic 20.04 apt 安装 react native 强化学习 proxy模式 状态模式 信号 个人博客 onlyoffice 在线office jina SSH 密钥生成 SSH 公钥 私钥 生成 云耀服务器 HAProxy 物联网开发 rtsp服务器 rtsp server android rtsp服务 安卓rtsp服务器 移动端rtsp服务 大牛直播SDK 容器技术 docker搭建pg docker搭建pgsql pg授权 postgresql使用 postgresql搭建 hexo HarmonyOS iperf3 带宽测试 seleium SEO 上传视频文件到服务器 uniApp本地上传视频并预览 uniapp移动端h5网页 uniapp微信小程序上传视频 uniapp app端视频上传 uniapp uview组件库 grub 版本升级 扩容 开发 QT 5.12.12 QT开发环境 Ubuntu18.04 磁盘镜像 服务器镜像 服务器实时复制 实时文件备份 对比 工具 meld DiffMerge 项目部署 推荐算法 lio-sam SLAM 软件卸载 系统清理 deployment daemonset statefulset cronjob 读写锁 AI Agent 字节智能运维 办公自动化 自动化生成 pdf教程 SVN Server tortoise svn fast 端口 查看 ss ABAP 合成模型 扩散模型 图像生成 ShenTong k8s二次开发 集群管理 OpenHarmony 鸿蒙开发 移动开发 存储维护 NetApp存储 EMC存储 端口聚合 windows11 捆绑 链接 谷歌浏览器 youtube google gmail PX4 Linux find grep 钉钉 MacOS sequoiaDB cocoapods 抓包工具 System V共享内存 进程通信 prometheus数据采集 prometheus数据模型 prometheus特点 autodl HiCar CarLife+ CarPlay QT RK3588 Node-Red 编程工具 流编程 docker desktop image IMM 网络建设与运维 智能音箱 智能家居 NLP模型 考研 wpf 本地化部署 xpath定位元素 kernel 玩机技巧 软件分享 软件图标 MDK 嵌入式开发工具 论文笔记 sublime text wsgiref Web 服务器网关接口 Qwen2.5-VL vllm deep learning su sudo docker部署翻译组件 docker部署deepl docker搭建deepl java对接deepl 翻译组件使用 chrome 浏览器下载 chrome 下载安装 谷歌浏览器下载 私有化 ardunio BLE 企业网络规划 华为eNSP 大大通 第三代半导体 碳化硅 java-rocketmq MySql nlp GIS 遥感 WebGIS h.264 内网环境 harmonyOS面试题 代理服务器 网卡的名称修改 eth0 ens33 金仓数据库 2025 征文 数据库平替用金仓 win服务器架设 windows server Xinference 极限编程 deepseek r1 conda配置 conda镜像源 docker部署Python 搭建个人相关服务器 vnc 区块链 yum换源 开机黑屏 电视剧收视率分析与可视化平台 增强现实 沉浸式体验 应用场景 技术实现 案例分析 AR 像素流送api 像素流送UE4 像素流送卡顿 像素流送并发支持 macOS 欧标 OCPP mm-wiki搭建 linux搭建mm-wiki mm-wiki搭建与使用 mm-wiki使用 mm-wiki详解 论文阅读 rancher 网络搭建 神州数码 神州数码云平台 云平台 ip协议 多路转接 英语 搜狗输入法 中文输入法 dock 加速 CentOS Stream 风扇控制软件 yolov5 热榜 数字证书 签署证书 Linux权限 权限命令 特殊权限 智能电视 js rpa WSL2 上安装 Ubuntu 达梦 DM8 AI员工 进程优先级 调度队列 进程切换 服务器正确解析请求体 IO 西门子PLC 通讯 接口优化 离线部署dify MAVROS 四旋翼无人机 nosql MobaXterm 解决方案 安装MySQL 通信工程 毕业