av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

javascript - 向nodejs發送post請求,只有options

瀏覽:90日期:2023-08-26 16:05:25

問題描述

向后臺發送post請求時,只有一個options的請求,而沒有真的post請求,get請求可以成功。而如果用postman,post請求也可以請求成功。需要配置什么嗎。代碼如下:

發送post請求時:

javascript - 向nodejs發送post請求,只有options發送get請求:

javascript - 向nodejs發送post請求,只有options

而在postman的環境下,post可以成功。

javascript - 向nodejs發送post請求,只有options

nodejs代碼如下:

var app = require(’express’)();var User = require('./users.js');app.post(’/users/login’,function (req,res) { res.setHeader(’Access-Control-Allow-Origin’, ’*’); res.send('foo'); console.log(res)})app.get(’/users/login’,function (req,res) { res.setHeader(’Access-Control-Allow-Origin’, ’*’); res.send('bar');})app.listen(’1090’,’127.0.0.1’);

前臺用的是angular的$http。想問的是,為什么post的時候,只有這個跨域的options啊

問題解答

回答1:

首先搞清楚為啥會發一個options的請求(如果你已經知道了就忽略好了),以下是發送(Preflight request)的先決條件。

請求以 GET, HEAD 或者 POST 以外的方法發起請求。或者,使用 POST,但請求數據為 application/x-www-form-urlencoded, multipart/form-data 或者 text/plain 以外的數據類型。比如說,用 POST 發送數據類型為 application/xml 或者 text/xml 的 XML 數據的請求。

使用自定義請求頭(比如添加諸如 X-PINGOTHER)

由于GET請求沒有預請求,直接發送所以沒問題。你在后端需要處理的options的請求,并且帶上CORS需要的那些頭,例如Access-Control-Allow-Origin等,這樣options的預請求成功之后,才會接著發送真正的post請求!!!

我自己有一個疑問,我看你后端的代碼是沒有處理options的請求的,但是你前端的狀態顯示這個請求是成功的!!!想知道這個是怎么弄的?

希望能幫到你

回答2:

https://github.com/wxungang/n...

完整代碼

標簽: JavaScript
主站蜘蛛池模板: 欧洲视频一区二区 | 99视频网 | 亚洲午夜小视频 | 国产视频综合 | 亚洲成人精品久久 | 国产精品久久一区 | 伊人久久成人 | av入口 | 成人夜晚看av | 亚洲毛片一区二区 | 国产一级视频在线观看 | 亚洲国产高清在线观看 | xx视频在线 | 国产99久久 | 欧美在线精品一区 | 国产亚洲二区 | 超碰在线影院 | 亚洲精品成人 | 国产高清一区二区 | 有码一区 | 国产成人小视频 | 一区中文字幕 | 国产ts一区| 久久久久久美女 | 精品不卡| 精品婷婷 | 黑人性hd | 国产精品伦一区二区三级视频 | www亚洲精品| 日韩av电影在线观看 | 亚洲永久免费 | 在线看免费的a | 亚洲精品一区二区三区在线 | 九九热免费视频在线观看 | 国产一区二区影院 | 国产一级在线 | 伊人影院99 | 国产伦精品一区二区三区精品视频 | 国产一区二区久久 | 污视频免费在线观看 | 最新高清无码专区 |