加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

C++、python和go语言实现的简单客户端服务器代码示例

发布时间:2020-12-16 20:57:36 所属栏目:Python 来源:网络整理
导读:工作中用到了C/S模型,所做的也无非是给服务器发数据,但开发阶段会遇到程序自身的回环测试,需要用到简单的服务端以便验证数据发送的正确性。 写软件用C++,跑测试用python,这段时间也刚好看go语言,所以都要有demo。以下三组程序实现的功能相同,这里一起

工作中用到了C/S模型,所做的也无非是给服务器发数据,但开发阶段会遇到程序自身的回环测试,需要用到简单的服务端以便验证数据发送的正确性。

写软件用C++,跑测试用python,这段时间也刚好看go语言,所以都要有demo。以下三组程序实现的功能相同,这里一起做下总结。

一、C++实现

Boost.Asio是一个跨平台的C++库,它用现代C++方法为网络和底层I/O程序提供了一致的异步I/O模型。 为了跨平台,我用boost库实现,具体如下。

服务端代码:

复制代码 代码如下:

/*
     File      : svr.cpp
     Author    : Mike
     E-Mail    : Mike_Zhang@live.com
*/

#include <iostream>
#include <boost/asio.hpp>

using boost::asio::ip::tcp;
enum {max_length = 1024};

typedef boost::shared_ptr<tcp::socket> socket_ptr;

int main()
{
    boost::asio::io_service io_service;
    tcp::acceptor a(io_service,tcp::endpoint(tcp::v4(),atoi("12345")));
    for (;;)
    {
        socket_ptr sock(new tcp::socket(io_service));
        a.accept(*sock);
        char data[max_length];
        boost::system::error_code error;
        size_t length = sock->read_some(boost::asio::buffer(data),error);
        data[length] = 0;
        std::cout<<data<<std::endl;
        sock->close();
    }
    return 0;
}

客户端代码:

复制代码 代码如下:

/*
     File      : cli.cpp
     Author    : Mike
     E-Mail    : Mike_Zhang@live.com
*/
#include <iostream>
#include <boost/asio.hpp>

using boost::asio::ip::tcp;
enum { max_length = 1024 };

int main(int argc,char* argv[])
{
    boost::asio::io_service io_service;
    tcp::resolver resolver(io_service);
    tcp::resolver::query query(tcp::v4(),"127.0.0.1","12345");
    tcp::resolver::iterator iterator = resolver.resolve(query);

    tcp::socket s(io_service);
    s.connect(*iterator);

    std::cout << "Please input: ";
    char request[max_length];
    std::cin.getline(request,max_length);
    size_t request_length = strlen(request);
    boost::asio::write(s,boost::asio::buffer(request,request_length));
    return 0;
}

编译:g++ cli.cpp -o cli -lboost_system -lboost_thread-mt

二、python实现

服务端代码:

复制代码 代码如下:

'''
     File      : svr.py
     Author    : Mike
     E-Mail    : Mike_Zhang@live.com
'''
import socket,os
sock = socket.socket(socket.AF_INET,socket.SOCK_STREAM) 
sock.bind(('127.0.0.1',12345)) 
sock.listen(5) 
while True: 
    connection,address = sock.accept() 
    buf = connection.recv(1024) 
    print buf           
    connection.close()

客户端代码:

复制代码 代码如下:

'''
     File      : cli.py
     Author    : Mike
     E-Mail    : Mike_Zhang@live.com
'''
import socket 
sock = socket.socket(socket.AF_INET,socket.SOCK_STREAM) 
sock.connect(('127.0.0.1',12345)) 
#sock.send('Testn') 
sock.send(raw_input("Please input : ")) 
sock.close()

三、go语言实现

服务端代码:

复制代码 代码如下:

/*
     File      : svr.go
     Author    : Mike
     E-Mail    : Mike_Zhang@live.com
*/
package main

import(
    "net"
    "fmt"
    "bufio"
)

func main() {
    client,err := net.Listen("tcp","127.0.0.1:12345")
    if err != nil {
        fmt.Printf("Error : %sn",err.String())
    }
    for {
        if c,err := client.Accept(); err == nil {
            defer c.Close()
            line,_ := bufio.NewReader(c).ReadString('n')
            fmt.Println(line)
        }
    }
}


客户端代码:

复制代码 代码如下:

/*
     File      : cli.go
     Author    : Mike
     E-Mail    : Mike_Zhang@live.com
*/
package main

import(
    "net"
    "fmt"
)

func main() {
    conn,err := net.Dial("tcp",err.String())
    }
    conn.Write([]byte("Just a test"))    
}

运行效果(go语言为例):

好,就这些了,希望对你有帮助。

您可能感兴趣的文章:

  • python使用socket创建tcp服务器和客户端
  • Python实现的FTP通信客户端与服务器端功能示例
  • Python实现基于多线程、多用户的FTP服务器与客户端功能完整实例
  • python3实现UDP协议的服务器和客户端
  • python3实现TCP协议的简单服务器和客户端案例(分享)
  • Python socket网络编程TCP/IP服务器与客户端通信
  • 利用Python中SocketServer 实现客户端与服务器间非阻塞通信
  • python实现TCP服务器端与客户端的方法详解
  • Python实现的简单文件传输服务器和客户端
  • Python实现一个服务器监听多个客户端请求

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读