Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >Linux客户端网口输入转串口输出

Linux客户端网口输入转串口输出

作者头像
嘘、小点声
发布于 2020-03-19 06:43:57
发布于 2020-03-19 06:43:57
12.6K00
代码可运行
举报
文章被收录于专栏:嘘、小点声嘘、小点声
运行总次数:0
代码可运行

概要与环境

使用socket通信方式,建立连接,在服务端将获取到的数据调用串口发送即可

服务端为Linux,客户端为Linux或Windows

测试过程中请:使用iptables -F,免得让人感觉不好。

另外,在Linux下的C语言头文件一部分不可以在Windows系统上运行,可能导致一些不便。

socket通信

参阅:https://www.cnblogs.com/wuyepeng/p/9717236.html

要真正实现合适的通信,仍然需要加之修改。在本例测试过程中,发送端的输出数据在接收端会多出两个字节长度。相信是在发送端造成的。

C客户端的测试代码基本相同:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
 1 #include <sys/types.h>
 2 #include <sys/socket.h>
 3 #include <stdio.h>
 4 #include <netinet/in.h>
 5 #include <arpa/inet.h>
 6 #include <unistd.h>
 7 #include <string.h>
 8 #include <stdlib.h>
 9 #include <fcntl.h>
10 #include <sys/shm.h>
11  
12 #define MYPORT  8887
13 #define BUFFER_SIZE 1024
14  
15 int main()
16 {
17     ///定义sockfd
18     int sock_cli = socket(AF_INET,SOCK_STREAM, 0);
19  
20     ///定义sockaddr_in
21     struct sockaddr_in servaddr;
22     memset(&servaddr, 0, sizeof(servaddr));
23     servaddr.sin_family = AF_INET;
24     servaddr.sin_port = htons(MYPORT);  ///服务器端口
25     servaddr.sin_addr.s_addr = inet_addr("xxxxxx");  ///服务器ip
26  
27     ///连接服务器,成功返回0,错误返回-1
28     if (connect(sock_cli, (struct sockaddr *)&servaddr, sizeof(servaddr)) < 0)
29     {
30         perror("connect");
31         exit(1);
32     }
33  
34     char sendbuf[BUFFER_SIZE];
35     char recvbuf[BUFFER_SIZE];
36     while (fgets(sendbuf, sizeof(sendbuf), stdin) != NULL)
37     {
38 //    int len = strlen(sendbuf);
39 //    if(sendbuf[len-1] == '\r'){sendbuf[len--]=0;}
40     printf("send:%s",sendbuf);
41         send(sock_cli, sendbuf, strlen(sendbuf),0); ///发送
42         recv(sock_cli, recvbuf, strlen(recvbuf),0); ///接收
43         fputs(recvbuf, stdout);
44         memset(sendbuf, 0, sizeof(sendbuf));
45         memset(recvbuf, 0, sizeof(recvbuf));
46     }
47     close(sock_cli);
48     return 0;
49 }

C服务端的测试代码:该代码存在致命的缺陷未修正。运行以后,在客户一端敲入几次回车即可显示。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
 1 #include <sys/types.h>
 2 #include <sys/socket.h>
 3 #include <stdio.h>
 4 #include <netinet/in.h>
 5 #include <arpa/inet.h>
 6 #include <unistd.h>
 7 #include <string.h>
 8 #include <stdlib.h>
 9 #include <fcntl.h>
10 #include <sys/shm.h>
11 #include <asm/termios.h>
12 #define DEV_NAME  "/dev/pts/1"
13 #define MYPORT  8887
14 #define QUEUE   20
15 #define BUFFER_SIZE 1024
16 
17 int mainFunction()
18 {
19     int fd;//serial port
20     ///定义sockfd
21     int server_sockfd = socket(AF_INET,SOCK_STREAM, 0);
22 
23     ///定义sockaddr_in
24     struct sockaddr_in server_sockaddr;
25     server_sockaddr.sin_family = AF_INET;
26     server_sockaddr.sin_port = htons(MYPORT);
27     server_sockaddr.sin_addr.s_addr = htonl(INADDR_ANY);
28 
29     fd = open(DEV_NAME, O_RDWR | O_NOCTTY);
30     if(fd < 0) 
31     {
32             perror(DEV_NAME);
33             return -1;
34     }
35     printf("%d port is ready\n");
36     ///bind,成功返回0,出错返回-1
37     while(bind(server_sockfd,(struct sockaddr *)&server_sockaddr,sizeof(server_sockaddr))==-1)
38     {;
39     }
40 
41     ///listen,成功返回0,出错返回-1
42     if(listen(server_sockfd,QUEUE) == -1)
43     {
44         perror("listen error\n");
45         return;
46     }
47 
48     ///客户端套接字
49     char buffer[BUFFER_SIZE];
50     struct sockaddr_in client_addr;
51     socklen_t length = sizeof(client_addr);
52 
53     ///成功返回非负描述字,出错返回-1
54     int conn = accept(server_sockfd, (struct sockaddr*)&client_addr, &length);
55     if(conn<0)
56     {
57         perror("connect error\n");
58         return;
59     }
60 
61     while(1)
62     {
63         memset(buffer,0,sizeof(buffer));
64         int len = recv(conn, buffer, sizeof(buffer),0);
65         if(len<=0)
66         {
67             printf("maybe disconnected... restart:\n");
68             break;
69         }
70         fputs(buffer, stdout);
71         send(conn, strcat("send message success:",buffer), len, 0);
72     }
73     close(conn);
74     close(server_sockfd);
75 
76 }
77 void main()
78 {
79     while(1)
80     {
81         mainFunction();
82     }
83 }

python实现通信参阅:https://blog.csdn.net/su_bao/article/details/80380465

python实现的通信更加方便。阅读链接信息即可。该python的客户端程序,修改参数可以直接与C语言的socket服务端通信。通信过程中,接收端和发送的字节数相同。

该代码在python2中可能输入数据需要添加双引号,

串口控制

串口部分可以参阅:周立功【开发指南】M6G2C&A6G2C;系列核心板软件开发指南。

该指南中,在第16章,有详细的串口发送案例。其中也详细的书写了一些自定义参数的函数,可供使用。

以下是基本相同的示例代码:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
 1 #include <stdio.h>
 2 #include <stdlib.h>
 3 #include <unistd.h>
 4 #include <fcntl.h>
 5 #include <asm/termios.h>
 6 #define DEV_NAME  "/dev/pts/1"
 7 int main (int argc, char *argv[])
 8 {
 9     int fd;
10     int len, i,ret;
11     char buf[] = "hello ZLG!";
12 
13     fd = open(DEV_NAME, O_RDWR | O_NOCTTY);
14     if(fd < 0) {
15             perror(DEV_NAME);
16             return -1;
17     }
18     printf("%d",fd);
19     len = write(fd, buf, sizeof(buf));
20     if (len < 0) {
21         printf("write data error \n");
22     }
23     printf("%s", buf);
24     return(0);
25 }

另外需要测试的是串口控制,则需要使用虚拟串口。

这里可以采用他人python写的一个虚拟串口脚本,建立两个互通的串口?:https://blog.csdn.net/qq_42973043/article/details/82888075

这里可以做出一些删减后的代码,基本相同如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
 1 import pty
 2 import os
 3 import select
 4 
 5 def mkpty():
 6     #
 7     master1, slave = pty.openpty()
 8     slaveName1 = os.ttyname(slave)
 9     master2, slave = pty.openpty()
10     slaveName2 = os.ttyname(slave)
11     print '/nslave device names: ', slaveName1, slaveName2
12     return master1, master2
13 
14 if __name__ == "__main__":
15 
16     master1, master2 = mkpty()
17     while True:        
18         rl, wl, el = select.select([master1,master2], [], [], 1)
19         for master in rl:
20             data = os.read(master, 128)
21             if master==master1:
22                 print "master1 receive data: %d data:" % len(data)
23                 print data
24             else:
25                 print "master2 receive data: %d data:" % len(data)
26                 print data

测试方式相同。

综合

修正部分如下,该部分去掉了一些错误。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
1     while(bind(server_sockfd,(struct sockaddr *)&server_sockaddr,sizeof(server_sockaddr))==-1)
2     {
3         
4     ;
5     }

C语言服务端完整代码如下

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#include <sys/types.h>
#include <sys/socket.h>
#include <stdio.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <unistd.h>
#include <string.h>
#include <stdlib.h>
#include <fcntl.h>
#include <sys/shm.h>
#include <asm/termios.h>
#define DEV_NAME  "/dev/pts/1"
#define MYPORT  8887
#define QUEUE   20
#define BUFFER_SIZE 1024

int mainFunction()
{
    int fd;//serial port
    ///定义sockfd
    int server_sockfd = socket(AF_INET,SOCK_STREAM, 0);

    ///定义sockaddr_in
    struct sockaddr_in server_sockaddr;
    server_sockaddr.sin_family = AF_INET;
    server_sockaddr.sin_port = htons(MYPORT);
    server_sockaddr.sin_addr.s_addr = htonl(INADDR_ANY);

    fd = open(DEV_NAME, O_RDWR | O_NOCTTY);
	if(fd < 0) 
	{
			perror(DEV_NAME);
			return -1;
	}
    printf("port is ready\n");
    cfsetispeed(fd,115200);
    cfsetospeed(fd,115200);
    //bind,成功返回0,出错返回-1
    while(bind(server_sockfd,(struct sockaddr *)&server_sockaddr,sizeof(server_sockaddr))==-1)
    {
        
	;
    }
    ///listen,成功返回0,出错返回-1
    if(listen(server_sockfd,QUEUE) == -1)
    {
        perror("listen error\n");
	return;
    }
    ///客户端套接字
    char buffer[BUFFER_SIZE];
    struct sockaddr_in client_addr;
    socklen_t length = sizeof(client_addr);

    ///成功返回非负描述字,出错返回-1
    int conn = accept(server_sockfd, (struct sockaddr*)&client_addr, &length);
    if(conn<0)
    {
        perror("connect error\n");
	return;
    }

    while(1)
    {
        memset(buffer,0,sizeof(buffer));
        int len = recv(conn, buffer, sizeof(buffer),0);
	if(len<=0)
        {
            printf("maybe disconnected... restart:\n");
            break;
        }
//	if(buffer[0]=='\n')
//	{
//	    printf("end by user");
//	    break;
//	}
	len = write(fd, buffer,len);
	if (len < 0) {
		printf("write data error \n");
		break;
	}
        send(conn,buffer, len, 0);
    }
    close(conn);
    close(server_sockfd);

}
void main()
{
    while(1)
    {
        mainFunction();
    }
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-03-16 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
网口转串口
client.py from socket import * HOST = '192.168.1.14' # or 'localhost' PORT = 8887 BUFSIZ =1024 ADDR = (HOST,PORT) tcpCliSock = socket(AF_INET,SOCK_STREAM) tcpCliSock.connect(ADDR) while True: data1 = input('>') #data = str(data) if not dat
嘘、小点声
2021/09/26
1.8K0
eBCC性能分析最佳实践(2) - 一个简单的eBCC分析网络函数的latency
http://koji.aliyun-inc.com/kojifiles/packages/ebcc/1.0.0/3.1.al7/src/ebcc-1.0.0-3.1.al7.src.rpm 祝大家五一快乐!
Linux阅码场
2019/06/04
7870
linux下socket编程实例_C语言窗口编程
TCP/IP(Transmission Control Protocol/Internet Protocol)即传输控制协议/网间协议,是一个工业标准的协议集,它是为广域网(WANs)设计的。  
全栈程序员站长
2022/11/10
5.4K0
linux下socket编程实例_C语言窗口编程
实现基于TCP的服务端/客户端
客户端调用connect函数后服务端接收连接请求(记录到等待队列)或发生断网等异常情况而中断连接请求才会返回(完成函数调用)。客户端的IP地址和端口号在调用connect函数时由内核自动分配,无需调用标记的bind函数进行分配。
玖柒的小窝
2021/12/15
1.2K0
实现基于TCP的服务端/客户端
基于Socket和OpenCV的实时视频传输(On Linux)「建议收藏」
上一篇介绍了在Windows上实现基于Socket和openCV的实时视频传输,这一篇将继续讲解在Linux上的实现。
全栈程序员站长
2022/07/30
1.3K0
基于udp的socket编程 c语言_C语言编程游戏
UDP协议的程序设计框架,客户端和服务器之间的差别在于服务器必须使用bind()函数来绑定侦听的本地UDP端口,而客户端则可以不进行绑定,直接发送到服务器地址的某个端口地址。框图如图1.3所示
全栈程序员站长
2022/10/04
18.5K0
基于udp的socket编程 c语言_C语言编程游戏
linux下的UDP广播通讯,客户端和服务器实现
我的博客即将同步至腾讯云开发者社区,邀请大家一同入驻:https://cloud.tencent.com/developer/support-plan?invite_code=33nqakp1y9es
呱牛笔记
2023/05/02
4K0
linux下的UDP广播通讯,客户端和服务器实现
[置顶] linux网络编程之socket(十四):基于UDP协议的网络程序
一、下图是典型的UDP客户端/服务器通讯过程 下面依照通信流程,我们来实现一个UDP回射客户/服务器   #include <sys/types.h>  #include <sys/socket.h
s1mba
2017/12/28
1.8K0
[置顶]
        linux网络编程之socket(十四):基于UDP协议的网络程序
服务端向客户端传输文件
本篇为:客户端向服务端请求文件传输,服务端根客户端需求发送文本文件(就是能用写字板打开成我们能看懂的文件,可能有些我没测到)
看、未来
2020/08/26
1.9K0
Socket编程实践(2) Socket API 与 简单例程
在本篇文章中,先介绍一下Socket编程的一些API,然后利用这些API实现一个客户端-服务器模型的一个简单通信例程。该例子中,服务器接收到客户端的信息后,将信息重新发送给客户端。 socket()函数 socket()函数用于创建一个套接字。这就好像购买了一个电话。不过该电话还没有分配号码。 #include <sys/types.h> #include <sys/socket.h> int socket(int domain, int type, int protocol
Tencent JCoder
2018/07/02
8530
socket编程小问题:地址已经被使用——Address already in use
很多socket编程的初学者可能会遇到这样的问题:如果先ctrl+c结束服务器端程序的话,再次启动服务器就会出现Address already in use这个错误,或者你的程序在正常关闭服务器端socket后还是有这个问题。正如下面的这段简单的socket程序。 server.c #include <sys/types.h> #include <sys/socket.h> #include <stdio.h> #include <netinet/in.h> #include <arpa/i
李海彬
2018/03/23
3.5K1
socket编程小问题:地址已经被使用——Address already in use
linux网络编程之socket(九):使用select函数改进客户端/服务器端程序
一、当我们使用单进程单连接且使用readline修改后的客户端程序,去连接使用readline修改后的服务器端程序,会出现一个有趣的现象,先来看输出: 先运行服务器端,再运行客户端, simba@ub
s1mba
2017/12/28
3.8K0
linux网络编程之socket(九):使用select函数改进客户端/服务器端程序
Linux网络编程TCP
TCP/IP 协议栈是一系列网络协议(protocol)的总和,是构成网络通信的核心骨架,它定义了电子设备如何连入因特网,以及数据如何在它们之间进行传输。
DeROy
2021/11/16
5.5K0
Linux网络编程TCP
linux网络编程之socket(三):最简单的回射客户/服务器程序、time_wait 状态
s1mba
2017/12/28
1.5K0
linux网络编程之socket(三):最简单的回射客户/服务器程序、time_wait 状态
DragonOS网络子系统介绍
本文将对DragonOS网络子系统进行简要介绍。出于“快速实现功能”的考虑,DragonOS目前网络子系统基于Smoltcp协议栈进行开发,具体协议部分采用smoltcp的实现。计划在将来重构网络子系统时,采用独立开发的协议栈,以支持“服务器系统”的需求。
灯珑LoGin
2023/10/18
4680
DragonOS网络子系统介绍
Linux上C语言写的简易telnet客户端
telnet.c #include <stdio.h> #include <stdlib.h> #include <sys/socket.h> #include <arpa/inet.h> #include <netinet/in.h> #include <netdb.h> #include <unistd.h> #include <errno.h> #include <signal.h> #include <time.h> #include <stdarg.h> #define ERR_EXIT(
drunkdream
2018/07/06
5.9K0
Linux Tcp通信——服务器与客户端
之前一直想做linux+qt方向的,然而现在变成嵌入式软件方向了。其实也还好吧,这样就需要对底层的一些东西了解,目前是智能交通行业了。
用户5908113
2020/05/28
7K0
【c++】测试用例:C/S模型、epoll模型
已经好几次去网上找现成的改一下用了,那我还不如自己备一份儿。 文章目录 Server Client epoll Server #include <stdio.h> #include <string.h> #include <stdlib.h> #include <unistd.h> #include <arpa/inet.h> #include <sys/socket.h> #include <netinet/in.h> int main()
看、未来
2022/01/10
5170
linux网络编程之socket(七):一个进程发起多个连接和gethostbyname等函数
s1mba
2017/12/28
1.7K0
linux网络编程之socket(七):一个进程发起多个连接和gethostbyname等函数
Linux下Socket编程入门
网络字节序是TCP/IP中规定好的一种数据表示格式,它与具体的CPU类型、操作系统等无关,从而可以保证数据在不同主机之间传输时能够被正确解释。网络字节序采用big endian排序方式。
_咯噔_
2022/02/23
3.6K0
推荐阅读
相关推荐
网口转串口
更多 >
领券
社区富文本编辑器全新改版!诚邀体验~
全新交互,全新视觉,新增快捷键、悬浮工具栏、高亮块等功能并同时优化现有功能,全面提升创作效率和体验
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验