简单实例分享-编程实例-socket-linux-Linux下Socket编程 (简单实例分享)

教程大全 2025-07-12 02:36:29 浏览

socket编程是一种在计算机网络中进行通信的基础方式,它被广泛运用于网络应用程序的设计中。在Linux环境中,Socket编程是一种基本的网络编程方式,可以实现客户端与 服务器 之间的数据传输与通信。在本文中,我们将介绍Linux下的Socket编程,并分享一些简单的实例供读者参考。

一、Socket编程基础知识

1.1 Socket定义

Socket是一种通信方式,它是一种计算机网络数据传输协议的API。Socket是一组用于接收和发送数据的API,它可以在计算机网络上建立连接,进行网络通信。Socket是一种抽象层,它实际上是一个文件描述符,可以用于数据的输入和输出。

1.2 Socket类型

在Socket编程中,有两种主要的Socket类型:

– 流Socket(SOCK_STREAM):用于建立面向连接的TCP连接,数据传输具有可靠性和顺序性;

– 数据报Socket(SOCK_DGRAM):用于无连接的UDP通信,数据传输速度快但不可靠,消息之间没有顺序。

1.3 Socket编程基本流程

在使用Socket编程进行数据通信时,需要进行如下的基本流程:

– 服务器端创建Socket、绑定IP与端口、监听客户端连接;

– 客户端创建Socket、连接服务器;

– 服务器端接受客户端连接请求,生成新的Socket与客户端通信;

– 客户端和服务器端进行数据传输。

二、Linux下Socket编程实践

为了更好地理解Socket编程,下面我们介绍一个简单的实例,该实例演示了如何实现基本的客户端和服务器端之间的消息传输。

2.1 服务器端代码

下面是基本的服务器端代码:

#define PORT 8000

#define MAX_CONN 10

int mn(int argc, char *argv[])

int server_fd, client_fd, len;

struct sockaddr_in server_addr, client_addr;

char buffer[1024];

// 创建Socket

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

perror(“Cannot create socket”);

// 绑定端口

memset(&server_addr, 0, sizeof(server_addr));

server_addr.sin_family = AF_INET;

server_addr.sin_port = htons(PORT);

server_addr.sin_addr.s_addr = htonl(INADDR_ANY);

if (bind(server_fd, (struct sockaddr *)&server_addr, sizeof(server_addr)) == -1) {

perror(“Bind error”);

// 监听

if (listen(server_fd, MAX_CONN) == -1) {

perror(“Listen error”);

printf(“Server listening on port %d…\n”, PORT);

// 循环接受连接请求

len = sizeof(client_addr);

if ((client_fd = accept(server_fd, (struct sockaddr *)&client_addr, &len)) == -1) {

perror(“Accept error”);

printf(“Connection established from client %s:%d\n”,

inet_ntoa(client_addr.sin_addr), ntohs(client_addr.sin_port));

// 与客户端进行通信

memset(buffer, 0, sizeof(buffer));

if (recv(client_fd, buffer, sizeof(buffer), 0)

perror(“Recv error”);

printf(“Received message from client %s:%d: %s\n”,

inet_ntoa(client_addr.sin_addr), ntohs(client_addr.sin_port), buffer);

if (strncmp(buffer, “exit”, 4) == 0)

if (send(client_fd, buffer, strlen(buffer), 0) == -1) {

perror(“Send error”);

close(client_fd);

printf(“Connection closed from client %s:%d\n”,

inet_ntoa(client_addr.sin_addr), ntohs(client_addr.sin_port));

close(server_fd);

在该代码中,我们首先创建了一个Socket,并绑定了IP地址和端口号。然后,我们开始监听客户端的连接请求。当有一个连接请求到来时,我们将生成一个新的Socket,并通过这个Socket与客户端进行通信。在与客户端进行通信时,我们可以通过recv()函数从客户端接收消息,也可以通过send()函数向客户端发送消息。

2.2 客户端代码

下面是基本的客户端代码:

#define PORT 8000

int mn(int argc, char *argv[])

int client_fd, len;

struct sockaddr_in server_addr;

char buffer[1024];

// 创建Socket

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

perror(“Cannot create socket”);

// 连接服务器

memset(&server_addr, 0, sizeof(server_addr));

server_addr.sin_family = AF_INET;

server_addr.sin_port = htons(PORT);

server_addr.sin_addr.s_addr = inet_addr(argv[1]);

if (connect(client_fd, (struct sockaddr *)&server_addr, sizeof(server_addr)) == -1) {

perror(“Connect error”);

printf(“Connect to server %s:%d successfully.\n”, argv[1], PORT);

// 与服务器进行通信

printf(“Input message: “);

fgets(buffer, sizeof(buffer), stdin);

if (send(client_fd, buffer, strlen(buffer), 0) == -1) {

perror(“Send error”);

if (strncmp(buffer, “exit”, 4) == 0)

memset(buffer, 0, sizeof(buffer));

if (recv(client_fd, buffer, sizeof(buffer), 0)

perror(“Recv error”);

printf(“Received message from server: %s”, buffer);

close(client_fd);

在该代码中,我们首先创建了一个Socket,并使用该Socket连接了服务器。在与服务器进行通信时,我们使用fgets()函数从标准输入读取用户的消息,并使用send()函数向服务器发送消息。同时,在接收服务器的回复时,我们通过recv()函数进行接收。

三、

相关问题拓展阅读:

linux下的 socket编程问题!

1你就打开文件,然后一个字符一竖伍个字符的读文件,然后一个字符一个字符的接收,再一个字符一个迅纤凳字符写入文件就行了阿

2这个问题你问的有点模亩旅糊,服务器端的编程有很多方式,也不是要每来个连接就要创建一个进程的。

之一数桐个问题:

对,是那样的,用open打开文件,用read读取文件,在发送给对方,接收方接收到薯码坦后,写入文件就可以了。不过在这个过程中更好别用字符串函数,除非你很熟悉。

第二个问题

首先你得去搞清楚什么是线程,什么是进程,fork出来的叫进程,pthread_create出来的才叫线程。服务器有很多种模型(多进程,多线程,select,epoll模型,这个我的bLog上有,famdestiny.cublog.cn),不一定要用多进程。

给你写了个代码,自己先看看:

注意,在自己的目录下创建模知一个叫pserverb的文件,程序会把这个文件复制成test文件。你可以自己根据需要改改

#define SERV_PORT 5358

#define MAX_CONN 10

#define BUF_LEN 1024

void str_echo(FILE *fp, int sockfd){

ssize_t nread;

int file_fd;

char buf = {0};

file_fd = open(“test”, O_WRON | O_TrunC | O_CREAT, 0755);

bzero(buf, BUF_LEN);

if((nread = read(sockfd, buf, BUF_LEN)) == -1) {

if(errno == EINTR) {

printf(“readn error: %s\n”, strerror(errno));

else if (nread == 0) {

printf(“%s\n”, buf);

write(file_fd, buf, nread);

close(file_fd);

void sig_chld(int sig){

while((pid = waitpid(-1, &state, WNOHANG)) > 0){

printf(“child process %d exited.”, pid);

int main(int argc, char **argv)

int listenfd, connfd;

socklen_t cliaddrlen;

pid_t childpid;

struct sockaddr_in servaddr, cliaddr;

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

printf(“socket error: %s\n”, strerror(errno));

bzero(&servaddr, sizeof(servaddr));

servaddr.sin_family = AF_INET;

servaddr.sin_addr.s_addr = htonl(INADDR_ANY);

servaddr.sin_port = htons(SERV_PORT);

if(bind(listenfd, (struct sockaddr *)&servaddr, sizeof(servaddr)) == -1){

printf(“bind error: %s\n”, strerror(errno));

if(listen(listenfd, MAX_CONN) == -1){

printf(“listen error: %s\n”, strerror(errno));

signal(SIGCHLD, sig_chld);

cliaddrlen = sizeof(cliaddr);

if((connfd = accept(listenfd, (struct sockaddr *)&cliaddr, &cliaddrlen)) == -1){

if(errno == EINTR){

printf(“accept error: %s\n”, strerror(errno));

if((childpid = fork()) == 0){

close(listenfd);

str_echo(stdin, connfd);

else if(childpid > 0){

close(connfd);

printf(“fork error!\n”);

#define SERV_ADDR “127.0.0.1”

#define SERV_PORT 5358

#define BUF_LEN 1024

void str_cli(char *path, int sockfd)

char sendbuf = {0};

if((fd = open(“./pserverb”, O_RDON)) == -1){

printf(“%s\n”, strerror(errno));

while((n = read(fd, sendbuf, BUF_LEN)) != 0) {

printf(“%s\n”, strerror(errno));

write(sockfd, sendbuf, n);

bzero(sendbuf, BUF_LEN);

close(fd);

Linux下Socket编程

int main(int argc, char **argv)

struct sockaddr_in servaddr;

fd = socket(AF_INET, SOCK_STREAM, 0);

bzero(&servaddr, sizeof(servaddr));

servaddr.sin_family = AF_INET;

servaddr.sin_addr.s_addr = inet_addr(SERV_ADDR);

servaddr.sin_port = htons(SERV_PORT);

if (connect(fd, (struct sockaddr *)&servaddr, sizeof(servaddr)) == -1) {

printf(“connect error: %s\n”, strerror(errno));

str_cli(argv, fd);

挖~

关于linux socket 编程实例的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。

香港服务器首选树叶云,2H2G首月10元开通。树叶云(shuyeidc.com)提供简单好用,价格厚道的香港/美国云服务器和独立服务器。IDC+ISP+ICP资质。ARIN和APNIC会员。成熟技术团队15年行业经验。


socket套接字,如何发送一个结构体?

流式套接字的编程步骤在使用之前须链接库函数:工程->设置->Link->输入ws2_,OK!SOCKET sockSrv=socket(AF_INET,SOCK_STREAM,0);//创建套接字(socket)。 SOCKADDR_IN addrSrv;_addr.S_un.S_addr=htonl(INADDR_ANY);//转换Unsigned short为网络字节序的格式_family=AF_INET;_port=htons(6000);客户端代码如下:#include #include void main(){WORD wVersionRequested;WSADATA wsaData;int err;wVersionRequested = MAKEWORD( 1, 1 );err = WSAStartup( wVersionRequested, &wsaData );加载套接字库if ( err != 0 ) {return;}if ( LOBYTE( ) != 1 ||HIBYTE( ) != 1 ) {WSACleanup()( );return; }SOCKET sockClient=socket(AF_INET,SOCK_STREAM,0);创建套接字(socket)。 SOCKADDR_IN addrSrv;_addr.S_un.S_addr=inet_addr(127.0.0.1);_family=AF_INET;_port=htons(6000);connect(sockClient,(SOCKADDR*)&addrSrv,sizeof(SOCKADDR));向服务器发出连接请求(connect)。

linux编程 编写一个函数

看看这个是不是可以:#!/bin/kshwhile :doecho enter your input: (q to quit) \cread user_inputif [ $user_input == q ]thenexit 0fiecho $user_input | awk {printf(Oct: %o\nDec: %d\nHex: %x\n,$1,$1,$1);}done

多播编程用socket如何实现?

创建一个Socket_DGRAM类型的SOCKET将此Socket绑定到本地的一个端口上,为接收服务器端发送的多播数据。加入多播组发送多播数据接收多播数据

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

发表评论

热门推荐