linux即时聊天源码,最简单的Linux命令行Socket聊天程序源代码

linux即时聊天源码,最简单的Linux命令行Socket聊天程序源代码只有今天贴出代码,明天看才知道自己有多么傻。单线程,一对一聊天,混搭风格编程,函数乱入不解释……/**ChatonLinuxTerminal–alpha*WortebyJimmy’steam@uestc*2011-2-23**Thisisthesorcecodeofclient*SomeBUGSstillunsloved,butwearetryin…

大家好,又见面了,我是你们的朋友全栈君。

只有今天贴出代码,明天看才知道自己有多么傻。

单线程,一对一聊天,混搭风格编程,函数乱入不解释……

/*

* Chat on Linux Terminal–alpha

* Worte by Jimmy’s team@uestc

* 2011-2-23

*

* This is the sorce code of client

* Some BUGS still unsloved, but we are trying our best to debug

* Be sure that your system’s port “1234” is not busy!

*

* */

#include

#include

#include

#include

#include

#include

#include

#include

#include

#define SERVPORT 1234

#define MAX_DATA_SIZE 1024

int main(int argc, char *argv[]) {

int sockfd, sendBytes,recvBytes;

char sendBuf[MAX_DATA_SIZE],recvBuf[MAX_DATA_SIZE];

struct hostent *host;

struct sockaddr_in servAddr;

if(argc != 2) {

fprintf(stderr,”usage:./client [hostname]”);

exit(1);

}

/*translate the address*/

if((host = gethostbyname(argv[1])) == NULL) {

perror(“fail to get host by name”);

exit(1);

}

printf(“Success to get host by name…\n”);

/*establish a socket*/

if((sockfd = socket(AF_INET, SOCK_STREAM, 0)) == -1) {

perror(“fail to establish a socket”);

exit(1);

}

printf(“Success to establish a socket…\n”);

/*init sockaddr_in*/

servAddr.sin_family = AF_INET;

servAddr.sin_port = htons(SERVPORT);

servAddr.sin_addr = *((struct in_addr *)host -> h_addr);

bzero(&(servAddr.sin_zero), 8);

/*connect the socket*/

if(connect(sockfd, (struct sockaddr *)&servAddr, sizeof(struct sockaddr_in)) == -1) {

perror(“fail to connect the socket”);

exit(1);

}

printf(“Success to connect the socket…\n”);

printf(“\033[40;32mWelcome to join %s!\033[1m\n”, inet_ntoa(servAddr.sin_addr));//include color set

while(1) {

/*send datas to server*/

printf(“Client:”);

gets(sendBuf);

if((sendBytes = send(sockfd, sendBuf, strlen(sendBuf), 0)) != strlen(sendBuf)) {

perror(“fail to send datas”);

exit(1);

}

printf(“(Success to send data!)\n”);

memset(sendBuf, 0x00, MAX_DATA_SIZE);

/*receive datas from server*/

if((recvBytes = recv(sockfd, recvBuf, MAX_DATA_SIZE, 0)) == -1) {

perror(“fail to receive datas”);

exit(1);

}

printf(“Server: %s \n”, recvBuf);

memset(recvBuf, 0x00, MAX_DATA_SIZE);

}

close(sockfd);

}

/*

* Chat on Linux Terminal–alpha

* Worte by Jimmy’s team@uestc

* 2011-2-23

*

* This is the sorce code of server

* Some BUGS still unsloved, but we are trying our best to debug

* Be sure that your system’s port “1234” is not busy!

*

* */

#include

#include

#include

#include

#include

#include

#include

#include

#include

#include

#include

#include

#include

#include

#define SERVPORT 1234

#define BACKLOG 20

#define MAX_CON_NO 10

#define MAX_DATA_SIZE 1024

int main(int argc, char *argv[]) {

struct sockaddr_in serverSockaddr, clientSockaddr;

int sinSize, recvBytes, sendBytes;

fd_set readfd;

fd_set writefd;

int sockfd, clientfd;

char sendBuf[MAX_DATA_SIZE], recvBuf[MAX_DATA_SIZE];

if(argc != 1) {

printf(“usage:./server\n”);

exit(1);

}

/*establish a socket*/

if((sockfd = socket(AF_INET, SOCK_STREAM, 0)) == -1) {

perror(“fail to establish a socket”);

exit(1);

}

printf(“Success to establish a socket…(sockfd = %d)\n”, sockfd);

/*init sockaddr_in*/

serverSockaddr.sin_family = AF_INET;

serverSockaddr.sin_port = htons(SERVPORT);

serverSockaddr.sin_addr.s_addr = htonl(INADDR_ANY);

bzero(&(serverSockaddr.sin_zero), 8);

int on = 1;

setsockopt(sockfd, SOL_SOCKET, SO_REUSEADDR, &on, sizeof(on));

/*bind socket*/

if(bind(sockfd, (struct sockaddr *)&serverSockaddr, sizeof(struct sockaddr))== -1) {

perror(“fail to bind”);

exit(1);

}

printf(“Success to bind the socket…\n”);

/*listen on the socket*/

if(listen(sockfd, BACKLOG) == -1) {

perror(“fail to listen”);

exit(1);

}

printf(“Success to listen on the socket…\n”);

while(1) {

FD_ZERO(&readfd);

FD_SET(sockfd, &readfd);

sinSize = sizeof(struct sockaddr_in);

if(select(MAX_CON_NO, &readfd, NULL, NULL, (struct timeval *)0) > 0) {

if(FD_ISSET(sockfd, &readfd) > 0) {

/*accept a client’s request*/

if((clientfd = accept(sockfd, (struct sockaddr *)&clientSockaddr, &sinSize)) == -1) {

perror(“fail to accept”);

exit(1);

}

printf(“Success to accpet a connection request…\n”);

printf(“\033[40;32m%s join in!\033[1m\n”, inet_ntoa(clientSockaddr.sin_addr));//include color set

while(1) {

/*receive datas from client*/

if((recvBytes = recv(clientfd, recvBuf, MAX_DATA_SIZE, 0)) == -1) {

perror(“fail to receive datas”);

exit(1);

}

printf(“Client:%s\n”, recvBuf);

memset(recvBuf, 0x00, MAX_DATA_SIZE);

/*send datas to client*/

printf(“Server:”);

gets(sendBuf);

if((sendBytes = send(clientfd, sendBuf, strlen(sendBuf), 0)) != strlen(sendBuf)) {

perror(“fail to send datas”);

exit(1);

}

printf(“(Success to send data!)\n”);

memset(sendBuf, 0x00, MAX_DATA_SIZE);

}

}

close(sockfd);

}

}

}

运行方法:

jimmy@MyPet:~$ gcc -o client client.c

jimmy@MyPet:~$ gcc -o server server.c

jimmy@MyPet:~$ ./server

Success to establish a socket…(sockfd = 3)

Success to bind the socket…

Success to listen on the socket…

jimmy@MyPet:~$ ./client MyPet

Success to get host by name…

Success to establish a socket…

Success to connect the socket…

Welcome to join 127.0.1.1!

Client:

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/146382.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • php addslashes函数已经没用了_JAVA substring

    php addslashes函数已经没用了_JAVA substringPHP为了安全性,所以引入了个magic_quotes_gpc=On的功能,可以不需要做任何处理就能直接把单引号插入数据库中,那么对于Off时,则需要考虑单引号的问题了,而不是一味地信任运行环境。当magic_quotes_gpc=On时,使用了addslashes()处理后的数据在数据库中将以\’形式保存,如果此时直接输出的话,就会发现比自己期待的内容多了个\,因此stripslashe…

    2022年9月25日
    4
  • 二分图匹配相关算法

    二分图匹配相关算法二分图匈牙利算法二分图匈牙利算法二分图匈牙利算法这里简单记录下二分图匹配的相关算法 供自己使用 如果各位游客看到觉得浪费时间 便请移步 文章全为个人模板记录匈牙利算法匈牙利算法研究的是二分图的最大匹配 是对给定的二分图求得最大的满足条件的匹配数 匹配对 其算法思想是利用 Berge 定理和 Hall 定理将初始匹配通过迭代寻找增广路径得到最大匹配 每次迭代得到的匹配大小加 1 具体迭代实现有 DFS

    2025年12月15日
    5
  • Spring batch批量处理框架最佳实践

    Spring batch批量处理框架最佳实践springbatch精选,一文吃透springbatch批量处理框架前言碎语批处理是企业级业务系统不可或缺的一部分,springbatch是一个轻量级的综合性批处理框架,可用于开发企业信息系统中那些至关重要的数据批量处理业务.SpringBatch基于POJO和Spring框架,相当容易上手使用,让开发者很容易地访问和利用企业级服务.springbatch具有高可扩展性的框架…

    2022年5月23日
    36
  • windows 执行 bat命令问题

    windows 执行 bat命令问题window环境下,通过DOS命令模式,调用bat脚本,执行jar包。可以正常打印jar包中的日志都指定日志文件。通过tomcat部署的某服务去调用时出现不可调用,也不打印日志问题。分两步来确定问题:1、参数是否传递给bat脚本;2、bat脚本中的java-jar是否正常执行了;问题1通过,在bat脚本入口处增加echoname:%1age:%2>&g…

    2025年7月23日
    3
  • js获取当前日期与时间_js获取只有年月日的日期

    js获取当前日期与时间_js获取只有年月日的日期vardate=newDate();date.getYear();//获取当前年份(2位)date.getFullYear();//获取完整的年份(4位)date.getMonth();//获取当前月份(0-11,0代表1月)date.getDate();//获取当前日(1-31)date.getDay();//获取当前星期X(0-6,0代表星期天)date.getTime();//获取当前时间(从1970.1.1开始的毫秒数)date.getH

    2022年9月23日
    5
  • 计算机负数补码_负数用补码表示如何理解

    计算机负数补码_负数用补码表示如何理解在计算机系统中,数值一律用补码来表示(存储)。主要原因:使用补码,可以将符号位和其它位统一处理;同时,减法也可按加法来处理。另外,两个用补码表示的数相加时,如果最高位(符号位)有进位,则进位被舍弃。2、补码与原码的转换过程几乎是相同的。数值的补码表示也分两种情况:(1)正数的补码:与原码相同。例如,+9的补码是00001001。(2)负数的补码:符号位为1

    2025年6月13日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号