beego可算是Go框架里面文檔最多的了。學起來比較容易。但是框架自身的局限性卻帶了不小的問題。
最近我在處理flash跨域問題上就遇到個活生生的例子:
flash里面的as3訪問外網時沒啥問題。可是假如通過網頁調取的情況下,flash訪問的外網又與所在網頁不是一個域的。就會產生跨域問題。打開瀏覽器,f12之后,看到的就是flash沒有訪問你的url,而是訪問了這個url所在的域名根目錄下的配置文件crossdomain.xml。該配置文件來設置跨域訪問的權限。
這時候需要在你的域名根目錄下放個crossdomain.xml文件。恰巧我用的是beego,不支持這功能!~
解決辦法:
既然不支持那就把beego寫成一個文件服務器的功能即可。把我的crossdomain.xml同樣放到static下,在收到這個請求時,直接將這個文件寫回到response即可。上代碼:
package main
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
39
40
41
42
43
44
45
46
47
48
49
|
import ( "fmt" http "net/http" "path/filepath" "strings" "github.com/astaxie/beego" ) type MainController struct { beego.Controller } func (this *MainController) Get() { //this.Ctx.Request.URL= http://127.0.0.1/crossdomain.xml orpath := this.Ctx.Request.URL.Path if strings.Index(orpath, "crossdomain.xml") >= 0 { fmt.Println(orpath) // /crossdomain.xml path := filepath.Join(`static`, "crossdomain.xml") http.ServeFile(this.Ctx.ResponseWriter, this.Ctx.Request, path) } this.Ctx.WriteString("hello world" + orpath) } func (this *MainController) Post() { name := this.GetString("name") sex := this.GetString("sex") this.Ctx.WriteString(name + sex+"成功") fmt.Println(name + sex) } func main() { beego.Router("/*", &MainController{}) beego.Run() } |
當然了這不是什么好辦法。只是拋磚引玉而已。所有的請求都要判斷一下,如果想完善一下,在路由配置時可以精確匹配url處理的controller就好了,而對于自己的controller就會沒有影響了
以上這篇完美解決beego 根目錄不能訪問靜態文件的問題就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持服務器之家。