Java:HttpPost请求键值对,MD5加密

我们在请求三方提供接口,我们可以通过简单的访问,获取到对应的信息:

/**
 * <b>Function: </b> todo
 *
 * @program: Post请求
 * @Package: com.kingbal.king.dmp
 * @author: dingcho
 * @date: 2024/06/19
 * @version: 1.0
 * @Copyright: 2024 www.kingbal.com Inc. All rights reserved.
 */
@Slf4j
public class BaseTest {

	//正式环境
	private static final String WANG_ACCOUNT = "XXXXW";
	//测试
	private static final String TEST_WANG_ACCOUNT = "TESTXXXXW";

	public static String doPost(Map<String, String> params, String desc) {
		String url = BASE_URL;
		CloseableHttpResponse response = null;
		CloseableHttpClient httpClient = HttpClients.createDefault();
		HttpPost httpPost = new HttpPost(url);
		try {
			String userName = HttpsUtils.IS_TEST ? TEST_WANG_ACCOUNT : WANG_ACCOUNT;
			params.put("UserName", userName);
			// 大部分都有加密
			String sign = HttpsUtils.getSign(params);
			params.put("Sign", sign);
			httpPost.addHeader("Content-type", "application/x-www-form-urlencoded");
			List<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>();
			for (Map.Entry<String, String> map : params.entrySet()) {
				nameValuePairs.add(new BasicNameValuePair(map.getKey(), map.getValue()));
			}
			httpPost.setEntity(new UrlEncodedFormEntity(nameValuePairs, "UTF-8"));
			InputStream contents = httpPost.getEntity().getContent();
			InputStreamReader inputStreamReader = new InputStreamReader(contents, "UTF-8");
			BufferedReader bufferedReader = new BufferedReader(inputStreamReader);
			String readLine = bufferedReader.readLine();
			URLDecoder.decode(readLine, "UTF-8");
			response = httpClient.execute(httpPost);
			HttpEntity entity = response.getEntity();
			String content = "";
			if (entity != null) {
				content = EntityUtils.toString(entity, "UTF-8");
				log.info("\n" + "请求地址 >>> " + url
						+ "\n" + "描述 >>> " + desc
						+ "\n" + "参数 >>> " + JSONUtil.parse(params)
						+ "\n" + "返回值 >>> " + content);
				return content;
			}
		} catch (Exception e) {
			e.printStackTrace();
		}
		return "获取数据错误";
	}

}

 当请求接口需要加密的时候我们需要生成加密串:

/**
* 获取加密排序、加密
*
* @param params
* @return
*/
public static String getSign(Map<String, String> params) {
	Collection<String> keySet = params.keySet();
	List<String> list = new ArrayList<>(keySet);
	Collections.sort(list);
	StringBuffer sbf = new StringBuffer();
	for (Object key : list) {
		sbf.append(params.get(key));
	}
	String sortStr = sbf.toString() + (IS_TEST ? TEST_PRIVATE_KEY : PRIVATE_KEY);
	log.error(sortStr);
	String result = MD5Utils.encrypt(sortStr);
	log.error(result);
	return result;
}

MD5Utils算法:

@Slf4j
public class MD5Utils {

	/**
	 * 获取指定字符串的md5值
	 * @param dataStr 明文
	 * @return String
	 */
	public static String encrypt(String dataStr) {
		try {
			MessageDigest m = MessageDigest.getInstance("MD5");
			m.update(dataStr.getBytes("UTF8"));
			byte[] s = m.digest();
			StringBuilder result = new StringBuilder();
			for (int i = 0; i < s.length; i++) {
				result.append(Integer.toHexString((0x000000FF & s[i]) | 0xFFFFFF00).substring(6));
			}
			return result.toString();
		}
		catch (Exception e) {
			log.error("error", e);
		}
		return "";
	}

}
  • 12
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 JSP 中对登录时的 POST 请求参数进行 MD5 加密,可以使用以下代码: ```java <% String username = request.getParameter("username"); // 获取 username 参数值 String password = request.getParameter("password"); // 获取 password 参数值 String passwordMD5 = ""; // 用于存储加密后的密码 if (password != null && !password.equals("")) { // 将密码进行 MD5 加密 MessageDigest md5 = MessageDigest.getInstance("MD5"); byte[] bytes = md5.digest(password.getBytes()); StringBuilder sb = new StringBuilder(); for (byte b : bytes) { sb.append(String.format("%02X", b)); } passwordMD5 = sb.toString(); } // 构造加密后的参数 String encryptedUsername = java.net.URLEncoder.encode(username, "UTF-8"); String encryptedPassword = java.net.URLEncoder.encode(passwordMD5, "UTF-8"); %> <form action="login.jsp" method="post"> <input type="text" name="username" value="<%=encryptedUsername%>"> <input type="password" name="password" value="<%=encryptedPassword%>"> <input type="submit" value="登录"> </form> ``` 其中,`request.getParameter("username")` 和 `request.getParameter("password")` 用于获取 POST 请求中的用户名和密码参数值,将密码进行 MD5 加密的代码与上面的例子相同,不再赘述。然后,构造加密后的参数值,使用 `java.net.URLEncoder.encode` 方法进行 URL 编码。 最后,将加密后的参数值设置到表单的输入框中,用户提交表单时,将会提交加密后的参数。在服务器端接收到请求后,需要对参数进行解密和校验,确保用户名和密码的正确性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值