日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

服务器端代理proxy实现跨域访问

發(fā)布時間:2024/1/1 编程问答 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 服务器端代理proxy实现跨域访问 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

在koa中使用代理proxy
我們知道瀏覽器有個"同源策略"的限制,再回憶一下,同源是 什么?所謂同源,即同協(xié)議、同域名、同端口。如果不滿足同源三者條件任意一個,即是非同源,也就是跨域訪問。
跨域訪問有不同的實現(xiàn)方法,今天來研究一下服務(wù)端代理是怎么實現(xiàn)跨域的。

服務(wù)器端代理是如何實現(xiàn)跨域的原理:服務(wù)器端不直接去發(fā)出跨域請求,而在服務(wù)器端設(shè)置一個代理(proxy),由服務(wù)器端向跨域下的代理發(fā)出請求,再將請求的結(jié)果返回到前端。

在koa中使用代理,需要引入koa-server-http-proxy模塊(中間件來代理)
下面的小實例看一下怎么使用代理:
服務(wù)器端:

const Koa = require("koa"); const Router = require("koa-router"); const koaStatic = require("koa-static"); const serverProxy = require("koa-server-http-proxy");let app = new Koa(); let router = new Router(); app.use(koaStatic(__dirname+"/static"));router.get("/",ctx=>{ctx.body = "5000服務(wù)端口"; });// 同源訪問 router.post("get","/serverPost",ctx=>{ctx.body = "同源訪問5000端口"; });// 服務(wù)器端代理:接口轉(zhuǎn)發(fā) app.use(serverProxy("/api",{// 接口的域名,代理從target后開始匹配,不是任意位置target:"http://localhost:4000",/* 配置pathRewrite可以做替換,因為實際請求中沒有api前綴,需要通過pathRewrite重寫地址,接口請求的時候?qū)⑶熬Y去除*/pathRewrite:{'^/api':''},// 開啟代理changeOrigin:true }));app.use(router.routes()); app.listen(5000);

客戶端:

<!DOCTYPE html> <html lang="en"> <head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title> </head> <body><h1>5000端口</h1><button class="btn1">同源請求</button><button class="btn2">非同源請求</button><script>// 模擬同源訪問document.querySelector(".btn1").onclick = function(){let xhr = new XMLHttpRequest();xhr.open("post","/serverPost",true);xhr.onload = function(){console.log(xhr.responseText);}xhr.send();} // 模擬非同源訪問(跨域訪問)document.querySelector(".btn2").onclick = function(){let xhr = new XMLHttpRequest();xhr.open("post","/api/serverPost",true);xhr.onload = function(){console.log(xhr.responseText);}xhr.send();} </script> </body> </html>

總結(jié)

以上是生活随笔為你收集整理的服务器端代理proxy实现跨域访问的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。