大佬教程收集整理的这篇文章主要介绍了GO — 提供跨域请求代理服务,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
单页应用中,异步请求数据会受到同源政策限制。
不仅仅是传统的ajax,基于promise的axios和fetch也会受到限制。解决方法有很多,这里简述一下使用golang搭建一个简单的代理服务。
用代理实现跨域请求的原理是
DomainA客户端(浏览器) ==> DomainA服务器 ==> DomainB服务器 ==> DomainA客户端(浏览器)
在页面的同源浏览器搭建一个代理服务,页面请求数据发至同源服务器后,由同源服务器转发到目标服务器,同时等待响应并将响应转发回页面。
实际上,在一些前端框架中,如vue.js,提供了简易的代理服务以供测试。在服务端采用相同的配置,可以非常方便的从开发环境转向生产环境。
httprouter是基于golang提供的Http包之上封装的非常轻便的http框架。
使用httprouter可以非常方便的解析url,添加handler。
go get github.com/julienschmidt/httprouter
func main() { router := httprouter.New() router.GET("/",indeX) //以post方式访问/github为前缀的url时,完整的url会转化为参数传入函数 router.POST("/github/*proxyPath",proxy) log.Fatal(http.ListenAndServe(serverPort,router)) }
func proxy(w http.ResponseWriter,r *http.request,ps httprouter.Params) { // /github -> remote remote := "https://github.com" // 获取完整url u := remote + ps.byName("proxyPath") log.Println(r.URL,"=>",u) // 以现有的request创建新的request req,err := http.Newrequest(r.Method,u,r.body) /* method url body */ req.Header = r.Header /* header */ client := http.DefaultClient // 发起新的请求 res,err := client.Do(req) if err != nil { w.WriteHeader(404) fmt.Fprint(w,err) return } // 获取新的body bodyRes,err:=IoUtil.ReadAll(res.body) if err!=nil{ w.WriteHeader(404) fmt.Fprint(w,err) return } // 设置新的header for k,vs := range res.Header { for _,v := range vs { w.Header().Add(k,v) } } // 设置新的cookie for _,value := range res.request.Cookies() { w.Header().Add(value.Name,value.value) } // 写入状态 w.WriteHeader(res.StatusCodE) w.Write(bodyRes) }
特别注意:写出时必须先设置header再写出状态码和body
以post的方式访问我们的代理地址
查看log
2018/02/22 11:33:07 /github/login/oauth/access_token => https://github.com/login/oauth/access_token
以上是大佬教程为你收集整理的GO — 提供跨域请求代理服务全部内容,希望文章能够帮你解决GO — 提供跨域请求代理服务所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。