1. 前後端介面對接規范(主要前端內容).md
前後端分離意味著,前後端之間使⽤ JSON 來交流,兩個開發團隊之間使⽤ API 作為契約進⾏交互。從此,後台選⽤的技術棧不影響前台。當我們決定需要前後端分離時,我們仍然還需要⾯對⼀系列的問題:
RESTful API 統一約束客戶端和伺服器之間的介面。簡化和分離系統架構,使每個模塊獨立!
REST即表述性狀態傳遞(英文:Representational State Transfer,簡稱REST)是Roy Fielding博士在2000年他的博士論文中提出來的一種 軟體架構 風格。它是一種針對 網路應用 的設計和開發方式,可以降低開發的復雜性,提高系統的可伸縮性。 REST是設計風格而不是標准。 REST通常基於使用 HTTP ,URI,和 XML ( 標准通用標記語言 下的一個子集)以及 HTML (標准通用標記語言下的一個應用)
統一介面約束定義客戶端和伺服器之間的介面。它簡化了分離的結構,使各部分獨立發展。
REST要求狀態要麼被放入資源狀態中,要麼保存在客戶端上。或者換句話說,伺服器端不能保持除了單次請求之外的,任何與其通信的客戶端的通信狀態。 從客戶端的每個請求要包含伺服器所需要的所有信息。 這樣做的最直接的理由就是可伸縮性—— 如果伺服器需要保持客戶端狀態,那麼大量的客戶端交互會嚴重影響伺服器的內存可用空間(footprint)。
伺服器返回信息必須被標記是否可以緩存,如果緩存,客戶端可能會重用之前的信息發送請求。
客戶端無需關注數據存儲,伺服器端無需關注用戶界面,提高了前後端可移植性。
客戶端不關心直接連接到最終伺服器還是連接到中間伺服器。中間伺服器可以通過啟用負載平衡和提供共享緩存來提高系統可擴展性。分層系統也可以執行安全策略。
伺服器可以通過傳輸邏輯來臨時擴展或定製客戶端的功能。
GET https//domain.com/api/{模塊名}/{?菜單名}/{介面名}/:param
說明:
被用於獲取資源。不允許對伺服器上資源做任何修改操作。
示例:
常用於更新資源。通過請求體攜帶資源發送給伺服器。 注意: 在資源ID由客戶端而不是由伺服器選擇的情況下,也可以使用PUT來創建資源。修改成功返回200,創建成功返回201。 建議使用post進行創建新資源。
常用於創建新資源。創建成功通常返回201。
刪除資源。
status說明
---------------------------------------------------------------------------分割線-----------------------------------------------------------
請求方式:POST
參數:說明
返回值:
示例1
正確的
錯誤的
2. 如何讓本地的前端伺服器訪問本地的後台伺服器
首行你要去注冊一個花生殼帳號,這里就不寫地址了,自己搜索一下。注冊好後下載客戶端,這個很重要,因為你要通過軟體解析你的IP地址。如圖
登錄後,你就要去配置一下你的本地伺服器軟體了,現在常用的伺服器組件有IIS,阿帕奇等,那今天我就用phpNOW這個做一下演示。
首先到網站上下載一個phpnow伺服器軟體,按照軟體要求進行安裝。(官方有提供教程)很簡單的。
安裝後打開PnCp.cmd 新增一下虛擬主機(或是你默認一下)通過localhost或127.0.0.1可以訪問,那就說明你配置沒有問題了
因為國內的ISP把80埠封閉了,所以你要用其它的埠,如圖:這里我用2099這個埠,如果你有用路由器的話你要設置一下轉發。(讓路由器幫忙解析到指定內網伺服器)這一步很重要。
之後你還要開放一下這個埠2099,右擊網上鄰居-屬性-更改防火牆設置--例外-增加埠
5
設置好後,你就可以輸入XXX域名:2099,或是127.0.0.1:2099這樣就可以訪問了,外網訪問的時候一定要加上:2099埠號。
3. 前端做好網頁後如何與後端數據伺服器代碼連接
你可以最直接通過資料庫啊,前後台不都通過這個鏈接起來么,有的可能復雜點,很多部分都分離了,分開書寫,不會的話可以去學學,不想學可以找額代弄代教
4. 前端跨域方式有哪些
處理跨域方法一——JSONP
1.JSONP原理
利用script元素的這個開放策略,網頁可以得到從其他來源動態產生的 JSON 數據。JSONP請求一定需要對方的伺服器做支持才可以。
2.JSONP和AJAX對比
JSONP和AJAX相同,都是客戶端向伺服器端發送請求,從伺服器端獲取數據的方式。但AJAX屬於同源策略,JSONP屬於非同源策略(跨域請求)
3.JSONP優缺點
JSONP優點是兼容性好,可用於解決主流瀏覽器的跨域數據訪問的問題。缺點是僅支持get方法具有局限性。
4.JSONP的流程(以第三方API地址為例,不必考慮後台程序)
聲明一個回調函數,其函數名(如fn)當做參數值,要傳遞給跨域請求數據的伺服器,函數形參為要獲取目標數據(伺服器返回的data)。
創建一個
伺服器接收到請求後,需要進行特殊的處理:把傳遞進來的函數名和它需要給你的數據拼接成一個字元串,例如:傳遞進去的函數名是fn,它准備好的數據是fn([{「name」:「jianshu」}])。
最後伺服器把准備的數據通過HTTP協議返回給客戶端,客戶端再調用執行之前聲明的回調函數(fn),對返回的數據進行操作。
處理跨域方法二——CORS
1.CORS原理
整個CORS通信過程,都是瀏覽器自動完成,不需要用戶參與。對於開發者來說,CORS通信與同源的AJAX通信沒有差別,代碼完全一樣。瀏覽器一旦發現AJAX請求跨源,就會自動添加一些附加的頭信息,有時還會多出一次附加的請求,但用戶不會有感覺。因此,實現CORS通信的關鍵是伺服器。只要伺服器實現了CORS介面,就可以跨源通信。
2.CORS優缺點
CORS要求瀏覽器(>IE10)和伺服器的同時支持,是跨域的根本解決方法,由瀏覽器自動完成。
優點在於功能更加強大支持各種HTTP Method,缺點是兼容性不如JSONP。
處理跨域方法三——WebSocket
Websocket是HTML5的一個持久化的協議,它實現了瀏覽器與伺服器的全雙工通信,同時也是跨域的一種解決方案。WebSocket和HTTP都是應用層協議,都基於 TCP 協議。但是 WebSocket 是一種雙向通信協議,在建立連接之後,WebSocket 的 server 與 client 都能主動向對方發送或接收數據。同時,WebSocket 在建立連接時需要藉助 HTTP 協議,連接建立好了之後 client 與 server 之間的雙向通信就與 HTTP 無關了。
原生WebSocket API使用起來不太方便,我們使用Socket.io,它很好地封裝了webSocket介面,提供了更簡單、靈活的介面,也對不支持webSocket的瀏覽器提供了向下兼容。
處理跨域方法四——postMessage
如果兩個網頁不同源,就無法拿到對方的DOM。典型的例子是iframe窗口和window.open方法打開的窗口,它們與父窗口無法通信。HTML5為了解決這個問題,引入了一個全新的API:跨文檔通信 API(Cross-document messaging)。這個API為window對象新增了一個window.postMessage方法,允許跨窗口通信,不論這兩個窗口是否同源。postMessage方法的第一個參數是具體的信息內容,第二個參數是接收消息的窗口的源(origin),即"協議 + 域名 + 埠"。也可以設為*,表示不限制域名,向所有窗口發送。
5. web前端與後台是怎麼樣實現連接在一起實現管理
ajax實現交互,後端也可以輸出前台頁面,不是很明白你問的問題,後台指後段語言還是指看到的後台管理界面
6. 如何讓web網頁與伺服器上的應用程序進行通訊呢
你好!
呵呵,很簡單啊。你在頁面有個鏈接到伺服器上面的Web服務,在Web服務裡面去執行你的開發的應用程序。我想這樣應該可以達到你的目的吧。親,記得給我分哦。
打字不易,採納哦!