linux-socket通信示例(传送文件)

本文提供了一组基于TCP协议的简单文件传输示例代码,包括服务器端和客户端实现。通过这些示例,读者可以了解如何使用socket编程进行基本的文件传输操作。
服务器端代码:
#include "creatSocket.h"
#include <string.h>
#include <stdio.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <netdb.h>
#include <fcntl.h>
#include <sys/stat.h>
#include <errno.h>
//#include "error.h"

#define BUFFSIZE 20
extern int errno;
main()
{
  int temp_sock;
  int ssock;
  char buff[BUFFSIZE+1];
 
  struct sockaddr_in pin;
  int size_pin = sizeof(pin);
  int count_receive ;       /* count the receive world */
  int fd;                   /* mark the file */
  int count;                /* count the number of reading */
  
  ssock = passiveTCP("8000",5);
  while(1)
  {
    printf("listen.../n");
    temp_sock = accept(ssock,(struct sockaddr *)&pin,&size_pin);
    count_receive = read(temp_sock,buff,BUFFSIZE);
    printf("has receive message:%s/n",buff);
    
    fd = open(buff,O_RDWR);
    if(fd < 0)
       errexit("can't open the file:%s/n",strerror(errno));
    while(count = read(fd,buff,BUFFSIZE))
    {
          buff[count] = '/0';
          printf("%s",buff);
          write(temp_sock,buff,count);
    }
    close(temp_sock);
    printf("the connect has closed!/n");
  }
}
客户端代码:
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <errno.h>
#include "error.h"
#include <netdb.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <string.h>
extern int errno;
#define BUFFSIZE 20

void menu();
void TCPclient();
void UDPclient();

main()
{
  int c_choose;
  while(1)
  {
    menu();
    scanf("%d",&c_choose);
    switch(c_choose)
    {
      case 1:TCPclient();break;
      case 2:UDPclient();break;
      default:exit(0);
    }
  }
}

void menu()
{
  printf("Please choose the client:/n");
  printf("1.TCPclient/n");
  printf("2.UDPclient/n");
  printf("3.exit/n");
  printf("please input you choose:");
} 

void UDPclient()
{}

void TCPclient()
{
  char filename[20];
  char buff[BUFFSIZE+1];
  int count;
  int port = 8000;
  struct sockaddr_in sin;
  sin.sin_family = AF_INET;
  sin.sin_addr.s_addr = INADDR_ANY;
  sin.sin_port = htons(port);
  
  int csock = socket(AF_INET,SOCK_STREAM,0);
  if(connect(csock,(void *)&sin,sizeof(sin)))
    errexit("has't connect to the server !:%s/n",strerror(errno));
  else
    printf("has connect to the server!/n");
  
  printf("please input the file name:");
  scanf("%s",buff);
  
  write(csock,buff,sizeof(buff));
  printf("the text content is :/n");
  int i =0 ;
  
  strcpy(filename,buff);
  int fd = creat(filename,O_WRONLY|O_CREAT);
  while(count = read(csock,buff,BUFFSIZE))
  {
    if(count < 0)
      exit(0);
    printf("%d,%d/n",i++,count);
    buff[count] = '/0';
    write(fd,buff,count);
    printf("%s",buff);
    memset(buff,0,sizeof(buff));
  }
  close(fd);
  printf("the file %s has receive!/n",filename);  
}
创建服务器端socket通用头文件:
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <stdlib.h>
#include <string.h>
#include <netdb.h>
#include <errno.h>
#include "error.h"

extern int errno;

unsigned short portbase = 0;

int passivesock(const char *service,const char *transport,int qlen)
{
  struct servent *pse;      //pointer to service information entry
  struct protoent *ppe;     //pointer to protocol information entry
  struct sockaddr_in sin;   //an Internet endpoint address
  int s,type;               //socket descriptor and socket type

  memset(&sin,0,sizeof(sin));
  sin.sin_family = AF_INET;
  sin.sin_addr.s_addr = INADDR_ANY;

  //Map service name to port number 
  if( pse = getservbyname(service,transport))
    sin.sin_port = htons(ntohs((unsigned short)pse->s_port)+portbase);
  else if((sin.sin_port = htons((unsigned short)atoi(service))) == 0)
    errexit("can't get /"%s/"service entry/n",service);

  //Map protocol name to protocol number
  if((ppe = getprotobyname(transport)) == 0)
    errexit("can't get/"%s/"protocol entry/n",transport);
  
  //Use protocol to choose a socket type
  if(strcmp(transport,"udp") == 0)
    type = SOCK_DGRAM;
  else
    type = SOCK_STREAM;

  //Allocate a socket
  s = socket(PF_INET,type,ppe->p_proto);
  if(s <0 )
    errexit("can't create socket :%s/n",strerror(errno));
  
  //Bind the socket
  if(bind(s,(struct sockaddr*)&sin,sizeof(sin)) < 0)
    errexit("can't bind to %s port:%s/n",service,strerror(errno));
  if(type == SOCK_STREAM && listen(s,qlen) < 0 )
    errexit("can't listen on %s port:%s/n",service,strerror(errno));
  
  return s;
}

int passiveUDP(const char*service)
{
  return passivesock(service,"udp",0);
}

int passiveTCP(const char *service,int qlen)
{
  return passivesock(service,"tcp",qlen);
}
错误处理头文件:
#include <stdio.h>
#include <stdlib.h>
#include <stdarg.h>

int errexit(const char * format,...)
{
  va_list args;
  va_start(args,format);
  vfprintf(stderr,format,args);
  va_end(args);
  exit(1);
} 

内容概要:本文系统阐述了企业新闻发稿在生成式引擎优化(GEO)时代下的全渠道策略与效果评估体系,涵盖当前企业传播面临的预算、资源、内容与效果评估四大挑战,并深入分析2025年新闻发稿行业五大趋势,包括AI驱动的智能化转型、精准化传播、首发内容价值提升、内容资产化及数据可视化。文章重点解析央媒、地方官媒、综合门户和自媒体四类媒体资源的特性、传播优势与发稿策略,提出基于内容适配性、时间节奏、话题设计的策略制定方法,并构建涵盖品牌价值、销售转化与GEO优化的多维评估框架。此外,结合“传声港”工具实操指南,提供AI智能投放、效果监测、自媒体管理与舆情应对的全流程解决方案,并针对科技、消费、B2B、区域品牌四大行业推出定制化发稿方案。; 适合人群:企业市场/公关负责人、品牌传播管理者、数字营销从业者及中小企业决策者,具备一定媒体传播经验并希望提升发稿效率与ROI的专业人士。; 使用场景及目标:①制定科学的新闻发稿策略,实现从“流量思维”向“价值思维”转型;②构建央媒定调、门户扩散、自媒体互动的立体化传播矩阵;③利用AI工具实现精准投放与GEO优化,提升品牌在AI搜索中的权威性与可见性;④通过数据驱动评估体系量化品牌影响力与销售转化效果。; 阅读建议:建议结合文中提供的实操清单、案例分析与工具指南进行系统学习,重点关注媒体适配性策略与GEO评估指标,在实际发稿中分阶段试点“AI+全渠道”组合策略,并定期复盘优化,以实现品牌传播的长期复利效应。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值