一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - java 獲取HttpRequest Header的幾種方法(必看篇)

java 獲取HttpRequest Header的幾種方法(必看篇)

2020-06-18 11:16java教程網 JAVA教程

下面小編就為大家帶來一篇java 獲取HttpRequest Header的幾種方法(必看篇)。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

在開發應用程序的過程中,如果有多個應用,通常會通過一個portal 門戶來集成,這個portal  是所有應用程序的入口,用戶一旦在portal 登錄之后,進入另外一個系統,就需要類似的單點登錄(SSO). 進入各個子系統的時候,就不需要再次登錄, 當然類似的功能,你可以通過專業的單點登錄軟件來實現,也可以自己寫數據庫token 等方式來實現。其實還有一個比較簡單的方法,就是通過 portal 封裝已經登錄過的用戶的消息,寫到http header 之中,然后把請求forward 到各個子系統中去,而各子系統從 http header 中獲取用戶名,作為是否登錄過的校驗或者合法的校驗。

總結了幾種處理http Header 的方法:

利用 HttpServletRequest

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
import javax.servlet.http.HttpServletRequest;
 //...
 private HttpServletRequest request;
 //get request headers
 private Map<String, String> getHeadersInfo() {
  Map<String, String> map = new HashMap<String, String>();
  Enumeration headerNames = request.getHeaderNames();
  while (headerNames.hasMoreElements()) {
    String key = (String) headerNames.nextElement();
    String value = request.getHeader(key);
    map.put(key, value);
  }
  return map;
 }

一個典型的例子如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
"headers" : {
  "Host" : "yihaomen.com",
  "Accept-Encoding" : "gzip,deflate",
  "X-Forwarded-For" : "66.249.x.x",
  "X-Forwarded-Proto" : "http",
  "User-Agent" : "Mozilla/5.0 (compatible; Googlebot/2.1; +
http://www.google.com/bot.html
)",
  "X-Request-Start" : "1389158003923",
  "Accept" : "*/*",
  "Connection" : "close",
  "X-Forwarded-Port" : "80",
  "From" : "googlebot(at)googlebot.com"
}

獲取 user-agent

?
1
2
3
4
5
6
import javax.servlet.http.HttpServletRequest;
 //...
 private HttpServletRequest request;
 private String getUserAgent() {
  return request.getHeader("user-agent");
 }

一個典型的例子如下:

?
1
2
3
Mozilla/5.0 (compatible; Googlebot/2.1; +
http://www.google.com/bot.html
)

利用 spring mvc 獲取  HttpRequest Header 的例子

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
import java.util.Enumeration;
import java.util.HashMap;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.servlet.ModelAndView;
@Controller
@RequestMapping("/site")
public class SiteController {
  @Autowired
  private HttpServletRequest request;
  @RequestMapping(value = "/{input:.+}", method = RequestMethod.GET)
  public ModelAndView getDomain(@PathVariable("input") String input) {
    ModelAndView modelandView = new ModelAndView("result");
    modelandView.addObject("user-agent", getUserAgent());
    modelandView.addObject("headers", getHeadersInfo());
    return modelandView;
  }
  //get user agent
  private String getUserAgent() {
    return request.getHeader("user-agent");
  }
  //get request headers
  private Map<String, String> getHeadersInfo() {
    Map<String, String> map = new HashMap<String, String>();
    Enumeration headerNames = request.getHeaderNames();
    while (headerNames.hasMoreElements()) {
      String key = (String) headerNames.nextElement();
      String value = request.getHeader(key);
      map.put(key, value);
    }
    return map;
  }
}

也許有人會說,Http Header  是可以模擬的,那么自己可以構造一個用來欺騙這些系統, 是的,的確是這樣,所以在用Http Header 來傳值得時候,一定要記得,所有的請求都必須經過 portal 來處理,然后 forward 到各子系統,就不會出現這個問題了。因為portal 首先攔截用戶發起的所有的請求,如果是構造的用戶,在portal 的sessiion 也是沒有記錄的,仍然會跳轉到登錄頁面,如果在protal 的 session 中記錄,而且  Http Header 中也有記錄,那么在子系統就是合法的用戶,然后自己可以根據一些要求處理業務邏輯了

JSP/Java獲取HTTP header信息(request)例子

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
<%
//header.jsp
out.println("Protocol: " + request.getProtocol() + "<br>");
out.println("Scheme: " + request.getScheme() + "<br>");
out.println("Server Name: " + request.getServerName() + "<br>" );
out.println("Server Port: " + request.getServerPort() + "<br>");
out.println("Protocol: " + request.getProtocol() + "<br>");
out.println("Server Info: " + getServletConfig().getServletContext().getServerInfo() + "<br>");
out.println("Remote Addr: " + request.getRemoteAddr() + "<br>");
out.println("Remote Host: " + request.getRemoteHost() + "<br>");
out.println("Character Encoding: " + request.getCharacterEncoding() + "<br>");
out.println("Content Length: " + request.getContentLength() + "<br>");
out.println("Content Type: "+ request.getContentType() + "<br>");
out.println("Auth Type: " + request.getAuthType() + "<br>");
out.println("HTTP Method: " + request.getMethod() + "<br>");
out.println("Path Info: " + request.getPathInfo() + "<br>");
out.println("Path Trans: " + request.getPathTranslated() + "<br>");
out.println("Query String: " + request.getQueryString() + "<br>");
out.println("Remote User: " + request.getRemoteUser() + "<br>");
out.println("Session Id: " + request.getRequestedSessionId() + "<br>");
out.println("Request URL: " + request.getRequestURL() + "<br>");
out.println("Request URI: " + request.getRequestURI() + "<br>");
out.println("Servlet Path: " + request.getServletPath() + "<br>");
out.println("Created : " + session.getCreationTime() + "<br>");
out.println("LastAccessed : " + session.getLastAccessedTime() + "<br>");
 
out.println("Accept: " + request.getHeader("Accept") + "<br>");
out.println("Host: " + request.getHeader("Host") + "<br>");
out.println("Referer : " + request.getHeader("Referer") + "<br>");
out.println("Accept-Language : " + request.getHeader("Accept-Language") + "<br>");
out.println("Accept-Encoding : " + request.getHeader("Accept-Encoding") + "<br>");
out.println("User-Agent : " + request.getHeader("User-Agent") + "<br>");
out.println("Connection : " + request.getHeader("Connection") + "<br>");
out.println("Cookie : " + request.getHeader("Cookie") + "<br>");
%>

關于request.getHeader("Referer")的說明

request.getHeader("Referer")獲取來訪者地址。只有通過鏈接訪問當前頁的時候,才能獲取上一頁的地址;否則request.getHeader("Referer")的值為Null,通過window.open打開當前頁或者直接輸入地址,也為Null。

以上就是小編為大家帶來的java 獲取HttpRequest Header的幾種方法(必看篇)的全部內容了,希望對大家有所幫助,多多支持服務器之家~

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲激情综合 | 亚洲国产高清视频 | 免费网站看v片在线香蕉 | 成年视频在线观看免费 | chinesezoozvideos| 香蕉国产成版人视频在线观看 | 秋霞色 | 1024视频色版在线网站 | 亚洲欧美日韩中文字幕网址 | 欧美日韩在线成人看片a | 欧美成人v视频免费看 | 久草在在线免视频在线观看 | 国产极品久久 | 国产综合成人亚洲区 | 国产精品天天影视久久综合网 | 99久久精品在免费线18 | 免费看成年视频网页 | 蝴蝶传媒免费安装 | 国产精品久线观看视频 | 国产欧美国产综合第一区 | 无码日韩精品一区二区免费 | 精品无码国产AV一区二区三区 | 精品国产乱码久久久久久免费 | 吃胸膜奶视频456 | 99久久国产综合精品女不卡 | 亚洲AV无码国产精品色午夜情 | 99精品国产自产在线观看 | 亚洲精品6久久久久中文字幕 | 4438全国最大免费观看 | 国产日韩欧美综合在线 | 国产精品一区二区不卡的视频 | 亚洲第一色网站 | 91亚洲视频在线观看 | 欧美一级片免费 | 操到翻白眼| 日本无遮挡拍拍拍凤凰 | 精品久久99麻豆蜜桃666 | 波多野结衣在线免费观看 | 无码精品AV久久久奶水 | 久久视频在线视频观看精品15 | 91短视频版高清在线观看免费 |