【项目管理】基于 C 语言的 QQ 聊天室实现(TCP + 多线程 + SQLite3)

基于 C 语言的 QQ 聊天室(TCP + 多线程 + SQLite3)

项目功能基础功能: 登录、注册、添加好友、私聊、创建群聊、群聊扩展功能: 删除好友、注销账号、好友在线状态、群管理(拉人/踢人)、VIP 特权、邮件通知等
功能介绍:模拟QQ聊天客户端:登录界面:1、登录2、注册		//将用户注册账户/密码信息存储在数据里3、注销服务器:转发信息:主要实现私聊和群聊的功能,只要通过服务器进行数据传输,最好都先用json在客户端打包,然后在服务器中解包处理信息:将从客户端发来的数据存储到数据库等操作主界面:1、添加好友			//是否需要同意2、查看我的好友		//显示好友当前状态,是否在线3、与好友私聊		//离线的信息怎么处理4、删除好友			//单删5、创建群聊6、开始群聊			//禁言7、拉好友进群		//群主和管理员的权限8、踢人				//群主和管理员的权限9、查看群中好友		//显示群主和管理员的权限、群员的权限10、注销账号11、公共朋友圈		//朋友圈//小游戏推荐使用TCP通信来实现,因为TCP只需要将客户端的fd存储在数据库,那么我们就可以随时想要客户端的fd然后给其发送信息。
==========================================================
1、画架构图--->实现什么功能
2、设置结构体
3、设置协议
4、设置函数
===================================================
客户端:>显示界面printf("1、登录    2、注册   3、退出  4、注销");单独写函数化界面Switch(){case 1:loginbreakcase 2:zhucebreakcase 3:logoutbreakcase 4:	zhuxiaobreak}//用户名:密码:...........send到服务器中---》数据存入数据库==================================================================服务器:1、并发服务器		考虑使用--->进程?线程?2、接受客户端的数据3、数据的转发数据库:1>打开数据库注册---写入登录---读取并匹配2>可以添加相关功能3>关闭数据库参考:服务器可以使用多路复用取创建线程,每一个线程都是单独和一个客户端进行通信客户端登录完成后,创建线程,专门用来接受服务器发送给客户端的信息数据库:需要多个table用户总表:储存注册的用户和密码,登录后将他的fd也放进去,下线后再次登录就更新。好友表:每当一个用户注册就创建一个好友表,里面储存该用户的好友名群聊总表:存储所有被创建的群聊名群聊成员总表:存储群聊里面的成员名=====================================================================

1. 系统架构设计

🔹 服务器端

	监听客户端连接多线程处理每个客户端使用 SQLite3 存储用户/好友/群信息解析 JSON 数据包转发私聊/群聊消息

🔹 客户端

	建立 TCP 连接JSON 格式封装数据交互界面(菜单选择私聊/群聊等)子线程接收服务器消息

🔹 1.1 架构图

+--------------------+          +------------------+
|      客户端       |    TCP/IP  |      服务器      |
+--------------------+ <------> +------------------+
| 1. 登录/注册      |             | 1. 处理用户请求  |
| 2. 添加好友       |             | 2. 保存数据到DB  |
| 3. 私聊/群聊      |             | 3. 发送/转发消息 |
| 4. 退出/注销      |             | 4. 维护在线状态  |
+--------------------+          +------------------+

聊天室实现流程图:(实现框架)
聊天室实现流程图

实现聊天室的登陆、注册流程图

注册:
注册
登陆:登陆
以上实现的编程思路逻辑为:

注册:
1、服务器要先启动,监听客户端的连接;
2、客户端启动,首先连接服务器,并显示登陆、注册界面;
3、服务器接收到客户端连接后,会创建一个子线程专门用于于客户端的通信;
4、选择注册后,提示输入用户名、密码,封装注册信息到结构体变量msg中,并发送该信令给服务器;
5、服务器接收到客户端注册信息后,进入注册处理流程;
6、注册功能:首先在数据库表中查找该用户名是否存在,如果不存在则使flage值为1,并且在数据库表中将该用户名密码保存到数据库中,并返回注册成功的信令;
否则使flage值为-1,并返回 错误信息;
7、客户端接收到服务器注册处理指令后,会打印提示信息,并显示步骤2的菜单。登陆:
1、服务器要先启动,监听客户端的连接;
2、客户端启动,首先连接服务器,并显示登陆、注册界面;
3、服务器接收到客户端连接后,会创建一个子线程专门用于于客户端的通信;
4、选择登陆后,提示输入用户名、密码,封装登陆信息到结构体变量msg中,并发送该信令给服务器;
5、服务器接收到客户端注册信息后,进入登陆处理流程;
6、登陆功能:首先查找该用户名、密码是否在数据库表中存在匹配项,找到返回对应的下标,并将于该客户端相连接的套接字保存到对应的条目中,返回登陆成功信息给客户端;如果没有找到,则返回-1,并返回错误信息给客户端;
7、客户端接收到服务器注册处理指令后,会打印提示信息,并设置客户端在线的标记login_f 为1,此时会显示 聊天功能对应的菜单。

客户端与服务端:私聊私聊

私聊流程:
1、客户端从菜单选择私聊功能;
2、输入要聊天的对象和聊天信息;
3、发送聊天信息给服务器;
4、服务器的子线程收到私聊数据之后,进入私聊流程;
5、向指定用户发送该私聊信息;

客户端与服务端:公聊
公聊

公聊流程:
1、客户端从菜单选择公聊功能;
2、输入要聊天信息;
3、回车发送聊天信息;
4、服务器的子线程收到公聊数据之后,进入公聊流程;
5、查找所有在线用户,向所有的在线用户发送该公聊信息;
6、客户端进入聊天后会创建一个子线程,该子线程会循环接收所有服务器发送的数据信息。

🔹 1.2 技术选型

组件技术方案
通信协议TCP(稳定可靠)
数据格式JSON(使用 cJSON 解析)
服务器模型I/O 多路复用(select 或 epoll)+ 线程池
数据库SQLite3(轻量级)
加密密码 SHA-256 哈希存储

2. 数据库设计

🔹 2.1 用户表(users)

字段类型说明
idINTEGER PRIMARY KEY用户 ID
usernameTEXT UNIQUE用户名
passwordTEXTSHA-256 哈希存储
statusINTEGER0=离线, 1=在线
fdINTEGER记录 socket 连接
CREATE TABLE users (id INTEGER PRIMARY KEY AUTOINCREMENT,username TEXT UNIQUE NOT NULL,password TEXT NOT NULL,status INTEGER DEFAULT 0,fd INTEGER DEFAULT -1
);

🔹 2.2 好友表(friends)

记录用户之间的好友关系。

字段类型说明
user_idINTEGER用户 ID
friend_idINTEGER好友 ID
CREATE TABLE friends (user_id INTEGER,friend_id INTEGER,FOREIGN KEY (user_id) REFERENCES users(id),FOREIGN KEY (friend_id) REFERENCES users(id)
);

🔹 2.3 群聊表(groups)

记录群聊信息。

字段类型说明
group_idINTEGER PRIMARY KEY群 ID
group_nameTEXT UNIQUE群名称
owner_idINTEGER群主 ID
CREATE TABLE groups (group_id INTEGER PRIMARY KEY AUTOINCREMENT,group_name TEXT UNIQUE NOT NULL,owner_id INTEGER NOT NULL,FOREIGN KEY (owner_id) REFERENCES users(id)
);

🔹 2.4 群成员表(group_members)

记录群聊成员及身份。

字段类型说明
group_idINTEGER群 ID
user_idINTEGER用户 ID
roleTEXTowner/admin/member
CREATE TABLE group_members (group_id INTEGER,user_id INTEGER,role TEXT CHECK(role IN ('owner', 'admin', 'member')) DEFAULT 'member',FOREIGN KEY (group_id) REFERENCES groups(group_id),FOREIGN KEY (user_id) REFERENCES users(id)
);

3. 通信协议(TCP)

请添加图片描述

🔹 3.1 数据包格式(JSON)

{"type": "login","username": "Alice","password": "123456"
}

🔹 3.2 主要消息类型

操作type 值附加字段
登录“login”username, password
注册“register”username, password
私聊“private_chat”from, to, message
群聊“group_chat”group_id, from, message
添加好友“add_friend”from, to
删除好友“delete_friend”from, to

4. 服务器端实现

🔹 4.1 服务器初始化

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <netinet/in.h>
#include <pthread.h>#define PORT 8080
#define MAX_CLIENTS 100void *handle_client(void *sockfd) {int client_sock = *(int *)sockfd;char buffer[1024];while (1) {memset(buffer, 0, sizeof(buffer));int bytes = recv(client_sock, buffer, sizeof(buffer), 0);if (bytes <= 0) {printf("客户端断开连接\n");break;}printf("收到消息: %s\n", buffer);send(client_sock, "消息收到", strlen("消息收到"), 0);}close(client_sock);return NULL;
}int main() {int server_sock, client_sock;struct sockaddr_in server_addr, client_addr;socklen_t client_size = sizeof(client_addr);server_sock = socket(AF_INET, SOCK_STREAM, 0);server_addr.sin_family = AF_INET;server_addr.sin_addr.s_addr = INADDR_ANY;server_addr.sin_port = htons(PORT);bind(server_sock, (struct sockaddr*)&server_addr, sizeof(server_addr));listen(server_sock, MAX_CLIENTS);printf("服务器启动, 监听端口 %d...\n", PORT);while (1) {client_sock = accept(server_sock, (struct sockaddr*)&client_addr, &client_size);printf("新客户端连接: %d\n", client_sock);pthread_t thread;pthread_create(&thread, NULL, handle_client, &client_sock);pthread_detach(thread);}close(server_sock);return 0;
}

5. 客户端实现

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <arpa/inet.h>#define SERVER_IP "127.0.0.1"
#define SERVER_PORT 8080int main() {int sock = socket(AF_INET, SOCK_STREAM, 0);struct sockaddr_in server_addr;server_addr.sin_family = AF_INET;server_addr.sin_port = htons(SERVER_PORT);inet_pton(AF_INET, SERVER_IP, &server_addr.sin_addr);connect(sock, (struct sockaddr*)&server_addr, sizeof(server_addr));char buffer[1024];while (1) {printf("输入消息: ");fgets(buffer, sizeof(buffer), stdin);send(sock, buffer, strlen(buffer), 0);memset(buffer, 0, sizeof(buffer));recv(sock, buffer, sizeof(buffer), 0);printf("服务器: %s\n", buffer);}close(sock);return 0;
}

5. 线程池优化(使用 epoll 处理多个客户端)

#include <sys/epoll.h>int epfd = epoll_create(1);
struct epoll_event event, events[MAX_CLIENTS];event.events = EPOLLIN;
event.data.fd = server_sock;
epoll_ctl(epfd, EPOLL_CTL_ADD, server_sock, &event);while (1) {int n = epoll_wait(epfd, events, MAX_CLIENTS, -1);for (int i = 0; i < n; i++) {if (events[i].data.fd == server_sock) {int client_sock = accept(server_sock, NULL, NULL);event.data.fd = client_sock;epoll_ctl(epfd, EPOLL_CTL_ADD, client_sock, &event);} else {char buffer[1024];recv(events[i].data.fd, buffer, sizeof(buffer), 0);printf("收到: %s\n", buffer);}}
}

以上为项目结构 和 模块化的编程思想,下面提供完整代码:

✅ 使用 TCP + JSON 进行消息传输;
✅ 基于 SQLite3 存储用户、好友、群聊信息;
✅ 服务器采用 多线程 + I/O 多路复用(epoll) 支持高并发。

客户端(client)

头文件集合

my.h

#ifndef __MY_H__
#define __MY_H__
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<unistd.h>
#include<sys/types.h>
#include<sys/stat.h>
#include<fcntl.h>
#include<sys/socket.h>
#include<arpa/inet.h>
#include<poll.h>
#include<stdbool.h>
#include<json/json.h>
#include<sqlite3.h>
#include<sys/time.h>
#include<signal.h>
#include<semaphore.h>
#include<pthread.h>
#include<errno.h>typedef struct msg{
char usr_name[20];
char passwd[20];
char qq_group[20];
char buf[100];
int qq;
int cmd;
}msg_q,*msg_p;extern void struct_init(msg_p* qt);
extern void json_init(msg_p * p);
extern const char * json_pack(msg_p p);
extern msg_p json_unpack(const char * buf1);
extern int user_insert(int fd);
extern int login_qq(int fd);
extern int add_friend(int fd);
extern int sql_into(msg_p qt);
extern int del_friend(int fd);
extern int sql_del(int qq);
extern int tuichu_qq(int fd);
extern int siliao_friend(int fd);
extern int group_fd(int fd);
extern int group_creat(msg_p qt);
extern int add_f_gp(int fd);
extern int table_show();
extern int fun1(void* arg,int col,char** str,char** name);
extern int qunliao(int fd);
extern int del_g_f(int fd);
extern int chakan();
extern int chakan_gf(int fd);
extern int qun_lib();#endif

json.h

#ifndef _JSON_H_
#define _JSON_H_
#include <stdio.h>
#include <string.h>
#include <json/json.h>
#include <stdlib.h>typedef struct msg{char usr_name[20];char passwd[20];char qq_group[20];char buf[100];int qq;int cmd;
}msg_q,*msg_p;extern void json_init(msg_p * p);
extern const char *json_pack(msg_p p);
extern msg_p json_unpack( const char *buf1);#endif
主函数

client.c

#include"my.h"
int fd;
extern int sdnum;
int main(int argc, char const *argv[])   //./client server_ip server_port
{if (argc!=3){printf("usage : %s <server_ip> <server_port>\n",argv[0]);//传参:服务器ip + 端口号exit(1);} msg_p qq;msg_p qq1;json_init(&qq);json_init(&qq1);const char* auf;char buf[521];fd=socket(AF_INET,SOCK_STREAM,0);if (fd<0){perror("socket");exit(1);}int ret;struct sockaddr_in server_addr;server_addr.sin_family=AF_INET;server_addr.sin_port=htons(atoi(argv[2]));server_addr.sin_addr.s_addr=inet_addr(argv[1]);ret=connect(fd,(struct sockaddr *)&server_addr,sizeof(server_addr));if (ret<0){perror("connect");exit(1);}/* fd_set myset;while(1){FD_ZERO(&myset); FD_SET(0,&myset);FD_SET(fd,&myset);select(fd+1, &myset, NULL,NULL,NULL);if(FD_ISSET(0,&myset)){*/
end:
while(1)
{fd_set myset;while(1){FD_ZERO(&myset); FD_SET(0,&myset);printf("-------------\n");printf("----1.注册---\n");printf("----2.登录---\n");printf("----3.退出---\n");printf("-------------\n");struct_init(&qq);printf("please chose:\n");select(fd+1, &myset, NULL,NULL,NULL);scanf("%d",&qq->cmd);if(FD_ISSET(0,&myset)){switch(qq->cmd){case 1:user_insert(fd);//注册bzero(buf,sizeof(buf));struct_init(&qq1);recv(fd,buf,sizeof(buf),0);qq1=json_unpack(buf);if(qq1->cmd==1){printf("注册成功\n");printf("你的QQ号为:%d\n",qq1->qq);}elseprintf("注册失败\n");break;case 2:login_qq(fd);//登录bzero(buf,sizeof(buf));struct_init(&qq1);recv(fd,buf,sizeof(buf),0);qq1=json_unpack(buf);if(qq1->cmd==1){printf("正在登录...\n");sleep(2);}else{printf("帐号或密码错误\n");break;}// menu();while(1){fd_set myset;while(1){
begin:FD_ZERO(&myset); FD_SET(0,&myset);FD_SET(fd,&myset);int qq_num;int i;//sleep(5);system("clear");printf("4.添加好友\n");printf("5.删除好友\n");printf("6.与好友私聊\n");printf("7.创建群聊\n");printf("8.拉好友进群\n");printf("9.开始群聊\n");printf("10.查看我的好友\n");printf("11.查看群中的好友\n");printf("12.退出登录\n");printf("请输入数字选择相应操作\n");select(fd+1, &myset, NULL,NULL,NULL);if(FD_ISSET(fd,&myset)){ do{bzero(buf,sizeof(buf));ret=recv(fd,buf,sizeof(buf),0);struct_init(&qq1);qq1=json_unpack(buf);			printf("%s\n",qq1->buf);if(qq1->cmd==1000){goto begin;}}while(qq1->cmd!=0);sleep(3);break;}scanf("%d",&i);if(FD_ISSET(0,&myset)){switch(i){case 4:add_friend(fd);//添加好友sleep(2);break;case 5:printf("请输入你要删除好友的QQ:");scanf("%d",&qq_num);//del_friend(fd);bzero(buf,sizeof(buf));struct_init(&qq1);qq1->cmd=5;qq1->qq=qq_num;auf=json_pack(qq1);send(fd,auf,strlen(auf),0);recv(fd,buf,sizeof(buf),0);qq1=json_unpack(buf);if(qq1->cmd==1){sql_del(qq_num);printf("删除成功\n");sleep(2);break;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/70895.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

无人机遥控器的亮度 和 两个工作频率

工作频率 2.4000-2.4835 GHz &#xff0c; 5.725-5.850 GHz 1.这是一个无人机的遥控器的两个工作频率&#xff0c;为什么会有两个工作频率&#xff1f; 无人机的遥控器采用双频段设计&#xff08;2.4GHz 和 5.8GHz&#xff09;&#xff0c;主要是为了解决以下问题并优化性…

drupal可以自动将测试环境的网页部署到生产环境吗

在 Drupal 中&#xff0c;自动将测试环境的网页部署到生产环境通常是通过设置合适的开发和部署流程来实现的。这种自动化部署过程通常涉及以下几个步骤&#xff1a; 1. 版本控制&#xff08;Git&#xff09; 为了保证测试环境和生产环境的一致性&#xff0c;首先需要使用 Git…

SOC-ATF 安全启动BL1流程分析(1)

一、ATF 源码下载链接 1. ARM Trusted Firmware (ATF) 官方 GitHub 仓库 GitHub 地址: https://github.com/ARM-software/arm-trusted-firmware 这是 ATF 的官方源码仓库&#xff0c;包含最新的代码、文档和示例。 下载方式&#xff1a; 使用 Git 克隆仓库&#xff1a; git…

《模拟器过检测教程:Nox、雷电、Mumu、逍遥模拟器 Magisk、LSposed 框架安装与隐藏应用配置》

一、夜神模拟器 (Nox) 过检测 使用版本&#xff1a;7.0.6.2&#xff08;20250209&#xff09; 1. 准备工作 将需要用到的应用放入文件夹&#xff1a; C:\Users\Administrator.DESKTOP-I5V50SS\Nox_share\Download 2. 安装面具鸭&#xff08;Magisk&#xff09; 在模拟器下…

.Net Core Visual Studio NuGet.Config 配置参考

Visual Studio 2022 NUGET NU1301 无法加载源 基础连接已关闭&#xff1a;无法建立SSL / TLS安全通道的信任关系&#xff1b;根据验证过程&#xff0c;远程证书无效&#xff0c;参考文章&#xff1a;https://blog.csdn.net/hefeng_aspnet/article/details/145780081 NuGet 行为…

同价位usb网卡与pcie网卡网速差距实测 热点测试

选用两款价位在75上下的网卡 2.4G usb&#xff1a; 2.4G pcie网卡&#xff1a; 5G PCIE 5G USB

DVWA -第二关-命令执行

这里是个ping命令的提交框 我们在输入ping命令的时候&#xff0c;同时执行其他命令操作 low 输入127.0.0.||ipconfig 消除乱码的方法&#xff1a;修改dvwaPage.inc.php文件中的”charsetutf-8”&#xff0c;修改”charsetGB2312” 可以显示出来&#xff0c;初级没有过滤 m…

通信方式汇总

在计算机网络和通信领域,通信方式指的是数据在网络中传输的方式和机制。不同的通信方式适用于不同的应用场景和需求。以下是几种常见的通信方式: 1. 同步通信与异步通信 同步通信: 数据传输是按固定时钟周期进行的,发送方和接收方需要保持同步。适用于需要严格时间同步的场…

类和对象——const修饰的类的对象和函数

const修饰的类的对象和函数 const成员函数和const对象1 const成员函数2 调用关系3 const在成员函数中的位置4 取地址&及const取地址操作符重载 const成员函数和const对象 1 const成员函数 将const修饰的“成员函数”称之为const成员函数&#xff0c;const修饰类成员函数&…

【DeepSeek-R1背后的技术】系列十三:归一化方式介绍(BatchNorm, LayerNorm, Instance Norm 和 GroupNorm)

【DeepSeek-R1背后的技术】系列博文&#xff1a; 第1篇&#xff1a;混合专家模型&#xff08;MoE&#xff09; 第2篇&#xff1a;大模型知识蒸馏&#xff08;Knowledge Distillation&#xff09; 第3篇&#xff1a;强化学习&#xff08;Reinforcement Learning, RL&#xff09;…

高压风机专用32位单片机MM32SPIN080G

专为高压风机量身打造的32位高性能单片机&#xff0c;拥有卓越的处理性能和丰富的接口资源&#xff0c;能够应对工业级应用的严苛要求。 RAMSUN高性能单电机控制SOC单片机——32位MM32SPIN080G&#xff0c;基于Cortex-M0内核构建&#xff0c;集成了200V三相N沟道栅极驱动器。它…

计算机毕设-基于springboot的融合多源高校画像数据与协同过滤算法的高考择校推荐系统的设计与实现(附源码+lw+ppt+开题报告)

博主介绍&#xff1a;✌多个项目实战经验、多个大型网购商城开发经验、在某机构指导学员上千名、专注于本行业领域✌ 技术范围&#xff1a;Java实战项目、Python实战项目、微信小程序/安卓实战项目、爬虫大数据实战项目、Nodejs实战项目、PHP实战项目、.NET实战项目、Golang实战…

nodejs将pdf转换成图片并提取图片内容

pdf2pic 安装方法 安装文档地址&#xff1a;https://github.com/yakovmeister/pdf2image/blob/HEAD/docs/gm-installation.md Windows下载下面两个文件&#xff0c;安装时没有自动设置环境变量&#xff0c;要分别设置到环境变量 Download Ghostscript Windows: https://gith…

机器学习--(随机森林,线性回归)

一、集成学习方法之随机森林 集成学习的基本思想就是将多个分类器组合&#xff0c;从而实现一个预测效果更好的集成分类器。集成算法可以说从一方面验证了中国的一句老话&#xff1a;三个臭皮匠&#xff0c;赛过诸葛亮。集成算法大致可以分为&#xff1a;Bagging&#xff0c;B…

RabbitMQ 的工作模式

目录 工作模式 Simple&#xff08;简单模式&#xff09; Work Queue&#xff08;工作队列&#xff09; Publish/Subscribe&#xff08;发布/订阅&#xff09; Exchange&#xff08;交换机&#xff09;? Routing&#xff08;路由模式&#xff09; Topics&#xff08;通配…

24.[前端开发-JavaScript基础]Day01-插件配置-变量-数据

一、邂逅JavaScript 1 认识编程语言 前端的三大核心 计算机语言 编程语言 常见的编程语言 2 编程语言发展历史 编程语言的发展历史 – 机器语言 编程语言的发展历史 – 汇编语言 编程语言的发展历史 – 高级语言 机器语言和高级语言 3 JavaScript的历史 认识JavaScript J…

uni-app集成sqlite

Sqlite SQLite 是一种轻量级的关系型数据库管理系统&#xff08;RDBMS&#xff09;&#xff0c;广泛应用于各种应用程序中&#xff0c;特别是那些需要嵌入式数据库解决方案的场景。它不需要单独的服务器进程或系统配置&#xff0c;所有数据都存储在一个单一的普通磁盘文件中&am…

為什麼使用不限量動態住宅IP採集數據?

在瞭解“不限量動態住宅IP數據採集”之前&#xff0c;我們需要先搞清楚什麼是“動態住宅IP”。簡單來說&#xff0c;動態IP是一種會定期變化的IP地址&#xff0c;通常由互聯網服務提供商&#xff08;ISP&#xff09;分配給家庭用戶。與固定IP&#xff08;靜態IP&#xff09;不同…

多模态人物视频驱动技术回顾与业务应用

一种新的商品表现形态&#xff0c;内容几乎存在于手淘用户动线全流程&#xff0c;例如信息流种草内容、搜索消费决策内容、详情页种草内容等。通过低成本、高时效的AIGC内容生成能力&#xff0c;能够从供给端缓解内容生产成本高的问题&#xff0c;通过源源不断的低成本供给倒推…

navicat161_premium_cs_x64 安装与使用

navicat161_premium_cs_x64 安装与使用https://mp.weixin.qq.com/s/eE90x59hDVdk-shXSvICbA