scoket用法

来源:https://www.cnblogs.com/lihongtaoya/archive/2023/03/31/17276968.html
-Advertisement-
Play Games

一.scoket基本介紹 1.scoket簡介(以下是來自chatgpt回答) 1)Socket(套接字)是電腦網路中用於描述主機之間通信的一種機制。它定義了一種標準的介面, 使得應用程式可以利用網路傳輸層提供的服務(如TCP或UDP)進行通信。 2)Socket的作用是在網路應用程式之間提供數據 ...


一.scoket基本介紹

1.scoket簡介(以下是來自chatgpt回答)

1)Socket(套接字)是電腦網路中用於描述主機之間通信的一種機制。它定義了一種標準的介面,

      使得應用程式可以利用網路傳輸層提供的服務(如TCP或UDP)進行通信。

2)Socket的作用是在網路應用程式之間提供數據傳輸服務。通過Socket,應用程式可以將數據發送

      到網路上的另一個應用程式,並從網路上的另一個應用程式接收數據。

3)Socket還提供了一種機制,使得應用程式可以接收來自網路上的請求,並對這些請求進行響應。

     常見的網路應用程式,如Web伺服器、郵件伺服器、FTP伺服器等都使用Socket技術。此外,許多P2P

   (點對點)應用程式,如BitTorrent、eMule等也使用Socket技術。Socket還可以用於實現各種網路應用

      程式,如網路游戲、聊天程式等。

2.建立TCP/IP連接

1)創建一個scoket對象

socket_stream = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

第一個參數表示通信協議類型

AF_INET:適用於網路通信

AF_UNIX:適用於本地進程間通信

第二個參數表示創建什麼連接

SOCK_STREAM:表示tcp/ip連線

SOCK_DGRAM:表示udp連接

2)與服務端建立連接

# 建立連接
ip_port = ("ip", "port")  # 連接的服務端ip和埠
socket_stream.connect(ip_port)  # 建立連接,出錯不返回錯誤碼
socket_stream.connect_ex(ip_port)  # 出錯時返回錯誤碼,不拋異常

connect()和connect_ex()選一個即可

3)發送數據

# 發送數據
data = 'hello'
socket_stream.send(data.encode("utf-8"))  # 發送TCP數據,當send在待發送數據量大於己端緩存區剩餘空間時,數據丟失,不會發完
# or
socket_stream.sendall(data.encode("utf-8"))  # 發送完整的TCP數據(迴圈調用send,sendall在待發送數據量大於己端緩存區剩餘空間時,數據不丟失,迴圈調用send直到發完)

當發送的數據較大時建議使用sendall發送

4)接收TCP數據

# 接收TCP數據。1024(變數)表示每次最多接受1M位元組的數據,recv()函數是一個阻塞函數,沒有要接收的數據時,會一直等待,直到接收到數據或出現錯誤才會返回
response_data = socket_stream.recv(1024)

5)關閉連接

# 關閉連接
socket_stream.close()

3.建立UDP連接

1)創建scoket對象

client_dgram = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)

2)發送數據

# 發送數據
ip_port = ('127.0.0.1', 8080)
data = 'Hello'
client_dgram.sendto(data.encode("utf-8"), ip_port)

這裡發送用的是sendto()方法

3)接收數據

# 接收UDP數據數據
data = client_dgram.recvfrom(4096)

4)關閉連接

# 關閉連接
client_dgram.close()

二.使用scoket編寫聊天程式

以下部分代碼參考:https://www.yuque.com/imhelloworld/nov9az/bffcea259d3c96fb17a130acebc12801

聊天程式的話涉及兩個端,既server和click。這裡直接貼代碼了,相關註釋都是代碼里

1)server

import socket
import threading

# 伺服器IP地址和埠號
SERVER_IP = 'IP地址'
SERVER_PORT = 埠號
# 創建一個socket對象
server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# 綁定IP地址和埠號
server_socket.bind((SERVER_IP, SERVER_PORT))
# 設置最大連接數,超過10後拒絕。0的話表示不接受連接,直接拒絕
server_socket.listen(10)
# 客戶端列表
clients = []


def handle_client(client_socket):
    while True:
        try:
            # 接收客戶端發送的消息
            message = client_socket.recv(10240).decode('utf-8')
            print("列印", message)
            if message == 'quert':
                client_socket.send(message.encode('utf-8'))
            else:
                # 廣播消息給所有客戶端
                for c in clients:
                    if c != client_socket:
                        c.send(message.encode('utf-8'))
        except:
            # 發生異常時關閉連接
            client_socket.close()
            clients.remove(client_socket)
            print("發送異常了")
            break


# 迴圈監聽客戶端連接
while True:
    print('Waiting for client connections...')
    # 接受客戶端連接請求,新的客戶端請求時創建一個新的socket,用於處理客戶端的請求,原有的socket繼續監聽其他客戶端的連接請求;
    # 函數是一個阻塞函數,當沒有客戶端連接請求時,會一直等待,直到有客戶端連接請求到達
    client_socket, client_address = server_socket.accept()
    print('客戶socket', client_socket, 'ip和埠', client_address)
    clients.append(client_socket)
    # 創建一個新的線程處理客戶端連接
    client_thread = threading.Thread(target=handle_client, args=(client_socket, ))
    client_thread.start()

2)click

import socket
import threading
import time

# 伺服器IP地址和埠號
SERVER_IP = 'IP地址'
SERVER_PORT = 埠號
# 創建一個socket對象
client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# 連接伺服器
client_socket.connect((SERVER_IP, SERVER_PORT))


def receive():
    while True:
        try:
            # 接收伺服器發送的消息
            message = client_socket.recv(1024).decode('utf-8')
            if message == 'quert':
                client_socket.close()
                break
            print('\n對方回答:', message)
        except:
            # 發生異常時關閉連接
            client_socket.close()
            break


def send():
    while True:
        # 獲取用戶輸入的消息
        message = input()
        if message == 'quert':
            client_socket.close()
            print('連接斷開,通信結束')
            break
        else:
            # 發送消息給伺服器
            client_socket.send(message.encode('utf-8'))


# 創建兩個線程,分別用於接收和發送消息
receive_thread = threading.Thread(target=receive)
send_thread = threading.Thread(target=send)
# 啟動線程
receive_thread.start()
send_thread.start()

這裡需要註意的是,既然是聊天程式,那麼肯定涉及兩個click,兩個click代碼一致即可,運行時先運行server,後運行click,之後就可以在Terminal下建立對話了。

以上是click在同一臺電腦上,若不在同一臺電腦的,建立對話需在同一個區域網下,ip地址在dos視窗下輸入ipconfig\all即可查看,埠號可隨便填個,只要不被占用就行。

三.scoket+chatgpt建立搜索對話框

1)獲取chatgpt搜索介面,這裡就直接貼代碼了

def api(params, tokened="token"):
    url = "https://api.aigcfun.com/api/v1/text?key=" + tokened
    data = {"messages": [{"role": "system", "content": "請以markdown的形式返回答案"},
                         {"role": "user", "content": params}], "tokensLength": 32, "model": "gpt-3.5-turbo"}
    response_data = requests.post(url=url, json=data)
    return response_data.json()["choices"][0]["text"]

params為用戶問的問題,return返回的是chatgpt回答的答案

2)獲取到chatgpt的回答內容後返回給服務端

def receive():
    while True:
        try:
            # 接收伺服器發送的消息
            message = client_socket.recv(1024).decode('utf-8')
            data_message = api(message)
            while data_message == None:  # 由於chatgpt有時響應的比較慢,這裡需添加個迴圈判斷
                continue
            # if data_message == '您今日使用次數已達上限,請明日再試!':
            #     data_message = api(params=message, tokened=token())

            client_socket.send(data_message.encode('utf-8'))  # 發送chatgpt回答的問題給服務端
        except:
            # 發生異常時關閉連接
            client_socket.close()
            break

3)目前chatpgt雖是免費的,但每天都有次數限制,所以可以請求獲取token的介面來獲取新的token。這裡就不做演示了(hhhhhh.........)

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 模型之間的關係(Relations Between Models) 上一章介紹了為包含基本欄位的模型創建自定義視圖。然而,在任何真實的業務場景中,我們都需要不止一個模型。此外,模型之間的鏈接是必要的。人們可以很容易地想象一個模型包含客戶,另一個模型則包含用戶列表。你可能需要參考任何現有業務模型上的客 ...
  • ChatGPT是一個基於GPT-3.5架構的自然語言處理工具,它具有文本生成、文本分類、對話生成等多種能力。作為一種強大的自然語言處理工具,ChatGPT可以應用於智能客服、智能問答、內容創作等多個領域。如果您對ChatGPT感興趣,可以通過關註本公眾號瞭解更多信息,並體驗基於ChatGPT的小程式... ...
  • Spring Spring為簡化開發而生,讓程式員只關心核心業務的實現,儘可能的不在關註非業務邏輯代碼(事務控制,安全日誌等)。 1,Spring八大模塊 這八大模塊組成了Spring 1.1 Spring Core模塊 這是Spring框架的最基礎的部分,它提供了依賴註入(DependencyIn ...
  • React Native 備忘清單 適合初學者的綜合 React Native 備忘清單,在開始 React Native 之前需要先掌握 react 庫入門,為開發人員分享快速參考備忘單。 React Native (簡稱RN)是Facebook於2015年4月開源的跨平臺移動應用開發框架,是Fa ...
  • React 備忘清單 IT寶庫整理適合初學者入門的React開發速查備忘清單,為開發人員分享快速參考備忘單。 React是用於構建用戶界面的JavaScript庫,起源於Facebook的內部項目,該公司對市場上所有 JavaScript MVC框架都不滿意,決定自行開發一套,用於架設Instagr ...
  • 一、延遲計算 RDD 代表的是分散式數據形態,因此,RDD 到 RDD 之間的轉換,本質上是數據形態上的轉換(Transformations) 在 RDD 的編程模型中,一共有兩種運算元,Transformations 類運算元和 Actions 類運算元。開發者需要使用 Transformations ...
  • 一 回顧trait使用 https://blog.csdn.net/bushuwei/article/details/103514174發現之前本人說明很模糊,自己居然不知道為什麼其實這裡的$c,就是class B再次回顧邏輯 二 分析 self和static區別說的沒毛病 Trait基類use t ...
  • 一、函數的定義 可以分為以下兩種: 1、函數聲明和函數定義分離 這種方法將函數聲明和函數定義分開,通常在頭文件中先聲明函數原型,然後在源文件中實現函數定義。 例如,頭文件 example.h 中聲明瞭一個函數 add: #ifndef EXAMPLE_H #define EXAMPLE_H int ...
一周排行
    -Advertisement-
    Play Games
  • 人臉識別技術在現代社會中扮演著越來越重要的角色,比如人臉識別門禁、人臉識別支付、甚至人臉識別網站登錄等。 最近有群友問.NET有沒有人臉識別的組件,小編查閱相關資料介紹下麵幾種.NET人臉識別組件供大家參考。 **1、Microsoft Azure Face API** 簡介:Microsoft A ...
  • # 1. 與 .NET Core 緩存的關係和差異 ABP 框架中的緩存系統核心包是 [Volo.Abp.Caching](https://www.nuget.org/packages/Volo.Abp.Caching) ,而對於分散式緩存的支持,abp 官方提供了基於 Redis 的方案,需要安裝 ...
  • 最近ET做熱更重載dll的時候,返回登陸會重新檢測新的dll,首次登錄之前已經Assembly.Load()過一次dll,第二次返回登陸再次load dll到記憶體中,Invoke執行方法的時候,異常了,有些方法執行了,有些未執行,於是查資料,看到些老資料說Assembly.Load重覆載入同名dll ...
  • 1. 擴展方法 擴展方法使你能夠向現有類型“添加”方法,而無需創建新的派生類型、重新編譯或以其他方式修改原始類型。 擴展方法是一種靜態方法,但可以像擴展類型上的實例方法一樣進行調用。 對於用 C#、F# 和 Visual Basic 編寫的客戶端代碼,調用擴展方法與調用在類型中定義的方法沒有明顯區別 ...
  • 以前在隨筆《Winform開發框架之客戶關係管理系統(CRM)的開發總結系列1-界面功能展示 》的幾篇隨筆中介紹過基於WInform開發框架開發的CRM系統,系統的功能主要也是圍繞著客戶相關信息來進行管理的。本篇隨筆介紹在最新的《SqlSugar開發框架》中整合CRM系統模塊的功能。 ...
  • 隨著技術的發展,ASP.NET Core MVC也推出了好長時間,經過不斷的版本更新迭代,已經越來越完善,本系列文章主要講解ASP.NET Core MVC開發B/S系統過程中所涉及到的相關內容,適用於初學者,在校畢業生,或其他想從事ASP.NET Core MVC 系統開發的人員。 經過前幾篇文章... ...
  • [toc] 這篇文章是我之前總結的一篇文章,因為整理博客的原因,原有博客已經註銷,但這篇文章對一些讀者很有用,所以現在新瓶裝舊酒重新整理回來分享給大家。 最近一段時間生產環境頻繁出問題,每次都會生成一個hs_err_pid*.log文件,因為工作內容的原因,在此之前並沒有瞭解過相關內容,趁此機會學習 ...
  • # 前言 在上一篇文章中,給大家講解了泛型的概念、作用、使用場景,以及泛型集合、泛型介面和泛型類的用法,但受限於篇幅,並沒有把泛型的內容講解完畢。所以今天我們會繼續學習泛型方法、泛型擦除,以及通配符等的內容,希望大家繼續做好學習的準備哦。 *** 全文大約【**4600】** 字,不說廢話,只講可以 ...
  • 昨天遇到參數key大小寫不一致導致校驗簽名失敗的問題,查了很長時間才找到原因。看了一下FastJson源碼,發現JSON.toObject中轉換成對象的時候會忽略大小寫。 所以,當使用了JSON.toObject將json轉成Java對象後,再用JSON.toObject轉成json,key值就變了 ...
  • 基於java的線上商城設計與實現,線上購物平臺,校園購物商城,商品銷售平臺,基於Java的電商平臺;電商平臺,買家和賣家可以在此平臺上進行銷售和交易,節約了大量的線下時間成本,購物車的功能,校園交易平臺等等; ...