httpf發送 json_Java用HttpClient3發送http/https協議get/post請求,發送map,json,xml,txt數據...

使用的是httpclient 3.1,

使用"httpclient"4的寫法相對簡單點,百度:httpclient https post

當不需要使用任何證書訪問https網頁時,只需配置信任任何證書

其中信任任何證書的類MySSLProtocolSocketFactory

主要代碼:

HttpClient client = new HttpClient();

Protocol myhttps = new Protocol("https", new MySSLProtocolSocketFactory(), 443);

Protocol.registerProtocol("https", myhttps);

PostMethod method = new PostMethod(url);

HttpUtil

package com.urthinker.wxyh.util;

import java.io.BufferedReader;

import java.io.IOException;

import java.io.InputStreamReader;

import java.util.Map;

import org.apache.commons.httpclient.HttpClient;

import org.apache.commons.httpclient.HttpMethod;

import org.apache.commons.httpclient.HttpStatus;

import org.apache.commons.httpclient.URIException;

import org.apache.commons.httpclient.methods.GetMethod;

import org.apache.commons.httpclient.methods.PostMethod;

import org.apache.commons.httpclient.methods.RequestEntity;

import org.apache.commons.httpclient.methods.StringRequestEntity;

import org.apache.commons.httpclient.params.HttpMethodParams;

import org.apache.commons.httpclient.protocol.Protocol;

import org.apache.commons.httpclient.util.URIUtil;

import org.apache.commons.lang.StringUtils;

import org.apache.commons.logging.Log;

import org.apache.commons.logging.LogFactory;

/**

* HTTP工具類

* 發送http/https協議get/post請求,發送map,json,xml,txt數據

*

* @author happyqing 2016-5-20

*/

public final class HttpUtil {

private static Log log = LogFactory.getLog(HttpUtil.class);

/**

* 執行一個http/https get請求,返回請求響應的文本數據

*

* @param url請求的URL地址

* @param queryString請求的查詢參數,可以為null

* @param charset字符集

* @param pretty是否美化

* @return返回請求響應的文本數據

*/

public static String doGet(String url, String queryString, String charset, boolean pretty) {

StringBuffer response = new StringBuffer();

HttpClient client = new HttpClient();

if(url.startsWith("https")){

//https請求

Protocol myhttps = new Protocol("https", new MySSLProtocolSocketFactory(), 443);

Protocol.registerProtocol("https", myhttps);

}

HttpMethod method = new GetMethod(url);

try {

if (StringUtils.isNotBlank(queryString))

//對get請求參數編碼,漢字編碼后,就成為%式樣的字符串

method.setQueryString(URIUtil.encodeQuery(queryString));

client.executeMethod(method);

if (method.getStatusCode() == HttpStatus.SC_OK) {

BufferedReader reader = new BufferedReader(new InputStreamReader(method.getResponseBodyAsStream(), charset));

String line;

while ((line = reader.readLine()) != null) {

if (pretty)

response.append(line).append(System.getProperty("line.separator"));

else

response.append(line);

}

reader.close();

}

} catch (URIException e) {

log.error("執行Get請求時,編碼查詢字符串“" + queryString + "”發生異常!", e);

} catch (IOException e) {

log.error("執行Get請求" + url + "時,發生異常!", e);

} finally {

method.releaseConnection();

}

return response.toString();

}

/**

* 執行一個http/https post請求,返回請求響應的文本數據

*

* @param url請求的URL地址

* @param params請求的查詢參數,可以為null

* @param charset字符集

* @param pretty是否美化

* @return返回請求響應的文本數據

*/

public static String doPost(String url, Map params, String charset, boolean pretty) {

StringBuffer response = new StringBuffer();

HttpClient client = new HttpClient();

if(url.startsWith("https")){

//https請求

Protocol myhttps = new Protocol("https", new MySSLProtocolSocketFactory(), 443);

Protocol.registerProtocol("https", myhttps);

}

PostMethod method = new PostMethod(url);

//設置參數的字符集

method.getParams().setParameter(HttpMethodParams.HTTP_CONTENT_CHARSET,charset);

//設置post數據

if (params != null) {

//HttpMethodParams p = new HttpMethodParams();

for (Map.Entry entry : params.entrySet()) {

//p.setParameter(entry.getKey(), entry.getValue());

method.setParameter(entry.getKey(), entry.getValue());

}

//method.setParams(p);

}

try {

client.executeMethod(method);

if (method.getStatusCode() == HttpStatus.SC_OK) {

BufferedReader reader = new BufferedReader(new InputStreamReader(method.getResponseBodyAsStream(), charset));

String line;

while ((line = reader.readLine()) != null) {

if (pretty)

response.append(line).append(System.getProperty("line.separator"));

else

response.append(line);

}

reader.close();

}

} catch (IOException e) {

log.error("執行Post請求" + url + "時,發生異常!", e);

} finally {

method.releaseConnection();

}

return response.toString();

}

/**

* 執行一個http/https post請求, 直接寫數據 json,xml,txt

*

* @param url請求的URL地址

* @param params請求的查詢參數,可以為null

* @param charset字符集

* @param pretty是否美化

* @return返回請求響應的文本數據

*/

public static String writePost(String url, String content, String charset, boolean pretty) {

StringBuffer response = new StringBuffer();

HttpClient client = new HttpClient();

if(url.startsWith("https")){

//https請求

Protocol myhttps = new Protocol("https", new MySSLProtocolSocketFactory(), 443);

Protocol.registerProtocol("https", myhttps);

}

PostMethod method = new PostMethod(url);

try {

//設置請求頭部類型參數

//method.setRequestHeader("Content-Type","text/plain; charset=utf-8");//application/json,text/xml,text/plain

//method.setRequestBody(content); //InputStream,NameValuePair[],String

//RequestEntity是個接口,有很多實現類,發送不同類型的數據

RequestEntity requestEntity = new StringRequestEntity(content,"text/plain",charset);//application/json,text/xml,text/plain

method.setRequestEntity(requestEntity);

client.executeMethod(method);

if (method.getStatusCode() == HttpStatus.SC_OK) {

BufferedReader reader = new BufferedReader(new InputStreamReader(method.getResponseBodyAsStream(), charset));

String line;

while ((line = reader.readLine()) != null) {

if (pretty)

response.append(line).append(System.getProperty("line.separator"));

else

response.append(line);

}

reader.close();

}

} catch (Exception e) {

log.error("執行Post請求" + url + "時,發生異常!", e);

} finally {

method.releaseConnection();

}

return response.toString();

}

public static void main(String[] args) {

try {

String y = doGet("http://video.sina.com.cn/life/tips.html", null, "GBK", true);

System.out.println(y);

// Map params = new HashMap();

// params.put("param1", "value1");

// params.put("json", "{\"aa\":\"11\"}");

// String j = doPost("http://localhost/uplat/manage/test.do?reqCode=add", params, "UTF-8", true);

// System.out.println(j);

} catch (Exception e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

}

}

MySSLProtocolSocketFactory

import java.io.IOException;

import java.net.InetAddress;

import java.net.InetSocketAddress;

import java.net.Socket;

import java.net.SocketAddress;

import java.net.UnknownHostException;

import java.security.KeyManagementException;

import java.security.NoSuchAlgorithmException;

import java.security.cert.CertificateException;

import java.security.cert.X509Certificate;

import javax.net.SocketFactory;

import javax.net.ssl.SSLContext;

import javax.net.ssl.TrustManager;

import javax.net.ssl.X509TrustManager;

import org.apache.commons.httpclient.ConnectTimeoutException;

import org.apache.commons.httpclient.params.HttpConnectionParams;

import org.apache.commons.httpclient.protocol.ProtocolSocketFactory;

/**

* author by lpp

*

* created at 2010-7-26 上午09:29:33

*/

public class MySSLProtocolSocketFactory implements ProtocolSocketFactory {

private SSLContext sslcontext = null;

private SSLContext createSSLContext() {

SSLContext sslcontext = null;

try {

// sslcontext = SSLContext.getInstance("SSL");

sslcontext = SSLContext.getInstance("TLS");

sslcontext.init(null,

new TrustManager[] { new TrustAnyTrustManager() },

new java.security.SecureRandom());

} catch (NoSuchAlgorithmException e) {

e.printStackTrace();

} catch (KeyManagementException e) {

e.printStackTrace();

}

return sslcontext;

}

private SSLContext getSSLContext() {

if (this.sslcontext == null) {

this.sslcontext = createSSLContext();

}

return this.sslcontext;

}

public Socket createSocket(Socket socket, String host, int port, boolean autoClose)

throws IOException, UnknownHostException {

return getSSLContext().getSocketFactory().createSocket(socket, host, port, autoClose);

}

public Socket createSocket(String host, int port) throws IOException, UnknownHostException {

return getSSLContext().getSocketFactory().createSocket(host, port);

}

public Socket createSocket(String host, int port, InetAddress clientHost, int clientPort)

throws IOException, UnknownHostException {

return getSSLContext().getSocketFactory().createSocket(host, port, clientHost, clientPort);

}

public Socket createSocket(String host, int port, InetAddress localAddress,

int localPort, HttpConnectionParams params) throws IOException,

UnknownHostException, ConnectTimeoutException {

if (params == null) {

throw new IllegalArgumentException("Parameters may not be null");

}

int timeout = params.getConnectionTimeout();

SocketFactory socketfactory = getSSLContext().getSocketFactory();

if (timeout == 0) {

return socketfactory.createSocket(host, port, localAddress, localPort);

} else {

Socket socket = socketfactory.createSocket();

SocketAddress localaddr = new InetSocketAddress(localAddress, localPort);

SocketAddress remoteaddr = new InetSocketAddress(host, port);

socket.bind(localaddr);

socket.connect(remoteaddr, timeout);

return socket;

}

}

// 自定義私有類

private static class TrustAnyTrustManager implements X509TrustManager {

public void checkClientTrusted(X509Certificate[] chain, String authType) throws CertificateException {

}

public void checkServerTrusted(X509Certificate[] chain, String authType) throws CertificateException {

}

public X509Certificate[] getAcceptedIssuers() {

return new X509Certificate[] {};

}

}

}

參考:

httpclient 4 https請求

百度:httpclient https post

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/260367.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/260367.shtml
英文地址,請注明出處:http://en.pswp.cn/news/260367.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

分頁優化的四種方式

轉自:http://www.orczhou.com/index.php/2009/03/four-way-pager-display/ 很久以前讀了一篇關于分頁的文章,后來越想越有道理,最近又重新找出來,并做了翻譯,原文參考:Four ways to optimize paginated displays. 翻譯…

使用 VMControl 2.4 實現多網絡的 Power 服務器捕捉和系統部署

VMControl 作為 IBM Systems Director 的一個高級管理器,提供了一系列的管理功能幫助 Power 管理員快速捕獲部署虛擬機系統,進行虛擬化環境的管理。而現代的數據中心,出于安全性,網路負載等多重因素的考慮,一般會存在有…

windows python安裝_window 安裝 python

官網地址下載安裝包點擊下載 會自動識別你當前的系統,或者點擊你需要安裝的平臺或者選擇其他版本執行安裝高級選項說明:Install for all users 所有用戶可使用Associate files with Python 關聯PY相關的文件Create shortcuts for installed applications…

iOS應用內付費(IAP)開發步驟列表

iOS應用內付費(IAP)開發步驟列表 前兩天和服務端同事一起,完成了應用內付費(以下簡稱IAP, In app purchase)的開發工作。步驟繁多,在此把開發步驟列表整理如下。因為只是步驟列表,所以并不含詳細的說明教程&#xff0c…

【unity3d--初始學習五--c#腳本對xml文件的創建和解析】

本人用c#編寫腳本。 創建xml文件時&#xff0c;主要用到System.Xml包中的XmlDocument,XmlNode,XmlElement。下面是創建xml文檔的一般步驟&#xff1a; XmlDocument docnew XmlDocument(); //<?xml version"1.0"?> XmlNode xmlnoddoc.CreateNode(XmlNodeType.…

python計算機視覺編程(全)(強烈推薦)_推薦一個計算機視覺圖書:python計算機視覺編程...

編輯部的主頁&#xff1a;好像沒啥用每章的代碼&#xff0c;github上面的&#xff1a;中文版github上面&#xff0c;英文版&#xff1a;項目主頁&#xff1a;中文在線的書&#xff1a;然后下載安裝安裝好了以后&#xff0c;點擊自動的編輯器&#xff1a;新建工程&#xff0c;插…

mysql工具的使用_產品操作MySQL入門篇-工具使用

MYSQL本資料為產品崗位作為日常工作參考&#xff0c;語言口語化At 2019/4/15 By David.Yang數據庫怎么登錄/管理&#xff1f;登錄數據庫的方式有多種&#xff0c;比如本地Client登錄、通過數據庫管理工具登錄、通過瀏覽器訪問數據庫端WEB軟件登錄。通過各種方式登錄后&#xff…

在windows下運行spark

1.下載spark:spark-2.0.0-bin-hadoop2.7.tgz 2.解壓至D:\bigdata\spark-2.0.0-bin-hadoop2.7 3.配置環境變量 HADOOP_HOME:D:\bigdata\hadoop-2.7.2 SPARK_HOME:D:\bigdata\spark-2.0.0-bin-hadoop2.7 Path中添加&#xff1a;%HADOOP_HOME%\bin;%SPARK_HOME%\bin; 4.運行 先運行…

UIView使用UIMotionEffect效果

UIView使用UIMotionEffect效果 這個效果在模擬器上看不了,所以無法截圖. UIViewMotionEffect.h UIViewMotionEffect.m // // UIViewMotionEffect.h // // Copyright (c) 2014年 Nick Jensen. All rights reserved. //#import <UIKit/UIKit.h>interface UIView (Moti…

JavaSE_04異常處理

1. exception [ksep()n; ek-] n. 例外&#xff1b;異議 2. throw [θr] vt. 投&#xff1b;拋&#xff1b;擲 vi. 拋&#xff1b;投擲 n. 投擲&#xff1b;冒險 3. throws [θrz] n. 曲拐&#xff08;throw的復數形式&#xff09; v. 投&#xff1b;拋&#xff08;throw的三單形…

關于html和javascript在瀏覽器中的加載順序問題的討論

轉自&#xff1a;http://www.cnblogs.com/beyondstorm/archive/2008/09/17/1292940.html 前一陣子橫掃了javascript&#xff0c;當時自我感覺良好。現在一想&#xff0c;又覺得沒什么。今天的任務是把asp.net ajax中客戶端頁面生命周期那一章研究完。然而&#xff0c;因為這一章…

java 觀察者模式_Java技術干貨分享:深入理解觀察者模式原理與技術

來源&#xff1a;編程技術精選觀察者模式(Observer Pattern)也叫做發布-訂閱(Publish/Subscribe)模式、模型-視圖(Model/View)模式。這個模式的一個最重要的作用就是解耦。也就是將被觀察者和觀察者進行解耦&#xff0c;使得他們之間的依賴性更小&#xff0c;甚至做到毫無依賴。…

python導入pyecharts錯誤沒有pyecharts_python報No module named 'pyecharts'的錯誤怎么辦?

問&#xff1a;導包的時候報No module named pyecharts的錯誤怎么辦&#xff1f;答&#xff1a;報上述錯誤一般是因為pyecharts這個包沒有下載成功&#xff0c;下面給大家介紹一下pyecharts庫的安裝與使用方法&#xff01;pyecharts是Python的數據可視化庫&#xff0c;可以幫助…

iOS開發:AFNetworking、MKNetworkKit和ASIHTTPRequest比較

轉&#xff1a;http://www.xue5.com/Mobile/iOS/747036.html 之前一直在使用ASIHTTPRequest作為網絡庫&#xff0c;但是由于其停止更新&#xff0c;iOS7上可能出現更多的問題&#xff0c;于是決定更換網絡庫。 目前比較流行的網絡庫主要有AFNetworking和MKNetworkKit&#xff…

java .listfiles_Java File.listFiles()

全屏Java Java File.listFiles()方法具有以下語法。public File [] listFiles()示例在下面的代碼顯示如何使用File.listFiles()方法。import java.io.File;// At: W w W. y I i ba I.C o mpublic class Main {public static void main(String[] args) {// create new fileFile …

基礎入門_Python-內建函數.運維開發中eval內建函數的最佳實踐?

簡單介紹:說明: 在指定命名空間中計算參數字符串的有效表達式,并返回一個對象,Help on built-in function eval in module __builtin__:eval(...)eval(source[, globals[, locals]]) -> valueEvaluate the source in the context of globals and locals.The source may be a…

java簡單畢設_計算機畢業設計之自定義畢設課題需要如何確定工作量

“ 真正讓導師滿意的不是眾多普通的功能&#xff0c;而是那一抹有創意的充滿著生活氣息的小功能。”自定義畢設課題&#xff0c;我覺得這是一種體現學生創新的一種很好的手段&#xff0c;但是有一些學生卻因為腦海中沒有積累足夠多的專業知識以及也沒有對現實生活進行足夠的思考…

C#基礎系列第五篇

前言&#xff1a; 完全是我在學習過程中記錄的筆記&#xff0c;只不過分享一下讓很多剛開始學習.net編程的人能夠很快的學會C#語言 多態的一些說明(1) 多態就是為了程序的可擴展性 (2)多態的使用&#xff1a;將不同的對象當作父類來看&#xff0c;屏蔽掉各個對象間的不同&#…

羅伯特·帕丁森Robert Pattinson(2)

2019獨角獸企業重金招聘Python工程師標準>>> 轉載于:https://my.oschina.net/Bettyty/blog/756873

網博士自助建站系統_自助建站:自助建站到底好還是不好?

自助建站到底好還是不好&#xff1f;很多想要做企業網站的企業都比較關心這個問題&#xff0c;因為自助建站便宜、快&#xff0c;有的自助建站做出來的效果還非常好&#xff0c;不輸于定制的網站的效果&#xff0c;那為什么自助建站大都還很便宜呢&#xff1f;東西還好還便宜的…