㈠ socket接收16進制速度比較快
是的,比較快 接收設置,sock接收的數據是bytes類型,收到的普通數據為b'xxx『,轉換成str類型,需要』xxx'.decode('utf-8'),但是收到的『aa'十六進制的bytes數據為b'\xaa',需轉換成普通 str 'aa',轉換用'xx'.hex()即可轉換。
if recv_msg:
msg = f"來自IP:{address[0]}埠:{address[1]}:"
self.tcp_signal_write_msg.emit(msg)
try:
info = recv_msg.decode("utf-8")
self.tcp_signal_write_info.emit(info, self.InfoRec)
except Exception as ret:
if recv_msg.hex(): #將16進制bytes b'\xaa'轉換成utf-8 str 'aa'
info = recv_msg.hex()
self.tcp_signal_write_info.emit(info, self.InfoRec)
else:
msg="數據格式錯誤"+ret.__str__()
self.tcp_signal_write_msg.emit(msg)
解析接收的數據:以十六進制顯示與普通方式顯示
if self.receive_HEX_flag: # 以十六進制接收
info=bytes(info,encoding='utf-8') #轉換成bytes類型
info_hex = base64.b16encode(info) #16進制編碼
else:
info_hex = info
base64以16進制編碼需bytes類型,重新將str轉換為bytes,用 bytes(info,encoding='utf-8')轉換。
發送設置:
if self.send_HEX_flag: #以十六進制發送
info_hex=base64.b16encode(info.encode())
else:
info_hex=info
16進制發只需將所需數據轉換成16進制即可,普通發送不用轉換。
㈡ 用socket怎麼向伺服器端發送16進制數據
getOutputStream(),從連接獲穗消取輸入流對猜慶知象。 這個對象可以和BufferedOutputStream,OutputStreamWriter等配差帆合使用; 建立BufferedOutputStream對象 BufferedOutputStream br=new BufferedOutputStream(socket.getOutputStream()); 調用BufferedOu...
㈢ python中想要把字母或數字轉為16進制\x30格式並且輸出,但是最終顯示卻還是字母是怎麼回事呢
給你一個函數試試。
def str_to_hex(s):
return ' '.join([hex(ord(c)).replace('0x', '') for c in s])
㈣ C# Socket發送接收位元組數組和十六16進制之間的轉換
用的Socket發送和接收數據,遠程模塊指令為16進制。
下面的轉換函數對於初學者來說比較方便:
//16進制字元串轉字肆敗如節數組 格式為 string sendMessage = "00 01 00 00 00 06 FF 05 00 64 00 00";
private static byte[] HexStrTobyte(string hexString)
{
hexString= hexString.Replace("","");
if((hexString.Length %2) !=0)
hexString+="";
byte[] returnBytes =new byte[hexString.Length /2];
for(inti =0; i < returnBytes.Length; i++)
returnBytes[i]= Convert.ToByte(hexString.Substring(i *2,2).Trim(),16);
returnreturn Bytes;
}
//位元組數組轉16進制字元串
public static string byteToHexStr(byte[] bytes)
{
string returnStr ="";
if(bytes !=null)
{
for(inti =0; i < bytes.Length; i++)
{
//ToString("X2") 為C#中的字元串格式控制符
returnStr+= bytes[i].ToString("X2");
}
}
returnreturnStr;
}
//位元組數組轉16進制更簡單的,利用BitConverter.ToString方法
//string str0x = BitConverter.ToString(result, 0, result.Length).Replace("-"," ");
註:
ToString("X2") 為C#中的字元串格式控制符
X為枯爛 十六進制
2為 每次都是兩位數
比如 0x0A ,若沒有2,就只裂啟會輸出0xA
㈤ Python 之 Socket編程(TCP/UDP)
socket(family,type[,protocal]) 使用給定的地址族、套接字類型、協議編號(默認為0)來創建套接字。
有效的埠號: 0~ 65535
但是小於1024的埠號基本上都預留給了操作系統
POSIX兼容系統(如Linux、Mac OS X等),在/etc/services文件中找到這些預留埠與的列表
面向連接的通信提供序列化、可靠的和不重復的數據交付,而沒有記錄邊界。意味著每條消息都可以拆分多個片段,並且每個消息片段都能到達目的地,然後將它們按順序組合在一起,最後將完整的信息傳遞給等待的應用程序。
實現方式(TCP):
傳輸控制協議(TCP), 創建TCP必須使用SOCK_STREAM作為套接字類型
因為這些套接字(AF_INET)的網路版本使用網際網路協議(IP)來搜尋網路中的IP,
所以整個系統通常結合這兩種協議(TCP/IP)來進行網路間數據通信。
數據報類型的套接字, 即在通信開始之前並不需要建議連接,當然也無法保證它的順序性、可靠性或重復性
實現方式(UDP)
用戶數據包協議(UDP), 創建UDP必須使用SOCK_DGRAM (datagram)作為套接字類型
它也使用網際網路來尋找網路中主機,所以是UDP和IP的組合名字UDP/IP
注意點:
1)TCP發送數據時,已建立好TCP連接,所以不需要指定地址。UDP是面向無連接的,每次發送要指定是發給誰。
2)服務端與客戶端不能直接發送列表,元組,字典。需要字元串化repr(data)。
TCP的優點: 可靠,穩定 TCP的可靠體現在TCP在傳遞數據之前,會有三次握手來建立連接,而且在數據傳遞時,有確認、窗口、重傳、擁塞控制機制,在數據傳完後,還會斷開連接用來節約系統資源。
TCP的缺點: 慢,效率低,佔用系統資源高,易被攻擊 TCP在傳遞數據之前,要先建連接,這會消耗時間,而且在數據傳遞時,確認機制、重傳機制、擁塞控制機制等都會消耗大量的時間,而且要在每台設備上維護所有的傳輸連接,事實上,每個連接都會佔用系統的CPU、內存等硬體資源。 而且,因為TCP有確認機制、三次握手機制,這些也導致TCP容易被人利用,實現DOS、DDOS、CC等攻擊。
什麼時候應該使用TCP : 當對網路通訊質量有要求的時候,比如:整個數據要准確無誤的傳遞給對方,這往往用於一些要求可靠的應用,比如HTTP、HTTPS、FTP等傳輸文件的協議,POP、SMTP等郵件傳輸的協議。 在日常生活中,常見使用TCP協議的應用如下: 瀏覽器,用的HTTP FlashFXP,用的FTP Outlook,用的POP、SMTP Putty,用的Telnet、SSH QQ文件傳輸.
UDP的優點: 快,比TCP稍安全 UDP沒有TCP的握手、確認、窗口、重傳、擁塞控制等機制,UDP是一個無狀態的傳輸協議,所以它在傳遞數據時非常快。沒有TCP的這些機制,UDP較TCP被攻擊者利用的漏洞就要少一些。但UDP也是無法避免攻擊的,比如:UDP Flood攻擊……
UDP的缺點: 不可靠,不穩定 因為UDP沒有TCP那些可靠的機制,在數據傳遞時,如果網路質量不好,就會很容易丟包。
什麼時候應該使用UDP: 當對網路通訊質量要求不高的時候,要求網路通訊速度能盡量的快,這時就可以使用UDP。 比如,日常生活中,常見使用UDP協議的應用如下: QQ語音 QQ視頻 TFTP ……
㈥ c#中socket編程伺服器端,伺服器接收到的數據是16進制的數據,如何將數據轉化為16進制
首先得保證接受到的數據的編碼集,如:UTF-8,然後用Encoding 相關的API進行轉化
㈦ 請問通過netty或者socket怎麼接收16進制的位元組碼
socket接收的本來就是byte數組,直接處理byte數組就好。一般原始的socket代碼都是用byte的。只有外界一些簡化的代碼,才會直接把byte數組轉換成字元再處理。
不過唯一的問題是,你這樣沒有tcp頭的數據。容易發生tcp拆包。
㈧ python socket recv 到的一個數據包中有 print repr出來有16進的有正常的字元串
struct包裡面有pack和unpack,字元串之間可以用+連接起來。
㈨ 求教各位大仙socket如何發送16進制數據
我們定義發送者和接收者,發送者作為客戶端,接收者作為服務端。
Sender.java
importjava.io.DataOutputStream;
importjava.io.IOException;
importjava.net.Socket;
importjava.util.Arrays;
publicclassSender{
publicstaticvoidmain(String[]args)throwsException{
//127.0.0.1代表本機地址,在8888埠上監聽
Sendersender=newSender("127.0.0.1",8888);
byte[]bytes={15,16,17,120};//對應的十六進制是0F101178
sender.send(bytes);
System.out.println("發送"+Arrays.toString(bytes)+"完畢!");
}
privatefinalStringhost;
privatefinalintport;
publicSender(Stringhost,intport){
this.host=host;
this.port=port;
}
privatevoidsend(byte[]bytes)throwsIOException{
Socketsocket=newSocket(host,port);//建立和服務端的socket
try(DataOutputStreamdos//建立輸出流
=newDataOutputStream(socket.getOutputStream())){
dos.write(bytes,0,bytes.length);//向輸出流寫入bytes
}
}
}
importjava.io.DataInputStream;
importjava.io.IOException;
importjava.net.ServerSocket;
importjava.net.Socket;
publicclassReceiver{
publicstaticvoidmain(String[]args)throwsException{
Receiverreceiver=newReceiver(8888);
receiver.receive();
}
;
publicReceiver(intport)throwsIOException{
serverSocket=newServerSocket(port);
}
privatevoidreceive()throwsIOException{
System.out.println("等待客戶端連接...");
Socketsocket=serverSocket.accept();
try(DataInputStreamdis=newDataInputStream(socket.getInputStream())){
byte[]bytes=newbyte[1024];//假設發送的位元組數不超過1024個
intsize=dis.read(bytes);//size是讀取到的位元組數
Stringhex=bytesToHex(bytes,0,size);
System.out.println("接收到的byte數組的十六進制:"+hex);
}
}
/**
*將byte數組轉化為十六進制字元串
*
*@parambytesbyte[]數組
*@parambegin起始位置
*@paramend結束位置
*@returnbyte數組的十六進制字元串表示
*/
privateStringbytesToHex(byte[]bytes,intbegin,intend){
StringBuilderhexBuilder=newStringBuilder(2*(end-begin));
for(inti=begin;i<end;i++){
hexBuilder.append(Character.forDigit((bytes[i]&0xF0)>>4,16));//轉化高四位
hexBuilder.append(Character.forDigit((bytes[i]&0x0F),16));//轉化低四位
hexBuilder.append('');//加一個空格將每個位元組分隔開
}
returnhexBuilder.toString().toUpperCase();
}
}
㈩ Python TCP通訊發送Byte出現數據裡面多出一上字元是怎麼回事
txt="\x27\x88",這個是由兩個轉義字元構成的字元串。
txt.encode()會使用utf-8編碼方式將字元串編碼為位元組序列(bytes對象)。
utf-8編碼的話,txt.encode()會返回3位元組的位元組序列:b'\x27\xc2\x88',因為對於字元'\x88',用utf-8編碼後是2個位元組b'\xc2\x88'。
所以,接收到的自然是3個位元組的位元組序列b'\x27\xc2\x88'。
要解碼後才是原字元串,即:
b'\x27\xc2\x88'.decode()=='\x27\x88'的結果是True。