Linux下类似QQ聊天工具Word格式文档下载.docx
- 文档编号:21325776
- 上传时间:2023-01-29
- 格式:DOCX
- 页数:44
- 大小:417.63KB
Linux下类似QQ聊天工具Word格式文档下载.docx
《Linux下类似QQ聊天工具Word格式文档下载.docx》由会员分享,可在线阅读,更多相关《Linux下类似QQ聊天工具Word格式文档下载.docx(44页珍藏版)》请在冰豆网上搜索。
图322、登录:
如果协议为login,则将用户名和密码信息提取,再遍历存放用户信息文件里的用户名和密码直到验证成功为止,如果验证成功则对所有在线的川户发送一条消息:
“提示XX用户登录成功”;
如果失败则只给登阳失败的客户端提示登录失败,并给出原囚,如“用户名不存在”或者“用户名或者密码输入错误”,并跳转到相应的代码执行其他功能,成功则等特发送客户端消息,失败则关闭Socket并结束线程,如图33所示:
图333、监听和踢出客户端:
通过六行和修改绑定的Socket和在线用户队列实现查看和踢出在线用户,踢出用户后向被踢出用户发送相关信息,如图34、图35所示。
图34图353.1.2.客户端客户端客户端的输入和消息的显示要使用2个终端,一个是Client,一个是Display。
Client终端为输入的界面。
在这个界面里,新建一个线程来接受服务器端发来的消息,再添加时间信息,并将这些信息写入文件,然后给Display进程发送一个消息,Display进程接到消息,就去读取文件并将这些数拟显示在Display终端。
打开客户端Display终端界而,用lseek将内部指t阵行向文件末尾,等待Client终端里的线秤将消息写入文件。
一旦有消息过来就去文件里读取数据井打印在Display终端。
打开客户端Client终端界而,有3个菜单,包括注册、登录、退出。
选择相应项即可进幻相关操作,注册和登录如图32、图33所示。
3.1.3.协议协议服务器端和客户端之间互相通信需要使用的协议:
l、all$msg为给所有人发送消息。
2、直接输入view$获得在线用户列表。
3、user$msg给用户名为user的用户发送私聊消息。
4、trans$user$filenam将文件传输给who。
5、reg为注册。
6、login为登录。
3.2.聊天聊天模块模块3.2.1.客户端客户端客户端在登陆成功之后在发送消息之前可以先查看在线用户列表,查看用户列表使用view$,如所示。
图36接着,可以使用user$msg的形式发送信息,这个消息是发送给user的。
或者,先使用user$来切换到发送消息,这个时候,你不需要加上协议,即可给user这个用户发送消息,如图37、图38所示。
图37图38当然,上述方法也可以实现一对多聊天。
如所示。
图39这些消息都加上协议user$msg来封装成结构体,再发送给服务器端。
3.2.2.服务器端服务器端如果是私聊,则根据客户端要发送到哪个用户,到链表里取得该用户名的客户端信息,服务器再发送给相应的接收信息的客户端,接收信息的客户终端就会光将信息保存到聊天记录的文件里,并显示收到的信息,并且信息前面会显示相应的提示符。
3.3.文件传输模块文件传输模块3.3.1.客户端客户端如果某个客户端想发送文件给其他客户端,则直接使用命令trans$user$filename。
trans为协议,user为用户名,filename包括本地的路径和文件名。
如图310、图311所示。
图310图3113.3.2.服务器端服务器端当发送到服务器的时候,根据协议,先给接收的客户端发送一条消息为trans标记:
某某用户给您发送了XX文件,Y接收N拒绝接收。
如果客户端按下N,则返回一条消息给服务器端,服务器端同时告诉发送的客户端对方拒绝接收文件。
发送端可以继续做其他的事。
如果接收的客户端按下Y,并立即按受保存的路径和文件名。
输入完后就可以接收文件了。
客户端返回一条消息给无误器端,服务器端同时返回一条消息给发送的客户端,告诉客户端对方同意接收文件,这时候文件开始传输;
发送完毕后,发送的客户端会显示传输完毕。
传输的文件可以使任意的文们。
不仅仅是文本,多媒体文件也可以。
第第4章章实现实现本设计由C语言实现,用VIM编译。
/*check.h*/#include#include#include#include#include#include#include#include#include#include#defineMAXLEN1024structmessagecharflag15;
charname10;
intsize;
charmsgMAXLEN;
intreg_check(structmessage*recievemsg);
intlogin_check(structmessage*recievemsg);
/*check.c*/#includecheck.hintreg_check(structmessage*recievemsg)intfd;
intread_size,write_size;
structmessagecmpmsg;
if(strlen(recievemsg-name)10|strlen(recievemsg-msg)20)return1;
if(strcmp(recievemsg-name,all)=0)return-1;
if(strcmp(recievemsg-name,reg)=0)return-1;
if(strcmp(recievemsg-name,login)=0)return-1;
if(strcmp(recievemsg-name,trans)=0)return-1;
if(fd=open(user.txt,O_RDWR|O_CREAT|O_A,PPEND,0666)0)perror(open);
printf(openn);
return-2;
doif(read_size=read(fd,&
cmpmsg,sizeof(cmpmsg)name,cmpmsg.name)=0)close(fd);
return-1;
while(read_size=sizeof(structmessage);
if(write_size=write(fd,recievemsg,sizeof(structmessage)0)perror(write);
close(fd);
while(write_size!
=sizeof(structmessage)/write_size=0-writesize;
lseek(fd,-write_size,SEEK_CUR);
write_size=write(fd,recievemsg,sizeof(structmessage);
printf(writefilesuccessn);
return0;
intlogin_check(structmessage*recievemsg)intfd;
intread_size;
if(fd=open(user.txt,O_RDONLY)0)perror(open);
cmpmsg,sizeof(structmessage)name,cmpmsg.name)=0)&
(strcmp(recievemsg-msg,cmpmsg.msg)=0)close(fd);
while(read_size0);
/*voidmain()structmessagesendmsg;
printf(inputname:
n);
gets(sendmsg.name);
printf(inputmima:
gets(sendmsg.msg);
printf(%dn,reg_check(&
sendmsg);
/printf(%dn,login_check(&
*/*client.c*/#include#include#include#include#include#include#include#include#include#include#include#include#include#include#defineMAXLEN1024structmessagecharflag15;
structmsqlongmsg_type;
charmsg_text5;
intqid=-1,fd=-1,sockfd,savefilefd=-1;
charfilefromname10;
voidhandleQuit(intsignal_no)if(fd0)close(fd);
close(sockfd);
if(qid0)if(msgctl(qid,IPC_RMID,NULL)0)printf(消息队列无法关闭n);
exit
(1);
close(savefilefd);
printf(程序正常退出n);
raise(SIGQUIT);
voidcutStr(charstr,charleft,intn,charright,intm,charc)inti,k,j;
for(i=0;
in;
i+)if(stri=c)break;
if(i=n)i=-1;
elsememset(left,0,strlen(left);
for(k=0;
ki;
k+)leftk=strk;
for(j=i+1;
jm;
j+)if(strj=0)break;
rightj-i-1=strj;
lefti=0;
if(j0)printf(filedata.msg=%sn,filedata.msg);
send(sockfd,&
filedata,sizeof(structmessage),0);
elseprintf(读取文件失败,文件传输中止n);
break;
while(filedata.size0);
savefilefd=-1;
voidhandlerecvmsg(int*sockfd)intconnfd=*sockfd;
intnread;
charbuf1024;
charstr1024;
structmessagerecvmsg;
time_ttimep;
structmsqmsg;
if(fd=open(chatlog.txt,O_RDWR|O_CREAT|O_APPEND)0)printf(打开聊天记录文件失败!
);
/printf(%dn,fd);
if(qid=msgget(2222,IPC_CREAT|0666)=-1)printf(创建消息队列失败n);
msg.msg_type=getpid();
strcpy(msg.msg_text,OK);
while
(1)nread=recv(connfd,&
recvmsg,sizeof(structmessage),0);
if(nread=0)printf(与服务器断开了连接n);
close(connfd);
exit(0);
elseif(strcmp(recvmsg.flag,all)=0)time(&
timep);
sprintf(str,%s%s发给所有人:
%snn,ctime(&
timep),recvmsg.name,recvmsg.msg);
elseif(strcmp(recvmsg.flag,sermsg)=0)time(&
printf(%s服务器发给所有人:
timep),recvmsg.msg);
continue;
elseif(strcmp(recvmsg.flag,view)=0)time(&
printf(%s当前在线客户端:
n%snn,ctime(&
elseif(strcmp(recvmsg.flag,trans)=0)pthread_tpid;
if(strcmp(recvmsg.msg,agree)=0)strcpy(filefromname,recvmsg.name);
/创建线程发送文件pthread_create(&
pid,NULL,(void*)handlesendfile,NULL);
elseif(strcmp(recvmsg.msg,disagree)=0)printf(对方拒绝接收文件n);
elseif(strcmp(recvmsg.msg,noexist)=0)printf(该客户端不存在n);
elsestrcpy(filefromname,recvmsg.name);
printf(%s向你请求传名为%s文件,是否同意接受?
agree(同意)|disagree(不同意)n,recvmsg.name,recvmsg.msg);
savefilefd=0;
elseif(strcmp(recvmsg.flag,transf)=0)intn;
if(strcmp(recvmsg.msg,end$)=0)printf(文件传输结束n);
elsen=write(savefilefd,recvmsg.msg,recvmsg.size);
/printf(recvmsg.msg=%sn,recvmsg.msg);
while(n0)lseek(savefilefd,n,SEEK_CUR);
n=write(savefilefd,recvmsg.msg,recvmsg.size);
elsetime(&
sprintf(str,%s%s发来的私聊消息:
write(fd,str,strlen(str);
msgsnd(qid,&
msg,sizeof(structmsq),0);
intmain(intargc,char*argv)structsockaddr_inserver_addr;
intport;
intdo_number;
structmessagea;
charstrMAXLEN;
charbufMAXLEN;
pthread_tpid;
if(argc!
=3)printf(请输入服务器IP和端口n);
port=atoi(argv2);
if(sockfd=socket(AF_INET,SOCK_STREAM,0)=-1)printf(创建socket失败n);
signal(SIGINT,handleQuit);
printf(-n);
printf(|n);
printf(|inputanumbertowork|n);
printf(|t1.loginttt|n);
printf(|t2.registertt|n);
printf(|t3.exitttt|n);
scanf(%d,&
do_number);
gets(str);
while(do_number!
=1&
do_number!
=2&
=3)printf(你输入的不是上面的选项,请重新输入:
if(do_number=3)close(sockfd);
printf(程序已退出!
bzero(&
server_addr,sizeof(structsockaddr_in);
server_addr.sin_family=AF_INET;
server_addr.sin_addr.s_addr=inet_addr(argv1);
server_addr.sin_port=htons(port);
if(connect(sockfd,(structsockaddr*)&
server_addr,sizeof(structsockaddr)=-1)printf(与服务器无响应,请隔一段时间再连接n);
exit
(2);
if(do_number=1)intn=3;
while(n)printf(请输入你的用户名:
scanf(%s,a.name);
printf(请输入密码:
scanf(%s,a.msg);
strcpy(a.flag,login);
/a.flag3=0;
a,sizeof(a),0);
printf(正在等待服务器应答.n);
recv(sockfd,buf,MAXLEN,0);
printf(接到服务器发来的信息:
%sn,buf);
if(strcmp(buf,登录成功!
)=0)/inti,j,k;
pthread_create(&
pid,NULL,(void*)handlerecvmsg,(void*)&
sockfd);
strcpy(a.flag,all);
while
(1)memset(a.msg,0,strlen(a.msg);
memset(str,0,strlen(str);
strcpy(buf,a.flag);
cutStr(str,a.flag,15,a.msg,MAXLEN,$);
printf(标志信息为:
%sn,a.flag);
if(strcmp(a.flag,view)=0)send(sockfd,&
strcpy(a.flag,buf);
elseif(strcmp(a.flag,trans)=0)&
(savefilefd=0)/printf(f=%s,a=%s,s=%d,a.flag,a.msg,savefilefd);
if(strcmp(a.msg,agree)=0)&
(savefilefd=0)charsavefilename20;
/charsavefileallname22;
printf(请输入保存的文件名,文件将保存在当前目录下!
dogets(savefilename);
savefilefd=open(savefilename,O_RDWR|O_CREAT|O_EXCL,0666);
if(savefilefd=-1)printf(文件名可能存在请重新命名.n);
while(savefilefd=-1);
if(savefilefd0)printf(创建文件失败!
elsestrcpy(a.name,filefromname);
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- Linux 类似 QQ 聊天工具
![提示](https://static.bdocx.com/images/bang_tan.gif)