当前位置: 首页 > article >正文

图床项目(二) 接口设计

接口设计1 . muduo 网络模型该模型相较于普通的reactor模型复杂一点其中包括mainReactor 和 多个 subReactor其中每一个 subReactor·对应一个线程。其中 mainReactor 负责处理新连接 并将连接均匀分配给 subReactor 后续该新连接有对应的subReactor处理read、send操作。1.1 muduo网络模型核心接口intmain(){std::coutHello, World!std::endl;uint16_thttp_bind_port8081;constchar*http_bind_ip0.0.0.0;int32_tnum_event_loops4;// 4个subReactorEventLoop loop;// 主循环InetAddressaddr(http_bind_ip,http_bind_port);LOG_INFO port :http_bind_port ip :http_bind_ip;// 创建一个HttpServer对象HttpServerserver(loop,addr,HttpServer,num_event_loops);server.start();loop.loop();return0;}此代码和muduo的核心接口之间的关系客户端连接到达时主 EventLoop 的 EpollPoller::poll() 返回activeChannels_ 中包含 Acceptor 的那个 Channel因为 listenfd 可读。Channel::handleEvent() 被调用根据事件类型可读执行注册的回调即 Acceptor::handleRead()。Acceptor::handleRead() 调用 accept 接受新连接得到新 socket connfd。然后 HttpServer 会创建一个 TcpConnection 对象代表新连接并从线程池中选出一个 sub EventLoop根据 num_event_loops 创建的子 Reactor。这个 TcpConnection 对象内部又会创建一个新的 Channel封装 connfd并设置其读回调为 TcpConnection::handleRead()、写回调为 TcpConnection::handleWrite() 等。将该 Channel 注册到选中的 sub EventLoop 的 Poller 中从此该连接的 IO 事件由那个 sub EventLoop 独立处理。1.1.1 EventLoopEventLoop 是事件循环loop.loop() 会进入循环内部使用 Poller如 EpollPoller来监听事件。loop.loop();当进入到此段代码的时候EventLoop会无限循环核心工作就是调用Poller::poll()获取当前活跃的IO事件默认的 Poller 实现就是 EpollPoller它封装了 epoll 的系统调用epoll_create、epoll_ctl、epoll_wait1.1.2 HttpServerHttpServer server(loop, addr, HttpServer, num_event_loops); 创建时内部会初始化一个 Acceptor接受器。Acceptor 负责监听服务端 socket它内部包含一个 Channel该 Channel 封装了监听套接字listenfd并设置其读回调为 Acceptor::handleRead()。当调用 server.start() 时Acceptor 会将这个 Channel 注册到主 EventLoop 上即传入的 loop使得主 loop 能够监听 listenfd 的可读事件。1.1.3 Channel封装了listenfd 描述符 封装read_callback等IO事件1.1.4 EpollPoller负责监听问价描述符是否触发以及返回时间的文加盟描述符及具体时间的模块就是Poller。2. 具体实现思想TcpServer 是 muduo 提供的通用 TCP 服务器类负责处理 TCP 层 的事务监听端口、接受连接、管理连接生命周期、收发原始字节流。而 HTTP 是 应用层协议需要解析请求如 GET/POST、URL、头部、生成响应状态码、内容类型。这部分逻辑与具体的 TCP 细节无关。因此可以在TcpServer 的基础上封装一层HttpServer用来专门处理Http的请求。根据注册的回调事件处理。2.1 封装HttpServer类构造函数参数loop 主线程的eventloopaddr 封装ip portname 服务名字num_event_loops多少个subReactorserver_.setConnectionCallback 调用tcpsrver的对应方法将httpserver的成员函数onConn()注册到连接事件void onConnection(const TcpConnectionPtr conn)httpserver的成员函数TcpServer server_封装的原生的TcpServer对象通过server_.start()启动该服务** EventLoop *loop_ ** 每个IO对象如TcpConnection、Acceptor必须属于一个特定的EventLoop线程所有对该对象的操作如处理读写事件、关闭等都必须在那个EventLoop线程中进行。因此需要保存该EventLoop指针以便后续将任务投递到该线程如调用runInLoop或queueInLoop。// 构建httpserverclassHttpServer{public:// 构造函数 loop主线程的eventloop addr封装ip port name服务名字 num_event_loops多少个subReactorHttpServer(EventLoop*loop,constInetAddressaddr,conststd::stringname,intnum_event_loops):loop_(loop),server_(loop,addr,name){// 对回调函数的绑定server_.setConnectionCallback(std::bind(HttpServer::onConnection,this,std::placeholders::_1));// 对收到数据后回调函数的绑定server_.setMessageCallback(std::bind(HttpServer::onMessage,this,// 三个占位符 -- onmessage函数有三个变量std::placeholders::_1,std::placeholders::_2,std::placeholders::_3));server_.setWriteCompleteCallback(std::bind(HttpServer::onWriteComplete,this,std::placeholders::_1));server_.setThreadNum(num_event_loops);}// 启动voidstart(){server_.start();}private:voidonConnection(constTcpConnectionPtrconn)// 新建连接和断开连接都会执行{LOG_INFO onConnectionconn.get();}voidonMessage(constTcpConnectionPtrconn,Buffer*buf,Timestamp time){LOG_INFO onMessageconn.get();}voidonWriteComplete(constTcpConnectionPtrconn){LOG_INFO onWriteComplete conn.get();}TcpServer server_;// 每个连接的回调数据 新连接/断开连接 收到数据 发送数据 --EventLoop*loop_nullptr;// 这是主线程的enentloopstd::atomicuint32_tconn_uuid_generator0;};2.2 封装HttpConn类注意因为对于httpserver每当触发onConnection的时候就会产生一个TcpConnectionPtr conn为了能够清晰的在对应的TcpConnection处理专属的httpconn所以需要封装一个HttpConn类TcpConnection muduo 网络库提供的 TCP 连接对象负责底层 Socket 的读写、连接状态维护。CHttpConn 自定义的 HTTP 业务处理类负责解析 HTTP 请求、执行具体业务逻辑如注册、登录、生成 HTTP 响应等。绑定就是将这两个对象关联起来使得每个 TcpConnection 都有一个专属的 CHttpConn 来处理它的应用层数据。如果不进行此类的封装就会出现问题数据交叉处理、响应错发等实现思路std::mapuint32_t, CHttpConnPtr s_http_map使用map 维护 key tcpserver中的context valueCHttpConn对象std::atomicuint32_t conn_uuid_generator 0;使用一个原子变量每次建立连接的时候自增用来设置为tcpserver中的context并且在CHttpconn对象中也有一个成员变量uint32_t uuid_ 0; 该标识是从tcpconn中来的这样就能做好标记。具体实现classCHttpConn:publicstd::enable_shared_from_thisCHttpConn{public:// 需要把httpconnectionptr传进来 和 ChttpConn绑定CHttpConn(TcpConnectionPtr tcp_conn){uuid_std::any_castuint32_t(tcp_conn_-getContext());}virtual~CHttpConn();voidOnRead(Buffer*buf);private://根据 不同的数据调用不同的业务逻辑函数// 账号注册处理int_HandleRegisterRequest(stringurl,stringpost_data);// 账号登陆处理int_HandleLoginRequest(stringurl,stringpost_data);TcpConnectionPtr tcp_conn_;uint32_tuuid_0;//该标识是从tcpconn中来的CHttpParserWrapper http_parser_;};usingCHttpConnPtrstd::shared_ptrCHttpConn;//声明称智能指针 别名注意当onMessage触发的时候调用http_conn中的OnRead(buf)方法具体执行逻辑要到CHttpConn中实现voidonMessage(constTcpConnectionPtrconn,Buffer*buf,Timestamp time){// 这里可以根据uuid 获取httpconn(因为在onConnection设置了上下文)uint32_tuuidstd::any_castuint32_t(conn-getContext());// 再根据uuid 获取httpconn的引用CHttpConnPtrhttp_conns_http_map[uuid];// 处理业务http_conn-OnRead(buf);// 直接在io线程处理}onRead()方法实现这里已经是获取到客户端发送来的数据包请求了所以需要引入http协议解析的第三方库进行url和content的解析。voidCHttpConn::OnRead(Buffer*buf){constchar*in_bufbuf-peek();// 获取数据int32_tlenbuf-readableBytes();// 可读数据长度// 使用http协议解析的第三方库CHttpParserWrapper http_parser;http_parser.ParseHttpContent(in_buf,len);if(http_parser.IsReadAll()){string urlhttp_parser.GetUrlString();string contenthttp_parser.GetBodyContentString();LOG_INFO get url : url;LOG_INFO get content : content;if(strncmp(url.c_str(),/api/reg,8)0){// 调用注册函数_HandleRegisterRequest(url,content);}elseif(strncmp(url.c_str(),/api/login,9)0){// 调用登录函数_HandleLoginRequest(url,content);}else{//如果不能处理的 直接返回// 构造回发的http协议数据 让服务器返回char*resp_contentnewchar[256];string str_json{\code\:1};uint32_tlen_jsonstr_json.size();// 暂时先放这里#defineHTTP_RESPONSE_REQ\HTTP/1.1 404 OK\r\n\Connection:close\r\n\Content-Length:%d\r\n\Content-Type:application/json;charsetutf-8\r\n\r\n%ssnprintf(resp_content,256,HTTP_RESPONSE_REQ,len_json,str_json.c_str());tcp_conn_-send(resp_content);// 构造的时候会把tcpconn传递过来}}// echo --封装http的数据(直接echo不行)// conn-send(in_buf,buf-readableBytes());}同时根据解析出来的api请求可以再封装api相关的处理方法。if(strncmp(url.c_str(),/api/reg,8)0){// 调用注册函数_HandleRegisterRequest(url,content);}elseif(strncmp(url.c_str(),/api/login,9)0){// 调用登录函数_HandleLoginRequest(url,content);}else.....2.3 封装API此处封装的api完全就是业务层面的处理了针对每一个不同的数据包的解析可以在void CHttpConn::OnRead(Buffer *buf)方法里面增加不同的业务处理方法此处先列举一个用户注册的。// 用户登录 -- 收到的数据 发回客户端的数据intApiRegisterUser(std::stringpost_data,std::stringresp_json){intret0;string user_name;string nick_name;string pwd;string phone;string email;// 判断数据是否为空if(post_data.empty()){LOG_ERRORdecodeRegisterJson failed;//序列化 把结果返回给客户端// code 1encdoRegisterJson(1,resp_json);return-1;}// json反序列化.........// 注册账号.........// 先在数据库查询用户名 昵称 是否存在 如果不存在才去注册.......return0;}jsonapp的序列化和反序列化序列化#includejson/json.h//创建json对象Json::Value root;//设置json属性root[code]code;//json序列化对象Json::FastWriter writer;//执行序列化str_jsonwriter.write(root);return0;反序列化#includejson/json.h//json对象Json::Value root;//json反序列对象Json::Reader jsonReader;//执行反序列化resjsonReader.parse(str_json,root);registerApi#includeapi_register.h#includeiostreamusingnamespacestd;#includejson/json.h#includemuduo/base/Logging.h// Logger日志头文件//序列化intencdoeRegisterJson(intcode,stringresp_json){// 创建一个json对象Json::Value root;// 添加数据root[code]code;// 序列化Json::FastWriter writer;// 返回json字符串resp_jsonwriter.write(root);return0;}//反序列化intdecodeRegisterJson(conststd::stringstr_json,stringuser_name,stringnick_name,stringpwd,stringphone,stringemail){boolres;// 创建一个json对象Json::Value root;// 反序列化Json::Reader reader;resreader.parse(str_json,root);if(!res){LOG_ERRORparse reg json failed;return-1;}// 用户名if(root[userName].isNull()){LOG_ERRORuserName null;return-1;}user_nameroot[userName].asString();// 昵称if(root[nickName].isNull()){LOG_ERRORnickName null;return-1;}nick_nameroot[nickName].asString();//密码if(root[firstPwd].isNull()){LOG_ERRORfirstPwd null;return-1;}pwdroot[firstPwd].asString();//电话 非必须if(root[phone].isNull()){LOG_WARNphone null;}else{phoneroot[phone].asString();}//邮箱 非必须if(root[email].isNull()){LOG_WARNemail null;}else{emailroot[email].asString();}}intregisterUser(stringuser_name,stringnick_name,stringpwd,stringphone,stringemail){intret0;// 还没有处理先直接返回0returnret;}// 用户登录 -- 收到的数据 发回客户端的数据intApiRegisterUser(std::stringpost_data,std::stringresp_json){intret0;string user_name;string nick_name;string pwd;string phone;string email;// 判断数据是否为空if(post_data.empty()){LOG_ERRORdecodeRegisterJson failed;//序列化 把结果返回给客户端// code 1encdoeRegisterJson(1,resp_json);return-1;}// json反序列化retdecodeRegisterJson(post_data,user_name,nick_name,pwd,phone,email);if(ret0){encdoeRegisterJson(1,resp_json);return-1;}// 注册账号// 先在数据库查询用户名 昵称 是否存在 如果不存在才去注册retregisterUser(user_name,nick_name,pwd,phone,email);//先不操作数据库看看性能encdoeRegisterJson(ret,resp_json);return0;}loginApi代码#includeapi_login.h#includeiostream#includestring#includejson/json.h#includemuduo/base/Logging.h// Logger日志头文件usingnamespacestd;intdecodeLoginJson(conststringjson_str,stringuser_name,stringpwd){boolres;Json::Value root;Json::Reader reader;resreader.parse(json_str,root);if(!res){LOG_ERRORparse login json failed ;return-1;}// 用户名if(root[user].isNull()){LOG_ERRORuser null;return-1;}user_nameroot[user].asString();//密码if(root[pwd].isNull()){LOG_ERRORpwd null;return-1;}pwdroot[pwd].asString();return0;}// 登录成功返回jsonintencodeLoginJson(intcode,stringtoken,stringstr_json){Json::Value root;root[code]code;if(code0){root[token]token;// 正常返回的时候才写入token}Json::FastWriter writer;str_jsonwriter.write(root);return0;}intverifyUserPassword(stringuser_name,stringpwd){intret0;// 这里暂时不做处理因为这里还没有涉及数据库returnret;}intsetToken(stringuser_name,stringtoken){intret0;token1234;//更新到redisreturnret;}// 用户登录 -- 收到的数据 发回客户端的数据intApiUserLogin(std::stringpost_data,std::stringresp_json){string user_name;string pwd;string token;// 判断数据是否为空if(post_data.empty()){encodeLoginJson(1,token,resp_json);return-1;}// 解析jsonif(decodeLoginJson(post_data,user_name,pwd)0){LOG_ERRORdecodeRegisterJson failed;encodeLoginJson(1,token,resp_json);return-1;}// 验证账号和密码是否匹配if(verifyUserPassword(user_name,pwd)0){LOG_ERRORverifyUserPassword failed;encodeLoginJson(1,token,resp_json);return-1;}// 生成tokenif(setToken(user_name,token)0){LOG_ERRORsetToken failed;encodeLoginJson(1,token,resp_json);return-1;}// 封装登录结果encodeLoginJson(0,token,resp_json);return0;}总结https://github.com/0voice

相关文章:

图床项目(二) 接口设计

接口设计 1 . muduo 网络模型 该模型相较于普通的reactor模型复杂一点,其中包括mainReactor 和 多个 subReactor ,其中每一个 subReactor对应一个线程。 其中 mainReactor 负责处理新连接 , 并将连接均匀分配给 subReactor ,后续…...

COA - CNN - BiGRU - Attention分类:新手友好的数据预测方案

COA-CNN-BiGRU-Attention分类 基于浣熊优化算法优化卷积神经网络(CNN)-双向门控循环单元(BGRU)结合注意力机制(Attention)的数据分类预测(可更换为回归/单变量/多变量时序预测,前私),Matlab代码,可直接运行,适合小白新手 无需更改…...

N诺机试题

2.整除&#xff08;末尾无空格用printf“ ”&#xff09;#include<stdio.h>int main(){int count0;for(int i100;i<1000;i){if(i%50&&i%60){printf("%d",i);count;if(count%100) printf("\n");else printf(" "); }}return 0;…...

手把手教你用4G Cat.1 bis开发智能硬件:从电路设计到低功耗优化的完整实战

4G Cat.1 bis智能硬件开发实战&#xff1a;从电路设计到低功耗优化的全流程指南 在共享充电宝扫码即用的便利背后&#xff0c;隐藏着一场关于低功耗通信的技术革命。当传统4G模块因高功耗让硬件开发者束手无策时&#xff0c;4G Cat.1 bis以单天线设计、10Mbps传输速率和μA级待…...

Babel polyfill配置全解析:为什么你的Next.js项目在IE11还是报错?

Babel polyfill配置全解析&#xff1a;为什么你的Next.js项目在IE11还是报错&#xff1f; 在2023年的前端生态中&#xff0c;浏览器兼容性依然是个令人头疼的问题。最近接手一个企业级Next.js项目时&#xff0c;我遇到了一个典型场景&#xff1a;开发环境一切正常&#xff0c;但…...

突破信息获取壁垒:智能内容解锁工具使用指南

突破信息获取壁垒&#xff1a;智能内容解锁工具使用指南 【免费下载链接】bypass-paywalls-chrome-clean 项目地址: https://gitcode.com/GitHub_Trending/by/bypass-paywalls-chrome-clean 你是否曾遇到这样的情况&#xff1a;一篇专业的技术文章、一份重要的研究报告…...

SEO_2024年最新SEO趋势与核心优化方法介绍

<h1 id"seo2024seo">SEO:2024年最新SEO趋势与核心优化方法介绍</h1> <p>在互联网时代&#xff0c;搜索引擎优化&#xff08;SEO&#xff09;仍然是网站流量和品牌推广的关键。2024年&#xff0c;SEO领域有许多新的趋势和核心优化方法&#xff0c;帮…...

终极ThinkPad风扇控制指南:如何让你的笔记本更安静更高效?

终极ThinkPad风扇控制指南&#xff1a;如何让你的笔记本更安静更高效&#xff1f; 【免费下载链接】TPFanCtrl2 ThinkPad Fan Control 2 (Dual Fan) for Windows 10 and 11 项目地址: https://gitcode.com/gh_mirrors/tp/TPFanCtrl2 你是否曾经被ThinkPad风扇的噪音困扰…...

CnDataSeed发布:中国科研工作者跳槽研究数据库(CAMRD)

一、数据简介 追踪学术流动&#xff0c;解析科研人才动力机制&#xff01; 在中国科研生态快速演化的背景下&#xff0c;科研人才流动是科研创新与学术产出的关键驱动力。但跳槽相关研究在高教研究中一直较为稀缺&#xff0c;系统化、可量化的科研工作者跳槽数据长期缺失&…...

MATLAB中扩展卡尔曼滤波与无迹卡尔曼滤波源代码:一键运行,误差对比及显示最大误差数字图像程...

MATLAB编写的EKF和UKF滤波程序源代码 扩展卡尔曼滤波、无迹卡尔曼滤波的MATLAB程序&#xff0c;有误差对比图像和最大误差数字的显示。 只有一个m文件&#xff0c;打开就能运行。 带中文注释。直接双击EKFUKFComparison.m就能看到两个滤波器在非线性系统里的较量。这个文件里塞…...

从EWA Splatting到3DGS:一阶泰勒展开如何保住高斯的“椭圆”形状?

从EWA Splatting到3DGS&#xff1a;一阶泰勒展开如何保住高斯的“椭圆”形状&#xff1f; 在计算机图形学的演进历程中&#xff0c;三维高斯分布&#xff08;3D Gaussian&#xff09;的投影问题一直是个既基础又关键的挑战。想象一下&#xff0c;当你试图将一个完美的三维椭球投…...

三相不平衡电压下H桥五电平并网逆变器并网控制探究

三相不平衡电压下级连H桥五电平并网逆变器并网控制&#xff0c;SPWM调制&#xff0c;正负序分离控制 1.采用正负序分离锁相环以及正序PI控制&#xff0c;负序PI控制 2.采用中点电位平衡控制-零序电压注入法 3.提供参考文献 提供仿真源文件&#xff0c;电流环参数设计&#xff0…...

浙政钉应用监控埋点参数(bid, sapp_id)到底去哪找?一份给开发者的沟通指南

浙政钉应用监控埋点参数获取实战指南&#xff1a;从沟通到落地的全流程解析 在政务数字化进程中&#xff0c;浙政钉作为重要的政务协同平台&#xff0c;其应用监控埋点数据的准确采集直接影响着后续的数据分析和决策支持。然而&#xff0c;许多开发团队在实际项目中常常陷入参数…...

DeepSeek LintCode 3867 · 范围内的数字计数 public int digitsCount(int d, int low, int high)

LintCode 3867 范围内的数字计数 问题分析 计算在区间 [low, high] 中&#xff0c;数字 d 出现的次数。 核心思想&#xff1a;使用数位DP或前缀和思想 • count(low, high) count(0, high) - count(0, low-1) 方法一&#xff1a;逐位统计法&#xff08;推荐&#xff09;AC pu…...

保姆级教程:用 Modelfile 快速部署 ModelScope 的 GGUF 模型到 Ollama(以 DeepSeek 为例)

从零到一&#xff1a;用Modelfile高效部署ModelScope的GGUF模型至Ollama实战指南 在本地运行大语言模型正成为开发者探索AI边界的新常态。不同于直接调用云端API&#xff0c;本地部署能带来数据隐私保障、响应速度提升以及模型深度定制等独特优势。Ollama作为轻量级模型运行框架…...

MMSegmentation项目交付必备:如何生成让客户/导师眼前一亮的可视化报告(附完整脚本)

MMSegmentation项目交付必备&#xff1a;如何生成让客户/导师眼前一亮的可视化报告&#xff08;附完整脚本&#xff09; 在计算机视觉项目的最终交付环节&#xff0c;一份专业、直观的可视化报告往往比堆砌技术参数更能打动客户或导师。MMSegmentation作为开源图像分割领域的标…...

Ubuntu 24.04 环境实战:ROS 2 Kilted 实现 SLAM 建图与 Nav2 导航

一、构建地图 1、安装依赖 安装 slam_toolbox 算法库&#xff1a; sudo apt install ros-kilted-slam-toolbox安装 TurtleBot3 全套支持包&#xff1a; sudo apt install ros-kilted-turtlebot3*2、使用清华源 如果apt安装很慢&#xff0c;请先配置清华源&#xff1a; sud…...

vs code 实现source insight中的快捷键功能

1.自定义快捷键连续两组快捷键CtrlK CtrlS打开键盘快捷键定义界面修改向前向后的快捷键。ctrlu删除当前行复制当前行到下面2.增加bookmarks功能扩展部分装插件&#xff0c;定义快捷键ctrlm增加标签可以修改标签3.多行移动多行向上移动&#xff0c;向下移动Windows/Linux 用 Alt…...

CentOS7-IP配置记录

简要说明 本文章主要记录CentOS7系统在桥接网络类型下的IP配置测试&#xff0c;主要分为静态和动态配置&#xff0c;以下部署配置仅作参考&#xff0c;可根据实际情况调整。 相关文章 CentOS7部署参考文章&#xff1a;VMware-CentOS7最小化安装记录 CentOS7指令参考文章&am…...

Android16进阶之MediaPlayer.selectTrack调用流程与实战(二百五十)

简介&#xff1a; CSDN博客专家、《Android系统多媒体进阶实战》作者 博主新书推荐&#xff1a;《Android系统多媒体进阶实战》&#x1f680; Android Audio工程师专栏地址&#xff1a; Audio工程师进阶系列【原创干货持续更新中……】&#x1f680; Android多媒体专栏地址&a…...

开源项目主题系统的3大核心机制深度解析:从CSS变量到动态切换的完整实现方案

开源项目主题系统的3大核心机制深度解析&#xff1a;从CSS变量到动态切换的完整实现方案 【免费下载链接】vue-vben-admin vbenjs/vue-vben-admin: 是一个基于 Vue.js 和 Element UI 的后台管理系统&#xff0c;支持多种数据源和插件扩展。该项目提供了一个完整的后台管理系统&…...

ESFT-gate-law-lite:法律文本智能分析新工具

ESFT-gate-law-lite&#xff1a;法律文本智能分析新工具 【免费下载链接】ESFT-gate-law-lite ESFT-gate-law-lite是基于HuggingFace的深度学习模型&#xff0c;专为法律领域定制。源自deepseek-ai团队&#xff0c;继承ESFT-vanilla-lite优势&#xff0c;强大而轻量&#xff0c…...

Ollama + DeepSeek + 芋道框架 + SearXNG 本地联网搜索完整教程

1. 环境准备与检查 在开始之前,请确保你的环境满足以下条件: 1.1 硬件要求 内存:建议至少8GB可用内存(运行7B模型需要约4-6GB) 硬盘:DeepSeek模型文件约4-5GB空间 CPU/GPU:如有NVIDIA GPU可加速推理(可选) 1.2 软件要求 操作系统:Windows 10/11、macOS、Linux均可 …...

首款支持AI渗透的WebShell管理工具,聊个天就能实现免杀|实现高隐蔽内网渗透

0x01 工具介绍 金刚狼首款支持 AI 渗透的 WebShell MCP&#xff0c;也是一款支持多层内网级联的 ASPX、ASHX 高级 WebShell 管理工具。工具采用 AES 加密通信&#xff0c;无需代理即可实现内网穿透&#xff0c;支持内存加载各类渗透工具&#xff0c;做到无文件落地隐蔽渗透目标…...

突破限制:BlenderCompat让Windows 7焕发新活力运行Blender 3.x

突破限制&#xff1a;BlenderCompat让Windows 7焕发新活力运行Blender 3.x 【免费下载链接】BlenderCompat Windows 7 support for Blender 3.x and newer 项目地址: https://gitcode.com/gh_mirrors/bl/BlenderCompat 在3D创作领域&#xff0c;Blender的每一次版本迭代…...

带标注的交通工具分类数据集,17334张原始图片,识别率92.4%,可识别汽车,公共汽车,自行车,摩托车,支持yolo,coco json,pascal voc xml格式

带标注的交通工具分类数据集&#xff0c;17334张原始图片&#xff0c;识别率92.4%&#xff0c;可识别汽车&#xff0c;公共汽车&#xff0c;自行车&#xff0c;摩托车&#xff0c;支持yolo&#xff0c;coco json&#xff0c;pascal voc xml格式 模型训练指标参数&#xff1a; …...

语音转换完全上手:Retrieval-based Voice-Conversion-WebUI从入门到精通

语音转换完全上手&#xff1a;Retrieval-based Voice-Conversion-WebUI从入门到精通 【免费下载链接】Retrieval-based-Voice-Conversion-WebUI 语音数据小于等于10分钟也可以用来训练一个优秀的变声模型&#xff01; 项目地址: https://gitcode.com/GitHub_Trending/re/Retr…...

日语零基础每天学习笔记【01-10】

第一天 日语五十音&#xff1a;平假名/片假名发音あア いイ うウ えエ おオaかカ きキ くク けケ こコkaさサ しシ すス せセ そソsaたタ ちチ つツ てテ とトtaなナ にニ ぬヌ ねネ のノnaはハ ひヒ ふフ へヘ ほホhaまマ みミ むム めメ もモmaや…...

密码安全必修课:为什么BCrypt比MD5更适合存储用户密码?

密码安全必修课&#xff1a;为什么BCrypt比MD5更适合存储用户密码&#xff1f; 在数字身份成为第二张身份证的时代&#xff0c;密码安全早已不是技术圈的内部话题。去年某社交平台600万用户数据泄露事件中&#xff0c;令人震惊的不是数据被盗本身&#xff0c;而是其中87%的密码…...

3.23-3.25笔记

这期实现温湿度采集、光照强度监测、智能设备控制&#xff08;加湿器、PWM 调光 LED、PWM 调速风扇&#xff09;确定引脚&#xff0c;根据原理图找出可以使用的引脚开关。根据手册信息PWM口GPIO0_D0和GPIO0_C6&#xff0c;把设备树GPIO0_D0做5G的复位disable&#xff0c;再加入…...