Java获取请求头、参数、路径方式
作者:阿毛~
这篇文章主要介绍了Java获取请求头、参数、路径方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
Java获取请求头、参数、路径
request.getReader()和request.getParameter("key") 方法只能读取一次,重复读取会报IO异常
第一种
从 ContainerRequestContext 对象 获取请求头、路径、参数
//请求头 MultivaluedMap<String, String> headers = containerRequestContext.getHeaders(); //路径参数 MultivaluedMap<String, String> pathParam = containerRequestContext.getUriInfo().getPathParameters(); //queryParam MultivaluedMap<String, String> queryParam = containerRequestContext.getUriInfo().getQueryParameters(); // 路径 String path = containerRequestContext.getUriInfo().getPath(true).toLowerCase();
注意:
这里MultivaluedMap和map不同,遍历的时候也不同,MultivaluedMap 一个key 可以有多个值 , map一个key 只对应一个值
举个例子:
// MultiValueMap 一个 key 可以对应多个 value
MultiValueMap<String, String> map = new LinkedMultiValueMap<>();
map.add("name", "小明");
map.add("name", "小红");
System.out.println(map.toString());
// Map 一个 key 对应一个 value
Map<String, String> hashMap = new HashMap<String, String>();
hashMap.put("name", "小明");
hashMap.put("name", "小红");
System.out.println(hashMap.toString());
--------------output---------------
{name=[小明, 小红]}
{name=小红}
第二种
从 HttpServletRequest 获取
// 获取所有header
Map<String, String> headerMap = new HashMap<>();
Enumeration enumeration = httpServletRequest.getHeaderNames();
while (enumeration.hasMoreElements()) {
String name = enumeration.nextElement();
String value = httpServletRequest.getHeader(name);
headerMap.put(name, value);
}
// 获取所有参数
Map<String, String> parameterMap = new HashMap<>();
Enumeration enumeration = httpServletRequest.getParameterNames();
while (enumeration.hasMoreElements()) {
String name = enumeration.nextElement();
String value = httpServletRequest.getParameter(name);
parameterMap.put(name, value);
}// 获取boby
InputStream inputStream = null;
try {
inputStream = httpServletRequest.getInputStream();
StringBuilder babyStr = new StringBuilder();
byte[] b = new byte[4096];
for (int n; (n = inputStream.read(b)) != -1; ) {
babyStr.append(new String(b, 0, n));
}
System.out.println(babyStr);
} catch (IOException e) {
e.printStackTrace();
} finally {
if (null != inputStream) {
try {
inputStream.close();
} catch (IOException e) {
e.printStackTrace();
}
}
} // 二进制读取 获取boby
int len = httpServletRequest.getContentLength();
byte[] buffer = new byte[len];
ServletInputStream in = null;
try {
in = httpServletRequest.getInputStream();
in.read(buffer, 0, len);
in.close();
} catch (IOException e) {
e.printStackTrace();
} finally {
try {
in.close();
} catch (IOException e) {
e.printStackTrace();
}
}注意:
HttpServletRequest 请求中的 body 内容仅能调用 request.getInputStream(), request.getReader()和request.getParameter("key") 方法读取一次,重复读取会报 java.io.IOException: Stream closed 异常
获取路径:
request.getServletPath() request.getPathInfo() request.getContextPath() request.getRequestURI() request.getRequestURL() request.getServletContext().getRealPath()
getServletPath():获取能够与“url-pattern”中匹配的路径,注意是完全匹配的部分,*的部分不包括。getPageInfo():与getServletPath()获取的路径互补,能够得到的是“url-pattern”中 模糊匹配(不确定) 的路径部分getContextPath():获取项目的根路径getRequestURI():获取根路径到地址结尾getRequestURL():获取请求的地址链接(浏览器中输入的地址)getServletContext().getRealPath(“/”):获取“/”在机器中的实际地址getScheme():获取的是使用的协议(http 或https)getProtocol():获取的是协议的名称(HTTP/1.11)getServerName():获取的是域名(xxx.com)getLocalName():获取到的是IP
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
