Java编程Post数据请求和接收代码详解

 更新时间:2017年11月20日 16:43:34   作者:白天的猫头鹰  
这篇文章主要介绍了Java编程Post数据请求和接收代码详解,涉及enctype的三种编码,post与get等相关内容,具有一定参考价值,需要的朋友可以了解下。

这两天在做http服务端请求操作,客户端post数据到服务端后,服务端通过request.getParameter()进行请求,无法读取到数据,搜索了一下发现是因为设置为text/plain模式才导致读取不到数据

urlConn.setRequestProperty("Content-Type","text/plain; charset=utf-8"); 

若设置为以下方式,则通过request.getParameter()可以读取到数据

urlConn.setRequestProperty("Content-Type","application/x-www-form-urlencoded"); 

enctype的三种编码

form表单中enctype属性可以用来控制对表单数据的发送前的如何进行编码,即在发送到服务器之前,所有字符都会进行编码(空格转换为"+"加号,特殊符号转换为ASCIIHEX值)。默认是application/x-www-form-urlencoded。

multipart/form-data用于发送二进制的文件,其他两种类型不能用于发送文件

text/plain用于发送纯文本内容,不对特殊字符进行编码,一般用于email之类的。

application/x-www-form-urlencoded和text/plain的区别简单讲就是一个发送html内容,一个发送纯文本内容

application/x-www-form-urlencoded在发送前编码所有字符(默认)

multipart/form-data不对字符编码。在使用包含文件上传控件的表单时,必须使用该值。

text/plain空格转换为"+"加号,但不对特殊字符编码。

当定义enctype为application/x-www-form-urlencoded时,使用以下方式接收数据

request.getParameter(参数名); 

当定义enctype为text/plain时,使用以下方式接收数据

    // 接收请求数据
    BufferedReader reader = request.getReader();
    char[] buf = new char[512];
    int len = 0;
    StringBuffer contentBuffer = new StringBuffer();
    while ((len = reader.read(buf)) != -1) {
      contentBuffer.append(buf, 0, len);
    }
        String content = contentBuffer.toString();
        
        if(content == null){
            content = "";
        }

post与get

tp请求在所有的编程语言中几乎都是支持的,我们常用的两种为:GET,POST请求。一般情况下,发送一个GET请求都很简单,因为参数直接放在请求的URL上,对于POST请求,由于其数据是在消息体中发送出去的,所以相对来说要麻烦一点,再涉及到需要发送文件等二进制的数据类型,就更需要更多的处理。

post和get可以通过键值对的方式进行参数传输,服务端通过request.getparameter方式进行请求获取数据。

客户端post数据到服务端,服务端接收处理

public class UrlConnection {
	@SuppressWarnings("finally") 
	  public static Boolean response(String url,String content) {
		String line     = "";
		String message    = "";
		String returnData  = "";
		Boolean postState   = false;
		BufferedReader bufferedReader = null;
		try {
			URL urlObject = new URL(url);
			HttpURLConnection urlConn = (HttpURLConnection) urlObject.openConnection();
			urlConn.setDoOutput(true);
			/*设定禁用缓存*/
			urlConn.setRequestProperty("Pragma:", "no-cache");
			urlConn.setRequestProperty("Cache-Control", "no-cache");
			/*维持长连接*/
			urlConn.setRequestProperty("Connection", "Keep-Alive");
			/*设置字符集*/
			urlConn.setRequestProperty("Charset", "UTF-8");
			/*设定输出格式为json*/
			urlConn.setRequestProperty("Content-Type", "application/json;charset=utf-8");
			/*设置使用POST的方式发送*/
			urlConn.setRequestMethod("POST");
			/*设置不使用缓存*/
			urlConn.setUseCaches(false);
			/*设置容许输出*/
			urlConn.setDoOutput(true);
			/*设置容许输入*/
			urlConn.setDoInput(true);
			urlConn.connect();
			OutputStreamWriter outStreamWriter = new OutputStreamWriter(urlConn.getOutputStream(),"UTF-8");
			outStreamWriter.write(content);
			outStreamWriter.flush();
			outStreamWriter.close();
			/*若post失败*/
			if((urlConn.getResponseCode() != 200)){
				returnData = "{\"jsonStrStatus\":0,\"processResults\":[]}";
				message = "发送POST失败!"+ "code="+urlConn.getResponseCode() + "," + "失败消息:"+ urlConn.getResponseMessage();
				// 定义BufferedReader输入流来读取URL的响应 
				InputStream errorStream = urlConn.getErrorStream();
				if(errorStream != null) 
				        {
					InputStreamReader inputStreamReader = new InputStreamReader(errorStream,"utf-8");
					bufferedReader = new BufferedReader(inputStreamReader);
					while ((line = bufferedReader.readLine()) != null) {
						message += line;
					}
					inputStreamReader.close();
				}
				errorStream.close();
				System.out.println("发送失败!错误信息为:"+message);
			} else{
				/*发送成功返回发送成功状态*/
				postState = true;
				// 定义BufferedReader输入流来读取URL的响应 
				InputStream inputStream = urlConn.getInputStream();
				InputStreamReader inputStreamReader = new InputStreamReader(inputStream,"utf-8");
				bufferedReader = new BufferedReader(inputStreamReader);
				while ((line = bufferedReader.readLine()) != null) {
					message += line;
				}
				returnData = message;
				inputStream.close();
				inputStreamReader.close();
				System.out.println("发送POST成功!返回内容为:" + message);
			}
		}
		catch (Exception e) {
			e.printStackTrace();
		}
		finally{
			try {
				if (bufferedReader != null) {
					bufferedReader.close();
				}
			}
			catch (IOException ex) {
				ex.printStackTrace();
			}
			return postState;
		}
	}
	/*读取request数据*/
	public static String getRequestData(HttpServletRequest request) throws IOException{
		BufferedReader reader = request.getReader();
		char[] buf = new char[512];
		int len = 0;
		StringBuffer contentBuffer = new StringBuffer();
		while ((len = reader.read(buf)) != -1) {
			contentBuffer.append(buf, 0, len);
		}
		String content = contentBuffer.toString();
		if(content == null){
			content = "";
		}
		return content;
	}
}

总结

以上就是本文关于Java编程Post数据请求和接收代码详解的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站:

java线程间通信的通俗解释及代码示例

Java多线程之线程通信生产者消费者模式及等待唤醒机制代码详解

Java多线程编程实现socket通信示例代码

如有不足之处,欢迎留言指出。

相关文章

  • 聊聊单线程的Redis为何会快到飞起

    聊聊单线程的Redis为何会快到飞起

    Redis想必大家都或多或少听过吧,我们在工作学习中通常用它来作为缓存使用,既然是作为缓存,大家的第一反应肯定是:这家伙很快
    2022-02-02
  • Kotlin教程之基本数据类型

    Kotlin教程之基本数据类型

    这篇文章主要介绍了Kotlin教程之基本数据类型的学习的相关资料,需要的朋友可以参考下
    2017-05-05
  • 详解Spring的autowire-candidate设计

    详解Spring的autowire-candidate设计

    现在的Spring应用通常都是基于注解开发,但是对Spring感兴趣的同学可以借助Spring早期基于Xml配置的各种运用来加深对Spring框架内部的理解和体会Spring框架的设计之妙。这篇文章我们就来谈谈Xml配置之default-autowire-candidates
    2021-06-06
  • SpringCloud使用Ribbon实现负载均衡的流程步骤

    SpringCloud使用Ribbon实现负载均衡的流程步骤

    在微服务架构中,负载均衡是一项关键的技术,它可以确保各个服务节点间的负载分布均匀,提高整个系统的稳定性和性能,Spring Cloud 中的 Ribbon 就是一种负载均衡的解决方案,本文将深入探讨 Ribbon 的原理和在微服务中的应用,需要的朋友可以参考下
    2024-02-02
  • Java中获取当前路径的几种方法总结

    Java中获取当前路径的几种方法总结

    这篇文章主要介绍了Java中获取当前路径的几种方法总结的相关资料,需要的朋友可以参考下
    2017-02-02
  • slf4j jcl jul log4j1 log4j2 logback各组件系统日志切换

    slf4j jcl jul log4j1 log4j2 logback各组件系统日志切换

    这篇文章主要介绍了slf4j、jcl、jul、log4j1、log4j2、logback的大总结,各个组件的jar包以及目前系统日志需要切换实现方式的方法,有需要的朋友可以借鉴参考下
    2022-03-03
  • java socket实现聊天室 java实现多人聊天功能

    java socket实现聊天室 java实现多人聊天功能

    这篇文章主要为大家详细介绍了java socket实现聊天室,java实现多人聊天功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-07-07
  • java多线程join()方法的作用和实现原理解析(应用场景)

    java多线程join()方法的作用和实现原理解析(应用场景)

    join方法主要是用于将当前线程挂起,等待其他线程结束后在执行当前线程,本文通过应用场景分析代码示例讲解java多线程join()方法的作用和实现原理,感兴趣的朋友一起看看吧
    2021-07-07
  • SpringBoot 注解事务声明式事务的方式

    SpringBoot 注解事务声明式事务的方式

    springboot使用上述注解的几种方式开启事物,可以达到和xml中声明的同样效果,但是却告别了xml,使你的代码远离配置文件。今天就扒一扒springboot中事务使用注解的玩法,感兴趣的朋友一起看看吧
    2017-09-09
  • SpringSecurity登录使用JSON格式数据的方法

    SpringSecurity登录使用JSON格式数据的方法

    这篇文章主要介绍了SpringSecurity登录使用JSON格式数据的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-02-02

最新评论