Java中的”推”技术 [/size]
bromon原创 版权所有
在一般的B/S程序中(最典型的是web服务),工作的方式是客户端(brower)向服务器端(server)发送一个请求,服务器端响应这个请求并发回客户端所请求的数据。在这个过程中服务器端扮演的是一个被动响应的角色,一般的情况下,服务器端是不会主动向客户端写数据的。由于HTTP是一个无连接的协议,也就是说当服务器端完成对客户端的响应后,双方的连接就断开了,直到下一次客户端发出请求时再重新建立连接。这样的HTTP协议是节省网络资源的,但是也给我们带来了一些麻烦,比如客户端不能实时探查服务器端的数据变化,不能作出及时的响应。所以当我们在做一些需要客户端和服务器端互相响应的程序时(比如聊天室、web短信息),不得不在客户端不停的刷新页面,以求获得最新的数据,这样做增加的服务器的负担。如果服务器能在数据发生变化的时候主动向客户端写数据,那么问题就解决了,这就是所谓的“推”技术。
在java中,客户端主动向服务器端申请数据,叫做“拉”;服务器主动向客户端写数据,叫做“推”。我们可以在服务器端打开某个端口,监听客户端的连接,就可以向客户端随意写数据,这是我们做C/S程序的原理,“推”技术采用相同的原理,只是客户端是浏览器而已,只要我们按照浏览器能够识别的格式向客户端写数据,客户端就可以通过HTTP与服务器建立连接,并获得数据。
HTTP是一个很庞大的协议,但是我们只需要用到很小一部分。最重要的是要知道按照什么格式写数据,浏览器才认识。当我们浏览一个网站的某一页,比如www.sohu.com/page.htm的时候,我们是在向服务器发送这样一个信息:
引用
GET /page.htm HTTP/1.0
From:
[email protected]
User-Agent: Mozilla/4.0 (compatible; MSIE 5.0; Windows NT 5.0; DigExt)
空行
其中第一行是我们要关注的,它由空格分隔成三部分,一是请求的方法(get),二是请求的页面,三是HTTP的版本。如果请求无误,服务器将返回如下信息:
引用
HTTP/1.0 200 OK
Date: Thu, 8 Oct 2002 14:23:11 GMT
Content-Type: text/html
Content-Length: 1644
<html>
<body>
<h1>Hello world!</h1>
(其他内容)...
</body>
</html>
第一行表示连接成果,然后是返回数据的属性,从<html>开始才是返回给浏览器返回的数据。在我们自己的程序中只需要按照上述格式写数据,就可以实现一个自己的简易web服务器。下面是一个hello,world的例子:
//myServer.java
import java.io.*;
import java.net.*;
public class myServer
{
static ServerSocket server=null;
static OutputStreamWriter ow=null;
public static void main(String args[])
{
int port=800;
try
{
server=new ServerSocket(port);
}catch(Exception e)
{
System.out.println(e);
}
while(true)
{
try
{
Socket socket=server.accept();
ow=new OutputStreamWriter(socket.getOutputStream());
ow.write("HTTP/1.0 200 ok ");
ow.write("Content-Type:text/html ");
ow.write("<html><body>");
ow.write("hello,world");
ow.write("</body></html>");
ow.flush();
socket.close();
}catch(Exception e)
{
System.out.println(e);
}
}
}
}
编译:javac myServer.java
运行:java myServer
然后打开浏览器,输入http://localhost:800,将会返回一个”hello,world”
以上就是一个“推”技术的简单实现,将它扩展一下,比如加入多线程响应,就可以实现无刷新的聊天室,请读者自己考虑。[/size]
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/bromon/archive/2004/06/22/22630.aspx[/size]