關(guān)于nginx配置 獲取靜態(tài)資源
問題描述
比如一個(gè)本地項(xiàng)目,啟動(dòng)服務(wù)后應(yīng)該是 127.0.0.1: 端口號 ,用這樣的方式能訪問,然后我在nginx的vhosts文件夾下面新建了一個(gè) ‘a(chǎn).xxxx.com.conf’的文件,在這里配置完以后,那么我本地的項(xiàng)目就可以通過a.xxxx.com訪問。
現(xiàn)在問題是在項(xiàng)目里有存放靜態(tài)文件的目錄,那么我要怎么做才能訪問到靜態(tài)文件呢?小白一枚,希望大神能告訴下怎么解決,或者幫貼個(gè)代碼參考一下。
比如我想獲得web下的javascript目錄下的js文件,目前我通過在vhosts下的a.xxxx.com.conf這么配置的方式可以獲取到。如下:location ~*/javascript/{
root /Users/xxx/WebstormProjects/myprojects/web/javascript
}
但是我想實(shí)現(xiàn)的方式其實(shí)是這樣的,比如我想通過img.xxx.com/javascript/a.js,這樣的方式能獲取到web下的資源該如何做呢?
謝謝謝謝。再結(jié)合我描述的看下下圖.
問題解答
回答1:怎么沒人回答啊?我也不是很懂,稍微說點(diǎn)我明白的吧
location /img { root /www/abc }
意思是訪問 a.xxxx.com/img 時(shí),到/www/ abc 中查找,就相當(dāng)于圖片在/www/abc/img 下手機(jī)打的,不詳細(xì)見諒,僅供參考
回答2:你這個(gè)姿勢本身就不太對。你是不是有點(diǎn)感覺,訪問一個(gè)URL,既想讓他訪問到你的服務(wù),又想讓他訪問到你的靜態(tài)文件。也許你會(huì)說,我的服務(wù)的URL和靜態(tài)文件的URL不一樣啊。問題就在這里,對于WEB服務(wù)器,他怎么知道不一樣呢,你的服務(wù)URL與靜態(tài)資源的URL有何不同?如果說的出不同,那么就是你的配置文件的規(guī)則。
通常情況下,在動(dòng)態(tài)程序中,人們是這樣設(shè)定的規(guī)則:
方案1請先嘗試這個(gè)URL是不是文件,是不是文件夾,如果是,請返回靜態(tài)資源
如果不是,請交給動(dòng)態(tài)程序(服務(wù))來處理
對應(yīng)的配置文件可能是這樣的:
server { listen 80; server_name a.xxx.com; index index.shtml index.html index.php; root /Users/xxx/WebstormProjects/myprojects/web/; location / {try_files $uri $uri/ /index.php$is_args$args; } location ~ .php$ {root /Users/xxx/WebstromProjects/myprojects/server/;fastcgi_pass 127.0.0.1:9001;fastcgi_index index.php;include fastcgi.conf; }}
而此時(shí),一般會(huì)將主目錄設(shè)置為: /Users/xxx/WebstormProjects/myprojects/web/ 并且在web目錄中放置一個(gè)index.php作為服務(wù)的入口,index.php可以將app的程序目錄設(shè)置為server。(那么久刪除php配置段的root)
方案2如樓上所說,主目錄是服務(wù)目錄,但我們有規(guī)則 ,javascript,css,images,uploads等目錄存放在web目錄下,于是,設(shè)定已這些路徑開頭的訪問將目錄指向到 web目錄下。
server { listen 80; server_name a.xxx.com; index index.html index.shtml index.php; root /Users/xxx/WebstromProjects/myproject/server; location / { // server } location ~ /(javascript|css|images) {root /Users/xxx/WebstromProjects/myproject/web; }}
提供一些思路,歸結(jié)其實(shí)就一條,先想好,你的訪問規(guī)則,什么URL是什么,對應(yīng)配置就好。
回答3:為了回答你的問題,特意注冊了一賬號
location /c/ {
alias /a/
}
如果訪問站點(diǎn)http://location/c訪問的就是/a/目錄下的站點(diǎn)信息。
相關(guān)文章:
1. 跟著課件一模一樣的操作使用tp6,出現(xiàn)了錯(cuò)誤2. PHP類屬性聲明?3. 微信小程序支持跳轉(zhuǎn)到外部鏈接網(wǎng)頁嗎4. angular.js - 這是什么錯(cuò)?誰遇到過?給點(diǎn)提示5. javascript - 安裝了babel,不起作用6. android - 關(guān)于百度定位的問題7. node.js - 初次安裝vue-cli遇到的問題8. css - 這些字體是怎么弄的?9. transform - css3 translate 的水平垂直居中問題求解10. 前端 - 應(yīng)該先從angularJS , vue.js , react 這些框架中的哪個(gè)開始入手?
