关键代码:
Url url = new url(fileurl);
HttpUrlConnection conn = (HttpUrlConnection)url.openConnection();
conn.connect();
BufferedOutputString out = new BufferedOutputString(conn.getOutputStream());
在本地,tomcat,和weblogic12都没有任何问题,唯独使用weblogic10,会出现Already connected错误。
最终发现weblogic10自带的jar中weblogic.net.http.HttpURLConnection类居然有bug。由于业务原因无法控制运行环境,决定解决这个问题。
先说解决办法:修改URL url = new URL(fileurl);为URL url = new URL(null,fileurl,new sun.net.www.protocol.http.Handle());解决!
方法分析:
(1)在url.openConnection()获得HttpUrlConnection时,会根据运行环境确定URLStreamHandler并调运不同的实现类。
(2)如果不指定URLStreamHandler,在weblogic环环境下会到weblogic.net.http.HttpURLConnection这个类,weblogic10提供的jar中该类getOutputStream()存在bug。
(3)在创建URL时直接使用带URLStreamHandler的构造方法,指定URLStreamHandler为sun包下的handler,就不会根据运行环境发生变化了,问题解决