⑴ 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. 使用线程池等机制,避免对系统资源占用过多。在处理大报文时,需要注意对系统资源的占用情况。如果所有处理任务都由一个线程负责,可能会导致系统崩溃。因此可以使用线程池等机漏陪制,分配合理的任务数,避免过高的系统资源占用。
综上所述,处理大报文接口需要综合嫌埋考虑多个方面,从数据的存储、传输、读取、压缩和加密等多个角度进行处理,以避免对系统资源的占用和处理效率的下降。