java用HttpURLConnection发起HTTP/HTTPS请求

MyX509TrustManager.java
package com.demo.until;

import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.net.HttpURLConnection;
import java.net.URL;
import java.security.cert.CertificateException;
import java.security.cert.X509Certificate;

import javax.net.ssl.HttpsURLConnection;
import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLSocketFactory;
import javax.net.ssl.TrustManager;
import javax.net.ssl.X509TrustManager;

public class MyX509TrustManager implements X509TrustManager {
	@Override
	public void checkClientTrusted(X509Certificate[] chain, String authType)
			throws CertificateException {
		// TODO Auto-generated method stub

	}

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

	}

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

	// 处理http请求 requestUrl为请求地址 requestMethod请求方式,值为"GET"或"POST"
	public static String httpRequest(String requestUrl, String requestMethod,
			String outputStr) {

		StringBuffer buffer = null;
		try {
			URL url = new URL(requestUrl);// 请求地址
			HttpURLConnection conn = (HttpURLConnection) url.openConnection();// 创建连接对象
			conn.setDoOutput(true);// 是否输出
			conn.setDoInput(true);// 是否输入
			conn.setRequestMethod(requestMethod);// post Or get
			conn.setRequestProperty("Charset", "utf-8");
			conn.setFollowRedirects(false);
			conn.setInstanceFollowRedirects(false);
			conn.connect();// 发起连接
			// 往服务器端写内容 也就是发起http请求需要带的参数
			if (null != outputStr) {
				OutputStream os = conn.getOutputStream();
				os.write(outputStr.getBytes("utf-8"));
				os.close();
			}

			// 读取服务器端返回的内容
			// PrintWriter out = new PrintWriter(new
			// OutputStreamWriter(conn.getOutputStream(),"utf-8"));
			// out.println(obj);

			InputStream is = conn.getInputStream();
			InputStreamReader isr = new InputStreamReader(is, "UTF-8");
			BufferedReader br = new BufferedReader(isr);
			buffer = new StringBuffer();
			String line = null;
			while ((line = br.readLine()) != null) {
				buffer.append(line);
			}

		} catch (Exception e) {
			e.printStackTrace();
		}
		return buffer.toString();
	}

	/*
	 * 处理https GET/POST请求 请求地址、请求方法、参数
	 */
	public static String httpsRequest(String requestUrl, String requestMethod,
			String outputStr) {
		StringBuffer buffer = null;
		try {
			// 创建SSLContext
			SSLContext sslContext = SSLContext.getInstance("SSL");
			TrustManager[] tm = { new MyX509TrustManager() };
			// 初始化
			sslContext.init(null, tm, new java.security.SecureRandom());
			;
			// 获取SSLSocketFactory对象
			SSLSocketFactory ssf = sslContext.getSocketFactory();
			URL url = new URL(requestUrl);
			HttpsURLConnection conn = (HttpsURLConnection) url.openConnection();
			conn.setDoOutput(true);
			conn.setDoInput(true);
			conn.setUseCaches(false);
			conn.setRequestMethod(requestMethod);
			// 设置当前实例使用的SSLSoctetFactory
			conn.setSSLSocketFactory(ssf);
			conn.connect();
			// 往服务器端写内容
			if (null != outputStr) {
				OutputStream os = conn.getOutputStream();
				os.write(outputStr.getBytes("utf-8"));
				os.close();
			}
			// 读取服务器端返回的内容
			InputStream is = conn.getInputStream();
			InputStreamReader isr = new InputStreamReader(is, "gbk");
			BufferedReader br = new BufferedReader(isr);
			buffer = new StringBuffer();
			String line = null;
			while ((line = br.readLine()) != null) {
				buffer.append(line);
			}
		} catch (Exception e) {
			e.printStackTrace();
		}
		return buffer.toString();
	}

	public static void main(String[] args) {
		//测试
		String testUrl = "https://tcc.taobao.com/cc/json/mobile_tel_segment.htm?tel=xxxxxx";//淘宝获取手机号信息接口
		String url = "地址";
		String s = httpsRequest(url, "POST", null);
		System.out.println(s);
	}
}

使用

这里测试的是小程序获取openid

        // 用code发起请求并获取oepnId
		MyX509TrustManager mx = new MyX509TrustManager();
		String s = mx
				.httpsRequest(
						"https://api.weixin.qq.com/sns/jscode2session?appid=''&secret=''&js_code=''
							&grant_type=authorization_code",
						"POST", null);
		//转JSON
		Gson gson = new Gson();
		Map<String, Object> map = new HashMap<String, Object>();
		map = gson.fromJson(s, map.getClass());
		String openId = (String) map.get("openid");
您好!对于 "unable to find valid certification path to requested target" 错误,通常是由于请求的目标服务器使用了自签名或无效的证书,导致 Java 无法验证证书的合法性。 解决此问题的一种方法是将目标服务器的证书添加到 Java 信任库中。您可以按照以下步骤进行操作: 1. 打开命令提示符或终端窗口。 2. 使用以下命令导航到 Java 安装目录下的 "bin" 文件夹: ``` cd <Java_Installation_Directory>\bin ``` 3. 使用以下命令运行 "keytool" 工具来导出目标服务器的证书: ``` keytool -export -alias <alias> -keystore <keystore_file> -file <output_file> ``` 其中,`<alias>` 是证书别名,`<keystore_file>` 是信任库文件路径,`<output_file>` 是导出的证书文件路径。您可以根据实际情况进行替换。 4. 根据您的操作系统和 Java 版本,将目标服务器的证书导入到 Java 信任库中。以下是几个常见的命令示例: - 对于 Windows: ``` keytool -import -v -trustcacerts -alias <alias> -file <certificate_file> -keystore "%JAVA_HOME%\lib\security\cacerts" ``` 其中,`<alias>` 是证书别名,`<certificate_file>` 是之前导出的证书文件路径。请确保在命令中使用正确的 Java 安装路径。 - 对于 macOS 和 Linux: ``` keytool -import -v -trustcacerts -alias <alias> -file <certificate_file> -keystore $JAVA_HOME/lib/security/cacerts ``` 同样地,`<alias>` 是证书别名,`<certificate_file>` 是之前导出的
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值