Java Socket应答与HTTP服务器的瓜葛
2015-04-29 11:27
363 查看
Java Socket应答与HTTP服务器的瓜葛
Java Socket应答一直伴随着我们的编程生活,在不断的发展中有很多知识需要我们学习。下面我们就先来看看有关Java Socket应答的代码,有点长,但是看下去就会让你豁然开朗。HTTP/1.1表示这个HTTP服务器是1.1版,200是服务器对客户请求的应答状态码,OK是对应答状态码的解释,之后是这个文档的元信息和文档正文。(相关应答状态码和元信息的解释请参阅Inetrnet标准草案:RFC2616)。
Http.java import java.net.*; import java.io.*; import java.util.Properties; import java.util.Enumeration; public class Http { protected Socket client; protected BufferedOutputStream sender; protected BufferedInputStream receiver; protected ByteArrayInputStream byteStream; protected URL target; private int responseCode=-1; private String responseMessage=""; private String serverVersion=""; private Properties header = new Properties(); public Http() { } public Http(String url) { GET(url) ; } /* GET方法根据URL,会请求文件、数据库查询结果、程序运行结果等多种内容 */ public void GET(String url) { try { checkHTTP(url); openServer(target.getHost(),target.getPort() ); String cmd = "GET "+ getURLFormat(target) +" HTTP/1.0\r\n" + getBaseHeads()+"\r\n"; sendMessage(cmd); receiveMessage(); } catch(ProtocolException p) { p.printStackTrace(); return; } catch(UnknownHostException e) { e.printStackTrace(); return; } catch(IOException i) { i.printStackTrace(); return; } } /* * HEAD方法只请求URL的元信息,不包括URL本身。若怀疑本机和服务器上的 * 文件相同,用这个方法检查最快捷有效。 */ public void HEAD(String url) { try { checkHTTP(url); openServer(target.getHost(),target.getPort() ); String cmd = "HEAD "+getURLFormat(target)+" HTTP/1.0\r\n" +getBaseHeads()+"\r\n"; sendMessage(cmd); receiveMessage(); }catch(ProtocolException p) { p.printStackTrace(); return; }catch(UnknownHostException e) { e.printStackTrace(); return; }catch(IOException i) { i.printStackTrace(); return; } } /* * POST方法是向服务器传送数据,以便服务器做出相应的处理。例如网页上常用的 * 提交表格。 */ public void POST(String url,String content) { try { checkHTTP(url); openServer(target.getHost(),target.getPort() ); String cmd = "POST "+ getURLFormat(target) +"HTTP/1.0\r\n"+getBaseHeads(); cmd += "Content-type: application/x-www-form-urlencoded\r\n"; cmd += "Content-length: " + content.length() + "\r\n\r\n"; cmd += content+"\r\n"; sendMessage(cmd); receiveMessage(); }catch(ProtocolException p) { p.printStackTrace(); return; }catch(UnknownHostException e) { e.printStackTrace(); return; }catch(IOException i) { i.printStackTrace(); return; } } protected void checkHTTP(String url) throws ProtocolException { try { URL target = new URL(url); if(target==null || !target.getProtocol().toUpperCase().equals("HTTP") ) throw new ProtocolException("这不是HTTP协议"); this.target = target; } catch(MalformedURLException m) { throw new ProtocolException("协议格式错误"); } } /* * 与Web服务器连接。若找不到Web服务器,InetAddress会引发UnknownHostException * 异常。若Socket连接失败,会引发IOException异常。 */ protected void openServer(String host,int port) throws UnknownHostException,IOException { header.clear(); responseMessage=""; responseCode=-1; try { if(client!=null) closeServer(); if(byteStream != null) { byteStream.close(); byteStream=null; } InetAddress address = InetAddress.getByName(host); client = new Socket(address,port==-1?80:port); sender = new BufferedOutputStream(client.getOutputStream()); receiver = new BufferedInputStream(client.getInputStream()); }catch(UnknownHostException u) { throw u; }catch(IOException i) { throw i; } } /* 关闭与Web服务器的连接 */ protected void closeServer() throws IOException { if(client==null) return; try { client.close(); sender.close(); receiver.close(); } catch(IOException i) { throw i; } client=null; sender=null; receiver=null; } protected String getURLFormat(URL target) { String spec = "http:// +target.getHost(); if(target.getPort()!=-1) spec+=":"+target.getPort(); return spec+=target.getFile(); } /* 向Web服务器传送数据 */ protected void sendMessage(String data) throws IOException{ sender.write(data.getBytes(),0,data.length()); sender.flush(); } /* 接收来自Web服务器的数据 */ protected void receiveMessage() throws IOException{ byte data[] = new byte[1024]; int count=0; int word=-1; // 解析第一行 while( (word=receiver.read())!=-1 ) { if(word=='\r'||word=='\n') { word=receiver.read(); if(word=='\n') word=receiver.read(); break; } if(count == data.length) data = addCapacity(data); data[count++]=(byte)word; } String message = new String(data,0,count); int mark = message.indexOf(32); serverVersion = message.substring(0,mark); while( mark<message.length() && message.charAt(mark+1)==32 ) mark++; responseCode = Integer.parseInt(message.substring(mark+1,mark+=4)); responseMessage = message.substring(mark,message.length()).trim(); // 应答状态码和处理请读者添加 switch(responseCode) { case 400: throw new IOException("错误请求"); case 404: throw new FileNotFoundException( getURLFormat(target) ); case 503: throw new IOException("服务器不可用" ); } if(word==-1) throw new ProtocolException("信息接收异常终止"); int symbol=-1; count=0; // 解析元信息 while( word!='\r' && word!='\n' && word>-1) { if(word=='\t') word=32; if(count==data.length) data = addCapacity(data); data[count++] = (byte)word; parseLine: { while( (symbol=receiver.read()) >-1 ) { switch(symbol) { case '\t': symbol=32; break; case '\r': case '\n': word = receiver.read(); if( symbol=='\r' && word=='\n') { word=receiver.read(); if(word=='\r') word=receiver.read(); } if( word=='\r' || word=='\n' || word>32) break parseLine; symbol=32; break; } if(count==data.length) data = addCapacity(data); data[count++] = (byte)symbol; } word=-1; } message = new String(data,0,count); mark = message.indexOf(':'); String key = null; if(mark>0) key = message.substring(0,mark); mark++; while( mark<message.length() && message.charAt(mark)<=32 ) mark++; String value = message.substring(mark,message.length() ); header.put(key,value); count=0; } // 获得正文数据 while( (word=receiver.read())!=-1) { if(count == data.length) data = addCapacity(data); data[count++] = (byte)word; } if(count>0) byteStream = new ByteArrayInputStream(data,0,count); data=null; closeServer(); } public String getResponseMessage() { return responseMessage; } public int getResponseCode() { return responseCode; } public String getServerVersion() { return serverVersion; } public InputStream getInputStream() { return byteStream; } public synchronized String getHeaderKey(int i) { if(i>=header.size()) return null; Enumeration enum = header.propertyNames(); String key = null; for(int j=0; j<=i; j++) key = (String)enum.nextElement(); return key; } public synchronized String getHeaderValue(int i) { if(i>=header.size()) return null; return header.getProperty(getHeaderKey(i)); } public synchronized String getHeaderValue(String key) { return header.getProperty(key); } protected String getBaseHeads() { String inf = "User-Agent: myselfHttp/1.0\r\n"+ "Accept: www/source; text/html; image/gif; */*\r\n"; return inf; } private byte[] addCapacity(byte rece[]){ byte temp[] = new byte[rece.length+1024]; System.arraycopy(rece,0,temp,0,rece.length); return temp; } public static void main(String[] args) { Http http=new Http(); //http.GET("http://192.168.1.5 ); int i; for (i=0; i<50000; i++) { http.GET("http://www.model-dl.com/modelinfo.asp?modelid=101 ); http.POST("http://www.model-dl.com/modelinfo.asp?modelid=101,"ratecontd=101&MM_insert=form1 "); } } }
以上就是对Java Socket应答的相关介绍,希望大家有所发现。
相关文章推荐
- 简单的用 Java Socket 编写的 HTTP 服务器应用,帮助学习HTTP协议
- http get请求获取服务器返回的应答数据
- 简单的用 Java Socket 编写的 HTTP 服务器应用,帮助学习HTTP协议
- 简单的用 Java Socket 编写的 HTTP 服务器应用,帮助学习HTTP协议(支持POST信息打印)
- java socket 架构 http 服务器(简易版)
- HttpWebResponse远程服务器返回错误: (500) 内部服务器错误
- 无法启动GlassFish Server 4.1.1:服务器未运行时,HTTP或HTTPS监听程序端口已被占
- Socket(TCP/UDP)及服务器、应用层协议(Http/FTP/SIP/Mega/SNMP)及服务器(Apache/FTPServer/SipProxy/MegaServer/SNMPServe
- 应用层协议实现系列(一)——HTTP服务器之仿nginx多进程和多路IO的实现
- python3用http.server模块搭建简易版服务器
- Node.js学习笔记(4)——除了HTTP(服务器和客户端)部分
- C#如何用WebClient动态提交文件至Web服务器和设定Http响应超时时间
- java下载远程http地址的图片文件到本地-自动处理图片是否经过服务器gzip压缩的问题
- 八、设置HTTP应答头
- 计算机网络之HTTP代理服务器
- SMTP、POP3、NNTP、FTP、HTTP 的服务器指令(简表)
- VPS CentOS-6 下 LNMP HTTP服务器的搭建
- Android-SAX解析XML文件(http访问取回服务器XML)
- [转]Android采用FTP上传图片到服务器文件被损坏,原文地址http://blog.csdn.net/ybygjy/article/details/6450826
- Python高级 -- 05 网络(http协议、web服务器、tcp/ip协议、网络通信)