我們模擬SSLSocket連接,請求博客園首頁,並打印響應消息。代碼引用來自《Java網絡編程精解》作者:孫衛琴
寫這篇博客為了說明模擬過程中出現的一些問題,模擬時請先在瀏覽器訪問目標路徑,F12查看網絡,查看原始的網絡請求頭。
注意:
1.HTTP請求報文包含請求行、請求頭部、空行、請求包體4個部分組成。
2.模擬請求頭部時Accept-Encoding不要使用壓縮,否則響應結果會出現亂碼
3.請求頭部結束使用回車換行符結束
代碼如下:
package com.beluga.hello.http; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; import java.net.Socket; public class TestHttpClient { Socket socket = null; public void createSocket() { try { socket = new Socket("www.javathinker.org", 80); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } } public void communcate() { // 注意這里必須制定請求方式 地址 注意空格 StringBuffer sb = new StringBuffer("GET http://www.javathinker.org/ HTTP/1.1\r\n"); // 以下為請求頭 sb.append("Host: www.javathinker.org\r\n"); sb.append("User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:53.0) Gecko/20100101 Firefox/53.0\r\n"); sb.append("Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8\r\n"); sb.append("Accept-Language: zh-CN,zh;q=0.8,en-US;q=0.5,en;q=0.3"); // 注意這里不要使用壓縮 否則返回亂碼 sb.append("Accept-Encoding: \r\n"); sb.append("Connection: keep-alive\r\n"); sb.append("Upgrade-Insecure-Requests: 1\r\n"); // 注意這里要換行結束請求頭 sb.append("\r\n"); System.out.println(sb.toString()); try { OutputStream os = socket.getOutputStream(); os.write(sb.toString().getBytes()); InputStream is = socket.getInputStream(); ByteArrayOutputStream baos = new ByteArrayOutputStream(); byte[] bytes = new byte[1024]; int len = -1; while ((len = is.read(bytes)) != -1) { baos.write(bytes, 0, len); } System.out.println(new String(baos.toByteArray())); socket.close(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } } public static void main(String[] args) { TestHttpClient client = new TestHttpClient(); client.createSocket(); client.communcate(); } }
喜歡請關注微信公眾號:碼農小麥