⑴ java Socket開發 關於報文傳遞和接收
看 Oracle 官方教程,同步式的 Socket 就是傳統的一問一答方式,它就是你需要的。
客戶端先 socket.getOutputStream().write(...); 之後到 socket.getInputStream().read(byte[]) 在循環中讀取直到 read 方法返回 -1 或你期望的位元組數已經全部收到了就停下來,如果不嘗試停下來,後面的 read 將會阻塞等待。
http://docs.oracle.com/javase/tutorial/networking/sockets/index.html
基於性能改進,一般我們需要使用 NIO 非同步的 socket,只需要一個線程負責通信,每個線程都有自己的出站消息隊列和入站消息隊列,以線程為 key 區分開,通信線程只負責把各自的消息從出站隊列中發送去並把收到的消息放入入站隊列中,應用程序線程就去各自的消息隊列中取消息就可以了。因為每個應用線程有各自的消息隊列,我們把消息放入出站隊列之後就到入站隊列上用同步鎖等待的方法阻塞到有消息回答時為止。
關於 NIO non-blocking 非阻塞式 socket,下面有一個 NBTimeServer 例子,它講的是服務端。客戶端與此類似,
http://docs.oracle.com/javase/7/docs/technotes/guides/io/example/index.html
NIO 通信線程樣例。
publicvoidrun()
{
inttip=0;
try
{
selector=Selector.open();
SelectionKeyk=channel.register(selector,getInterestOptions());
k.attach(thread);//把當前線程綁定到附件中。
this.running=true;
statusChanged(Status.CONNECTED);
while(this.isRunning())
{
//select()isablockingoperation.
inteventCount=selector.select();
debug("[MC.Debug]PollingTCPevents..."+eventCount);
if(eventCount>0&&channel.isOpen()&&this.isRunning())
{
Setkeys=selector.selectedKeys();
for(Iteratoriter=keys.iterator();iter.hasNext();iter.remove())
{
SelectionKeykey=(SelectionKey)iter.next();
Threadthread=(Thread)key.attachment();
if(!key.isValid())
{//channelisclosing.
break;
}
process(key);//處理讀取消息並把消息放入thread對應的隊列。//寫出消息類似的,不過在register時需要注冊寫出允許的事件,
}
}
}
}
⑵ JAVA解析發送tcp ip報文
JAVA 寫一個SOCKET 伺服器,接收、處理單片機遞交上來的數據
通過文字輸入流,直接可以當字元處理的。也很方便輸出返饋。
⑶ java中報文啥時候用呢一直搞不懂
你可以了解一下http協議
報文就是一組客戶端和服務端都認可的信息數據。可以是xml形式,json格式。等等
比如有一個android客戶端向服務端發送登陸報文
<user>
<username></username>
<password>123456</password>
</user>
這段由客戶端到服務端的xml,就可以視為一個上行報文
服務端收到報文後會返回登陸成功或者失敗的信息
比如:200(成功)
404 (失敗)
甚至返回更詳細的失敗信息等等這個由服務端到客戶端的返回信息同樣可以是多樣性,可視為下行報文
⑷ javaweb里get請求頭報文信息含義是什麼啊
常見的HTTP報文頭屬性
Accpet
告訴服務端,客戶端接收什麼類型的響應
Referer
表示這是請求是從哪個URL進來的,比如想在網上購物,但是不知道選擇哪家電商平台,你就去問度娘,說哪家電商的東西便宜啊,然後一堆東西彈出在你面前,第一給就是某寶,當你從這里進入某寶的時候,這個請求報文的Referer就是www..com
Cache-Control
對緩存進行控制,如一個請求希望響應的內容在客戶端緩存一年,或不被緩可以通過這個報文頭設置
Accept-Encoding
例如:Accept-Encoding:gzip, deflate(這兩種都是壓縮格式)
這個屬性是用來告訴伺服器能接受什麼編碼格式,包括字元編碼,壓縮形式(一般都是壓縮形式)
Host
指定要請求的資源所在的主機和埠
User-Agent 作用:告訴伺服器,客戶端使用的操作系統、瀏覽器版本和名稱
⑸ java大報文介面怎麼處理
Java 處理大報文介面一般需要注意以下幾個方面:
1. 使用合適的數據結構存儲和傳輸大報文。在處理大報文時,需要注意報文的數據大小和結芹搜螞構,怎樣更好的處理和傳輸大報文是一個重要的問題。Java提供了多種數據結構用於存儲和傳輸數據,比如List、Set等,根據數據特點選擇合適的數據結構是非常重要的。
2. 使用流式讀取或逐行讀取大報文。在處理大報文時,可以考慮使用流式讀取或逐行讀取的方式,避免一次性讀取所有內容,導致內存耗盡的情況。在Java中可以使用BufferedReader等對大文件進行讀取。
3. 分塊傳輸。在傳輸大報文時,可以採用分塊傳輸的方式,將大報文劃分成固定大小的塊進行傳輸,避免一次性傳輸大報文導致網路擁堵等問題。在Java中可以使用ByteBuffer類對大文件進行分塊傳輸。
4. 壓縮和加密大報文。在傳輸大報文時,可以採用數據壓縮和加密的方式,有效地提高傳輸速度和安全性。在Java中可以使用GZip類和BZip2類等進行數據壓縮,使用AES、DES等加密演算法對數據進行加密。
5. 使用線程池等機制,避免對系統資源佔用過多。在處理大報文時,需要注意對系統資源的佔用情況。如果所有處理任務都由一個線程負責,可能會導致系統崩潰。因此可以使用線程池等機漏陪制,分配合理的任務數,避免過高的系統資源佔用。
綜上所述,處理大報文介面需要綜合嫌埋考慮多個方面,從數據的存儲、傳輸、讀取、壓縮和加密等多個角度進行處理,以避免對系統資源的佔用和處理效率的下降。