https和http协议接口post请求接口方法

转载 2017年08月12日 23:11:59
一、只针对http 的post请求
package test;

import java.io.InputStreamReader;
import java.net.URI;

import net.sf.json.JSONObject;

import org.apache.http.Header;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.entity.StringEntity;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.util.EntityUtils;

public class HttpClientRequest {

public static String post(String url,JSONObject json, String token){
String result = null;
        HttpClient client = new DefaultHttpClient();  
        HttpPost request;  
        try {  
            request = new HttpPost(new URI(url)); 
            if(json != null){
            StringEntity s = new StringEntity(json.toString(),"utf-8");
s.setContentType("application/json");
request.setEntity(s);
            }
            if(token != null){
            request.setHeader("token", token);
            }
            
            HttpResponse response = client.execute(request); 
            int returncode = response.getStatusLine().getStatusCode();
            System.out.println("Response Code:"+returncode);
            if (returncode == 200) {
            Header[] header = response.getHeaders("token");
            if(header.length >0){
            for(Header h:header){
            System.out.println(h.getName()+" "+h.getValue());
            }
            }
            HttpEntity entity = response.getEntity();
            long contentLen = entity.getContentLength();
            if(contentLen == 0){
            return "User Has No Authority";
            }
String charset = EntityUtils.getContentCharSet(entity);
InputStreamReader isr = new InputStreamReader(entity.getContent(), charset);
StringBuffer sb = new StringBuffer();
char[] ct = new char[64];
int len = 0;
while((len = isr.read(ct))!=-1){
String sst = new String(ct);
sst = sst.substring(0, len).trim();
sb.append(sst);
}
result = sb.toString().replace("\\\"", "\"");
result = result.substring(1, result.length()-1);
            }
        } catch(Exception e) {
        e.printStackTrace();
        }
        return result;
}
}


二、针对https和http都可以的post请求
package https;

import java.io.BufferedReader;
import java.io.ByteArrayOutputStream;
import java.io.DataOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.net.FileNameMap;
import java.net.MalformedURLException;
import java.net.URI;
import java.net.URISyntaxException;
import java.net.URL;
import java.security.KeyManagementException;
import java.security.NoSuchAlgorithmException;
import java.security.NoSuchProviderException;
import java.security.cert.CertificateException;
import java.security.cert.X509Certificate;
import java.util.List;
import java.util.Map;

import javax.net.ssl.HostnameVerifier;
import javax.net.ssl.HttpsURLConnection;
import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLSession;
import javax.net.ssl.TrustManager;
import javax.net.ssl.X509TrustManager;

import net.sf.json.JSONObject;

import org.apache.commons.httpclient.ProtocolException;
import org.apache.commons.httpclient.methods.PostMethod;
import org.apache.http.Header;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.conn.scheme.Scheme;
import org.apache.http.conn.ssl.SSLSocketFactory;
import org.apache.http.entity.HttpEntityWrapper;
import org.apache.http.entity.StringEntity;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.util.EntityUtils;

public class HttpsUtil{
static class TrustAnyTrustManager implements X509TrustManager{

@Override
public void checkClientTrusted(X509Certificate[] arg0, String arg1)
throws CertificateException {
// TODO Auto-generated method stub
}

@Override
public void checkServerTrusted(X509Certificate[] arg0, String arg1)
throws CertificateException {
// TODO Auto-generated method stub
}

@Override
public X509Certificate[] getAcceptedIssuers() {
// TODO Auto-generated method stub
return null;
}
}
static class TrustAnyHostnameVerifier implements HostnameVerifier{

@Override
public boolean verify(String arg0, SSLSession arg1) {
// TODO Auto-generated method stub
return true;
}
}
/**
* post方式请求服务器(https协议)
* @param url
*            请求地址
* @param content
*            参数
* @param charset
*            编码
* @return
 * @throws URISyntaxException 
* @throws NoSuchAlgorithmException
* @throws KeyManagementException
* @throws IOException
*/
static public String SendHttpsPOST(String url,JSONObject json, String token) throws URISyntaxException 
String result = null;
        HttpClient client = new DefaultHttpClient();  
        HttpPost request;  
        try {  
            request = new HttpPost(new URI(url)); 
            if(json != null){
            StringEntity s = new StringEntity(json.toString(),"utf-8");
s.setContentType("application/json");
request.setEntity(s);
            }
            if(token != null){
            request.setHeader("token", token);
            }
            //设置SSLContext 
            SSLContext sslcontext = SSLContext.getInstance("TLS"); 
            sslcontext.init(null, new TrustManager[]{new TrustAnyTrustManager()}, null);

            //打开连接
        //要发送的POST请求url?Key=Value&Key2=Value2&Key3=Value3的形式 
            SSLSocketFactory socketFactory = new SSLSocketFactory(sslcontext); 
            
            client.getConnectionManager().getSchemeRegistry().register(new Scheme("https", 443, socketFactory)); 
            HttpResponse response = client.execute(request); 
            int returncode = response.getStatusLine().getStatusCode();
            System.out.println("Response Code:"+returncode);           
           
            if (returncode == 200) {
            Header[] header = response.getHeaders("token");
            if(header.length >0){
            for(Header h:header){
            System.out.println(h.getName()+" "+h.getValue());
            }
            }
            HttpEntity entity = response.getEntity();
            long contentLen = entity.getContentLength();
            if(contentLen == 0){
            return "User Has No Authority";
            }
String charset = EntityUtils.getContentCharSet(entity);
InputStreamReader isr = new InputStreamReader(entity.getContent(), charset);
StringBuffer sb = new StringBuffer();
char[] ct = new char[64];
int len = 0;
while((len = isr.read(ct))!=-1){
String sst = new String(ct);
sst = sst.substring(0, len).trim();
sb.append(sst);
}
result = sb.toString().replace("\\\"", "\"");
result = result.substring(1, result.length()-1);
            } 
        } catch (KeyManagementException e) { 
            e.printStackTrace(); 
        } catch (NoSuchAlgorithmException e) { 
            e.printStackTrace(); 
        } catch (MalformedURLException e) { 
            e.printStackTrace(); 
        } catch (ProtocolException e) { 
            e.printStackTrace(); 
        } catch (IOException e) { 
            e.printStackTrace(); 
        }
        return result; 
      
}
}

相关文章推荐

JAVA利用HttpClient进行POST请求(HTTPS)

目前,要为另一个项目提供接口,接口是用HTTP URL实现的,最初的想法是另一个项目用JQuery post进行请求。 但是,很可能另一个项目是部署在别的机器上,那么就存在跨域问题,而JQuery的...

LR访问Https接口

http://mp.weixin.qq.com/s/c2Eze_GwxENwpDQObbFUKA

http接口开发与调用案例

http接口开发与调用案例

整理了一下,真正可用的免费的https、http接口,测试接口可以使用

我搜了一下开放式的接口,往上大同小异,基本上都是抄来抄去,有些接口早就不能用了,也是直接转载,我做了一下排除,留下了真正的能用的一些免费接口,希望能对大家有所帮助吧。这些接口截至2017.3.10 发...

深入分析ConcurrentHashMap的锁分段技术

术语定义 术语 英文 解释 哈希算法 ...

tomcat+https协议的接口编写及客户端访问

https协议的接口编写及客户端访问

http接口开发及调用

一般用post; package com.XXXX.XXXX.service; import java.io.File; import java.io.IOException; import ja...

Android客户端与Java tomcat之间HTTPS通讯

Android客户端与Java tomcat之间HTTPS通讯,并实现post传值

https+xml服务端/客户端java后台编写及soapUI https测试

目录(?)[-] 一httpsxml服务端编写 1 创建证书文件 11 创建服务器KeyStore12 导出服务端证书13 创建客户端KeyStore14 导出客户端Cer证书15 ...

HTTPS接口加密和身份认证(转)

HTTPS接口加密和身份认证 对HTTPS研究有一段时间了,在这里写下一些收集的资料和自己的理解。有不对的地方希望斧正。1.为什么要使用HTTPS代替HTTP1.1HTTPS和HTTP的区别 http...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)