2014-09-22 1268 views
5

我卡住在java.net.SocketInputStream.socketRead0(本地方法)。請參閱下面的線程轉儲,它已處於此狀態3小時。卡住在java.net.SocketInputStream.socketRead0(本地方法)

Thread-0" prio=10 tid=0x00007facd02a5000 nid=0x309 runnable [0x00007facd4a43000] 
java.lang.Thread.State: RUNNABLE 
    at java.net.SocketInputStream.socketRead0(Native Method) 
    at java.net.SocketInputStream.read(SocketInputStream.java:150) 
    at java.net.SocketInputStream.read(SocketInputStream.java:121) 
    at sun.security.ssl.InputRecord.readFully(InputRecord.java:442) 
    at sun.security.ssl.InputRecord.read(InputRecord.java:480) 
    at sun.security.ssl.SSLSocketImpl.readRecord(SSLSocketImpl.java:927) 
    - locked <0x00000000e34a0428> (a java.lang.Object) 
    at sun.security.ssl.SSLSocketImpl.readDataRecord(SSLSocketImpl.java:884) 
    at sun.security.ssl.AppInputStream.read(AppInputStream.java:102) 
    - locked <0x00000000e34a0590> (a sun.security.ssl.AppInputStream) 
    at java.io.BufferedInputStream.fill(BufferedInputStream.java:235) 
    at java.io.BufferedInputStream.read1(BufferedInputStream.java:275) 
    at java.io.BufferedInputStream.read(BufferedInputStream.java:334) 
    - locked <0x00000000e30408b8> (a java.io.BufferedInputStream) 
    at sun.net.www.http.HttpClient.parseHTTPHeader(HttpClient.java:633) 
    at sun.net.www.http.HttpClient.parseHTTP(HttpClient.java:579) 
    at sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLConnection.java:1322) 
    - locked <0x00000000e3031d00> (a sun.net.www.protocol.https.DelegateHttpsURLConnection) 
    at sun.net.www.protocol.https.HttpsURLConnectionImpl.getInputStream(HttpsURLConnectionImpl.java:254) 
    - locked <0x00000000e3031c80> (a sun.net.www.protocol.https.HttpsURLConnectionImpl) 

而且我已將連接超時和讀取超時設置爲URLConnection。請參閱下面的代碼片段。所以我不知道爲什麼它會掛在java.net.SocketInputStream.socketRead0。我偶爾會遇到這個問題。任何建議表示讚賞!

public String sendPost(String params) throws Throwable { 
PrintWriter out = null; 
String htmlContent = null; 
try 
{ 
    StringBuffer strBuffer = new StringBuffer(); 
    URL url = new URL(this.webUrl); 
    URLConnection urlConnection = url.openConnection(); 
    urlConnection.setConnectTimeout(3000); 
    urlConnection.setReadTimeout(3000); 

    urlConnection.setRequestProperty("accept", "*/*"); 
    urlConnection.setRequestProperty("connection", "Keep-Alive"); 
    urlConnection.setRequestProperty("user-agent", "***"); 

    urlConnection.setDoOutput(true); 
    urlConnection.setDoInput(true); 

    out = new PrintWriter(urlConnection.getOutputStream()); 
    out.print(params); 
    out.flush(); 

    BufferedReader bufferdReader = new BufferedReader(new InputStreamReader(urlConnection.getInputStream(), "utf-8")); 
    String readLine = null; 
     try { 
      while ((readLine = bufferdReader.readLine()) != null) { 
       strBuffer.append(readLine); 
      } 
     } catch (Throwable e) { 
      return htmlContent; 
     } 
     htmlContent = strBuffer.toString(); 
     bufferdReader.close(); 
+0

'連接:保持alive'是默認的。你不寫任何POST參數:這是故意的嗎? – EJP 2014-09-22 07:45:47

+0

謝謝@EJP,我只是將更多的代碼粘貼到代碼引用中,這是一個後期操作。請再次查看.. – BurningDocker 2014-09-22 07:59:00

+0

你有任何更新嗎?我有完全相同的問題 – HamoriZ 2014-11-20 14:18:42

回答

0

我認爲這是一個URLConnection的錯誤。使用套接字和超時對他們進行檢查。