内射老阿姨1区2区3区4区_久久精品人人做人人爽电影蜜月_久久国产精品亚洲77777_99精品又大又爽又粗少妇毛片

Scala下Play框架學習筆記(HttpRouting)-創(chuàng)新互聯

內置的HTTP路由

創(chuàng)新互聯專注于博州網站建設服務及定制,我們擁有豐富的企業(yè)做網站經驗。 熱誠為您提供博州營銷型網站建設,博州網站制作、博州網頁設計、博州網站官網定制、重慶小程序開發(fā)服務,打造博州網絡公司原創(chuàng)品牌,更為您提供博州網站排名全網營銷落地服務。

路由把每一個引進來的HTTP請求對應到相應的Action去。

HTTP請求被認為是MVC框架下的一個事件,這一事件包含兩部分主要信息:

(1)請求路徑,包括query String

(2)HTTP方法,如get,post等

  路由被定義在經過編譯的conf/routes中,因此你能在瀏覽器上直接看到報錯信息。

conf/routes中每一行一般由HTTP方法和相應URI組成:

GET  /clients/:id     controllers.Clients.show(id: Long)

也可加上評論:

# Display a client.

GET  /clients/:id     controllers.Clients.show(id: Long)

以下這個不太懂,請高人指教:

->   /api            api.MyRouter

HTTP方法

HTTP方法包括get、post、patch、put、delete、head等。

URI PATTERN

URI PATTERN定義了routes的路徑,部分請求路徑可以是動態(tài)的。

(1)靜態(tài)路徑:

準確匹配請求路徑,可以定義如下:

GET  /clients/all     controllers.Clients.list()

 (2)動態(tài)的部分:

如果要通過ID來搜索路徑,需要用動態(tài)指定的方式。

GET  /clients/:id     controllers.Clients.show(id: Long)

The default matching strategy for a dynamic part is defined by the regular expression [^/]+, meaning that any dynamic part defined as :id will match exactly one URI path segment.

通過*id可以來匹配多個URI,如下:

GET  /files/*name     controllers.Application.download(name)

以上的router,對于GET /files/p_w_picpaths/logo.png這樣的請求,name會匹配p_w_picpaths/logo.png。

用自定義正則表達式動態(tài)路由

$id<regex>可以來自定義正則表達式

GET  /items/$id<[0-9]+>  controllers.Items.show(id: Long)

 the parameter is not decoded by the router or encoded by the reverse router. You’re responsible for validating the input to make sure it makes sense in that context.

controller action method

如果方法沒有參數,可以如下定義:

GET  /           controllers.Application.homePage()

如果有參數,則從請求URI中尋找參數:

# Extract the page parameter from the path.

GET  /:page        controllers.Application.show(page)

或者如下:

# Extract the page parameter from the query string.

GET  /           controllers.Application.show(page)

show方法的定義如下:

def show(page: String) = Action {
 loadContentFromDatabase(page).map { htmlContent =>
  Ok(htmlContent).as("text/html")
 }.getOrElse(NotFound)

}

如果要把入參轉換成scala的數據類型,就要有下面的router,并且實現相應的方法:

GET  /clients/:id     controllers.Clients.show(id: Long)

def show(id: Long) = Action {
 Client.findById(id).map { client =>
  Ok(views.html.Clients.display(client))
 }.getOrElse(NotFound)

}

固定值的參數:

# Extract the page parameter from the path, or fix the value for /
GET  /           controllers.Application.show(page = "home")

GET  /:page        controllers.Application.show(page)

默認值方式:

# Pagination links, like /clients?page=3

GET  /clients       controllers.Clients.list(page: Int ?= 1)

Option類型,不需要在每一次傳參時都傳入:

# The version parameter is optional. E.g. /api/list-all?version=3.0

GET  /api/list-all     controllers.Api.list(version: Option[String])

注:多個routes沖突時,使用第一個。

play.api.mvc.Call中提供了HTTP回調,提供了HTTP和URI方法,它用如下方法創(chuàng)建控制器:

package controllers

import play.api._
import play.api.mvc._

class Application extends Controller {

 def hello(name: String) = Action {
  Ok("Hello " + name + "!")
 }

}

如果在conf/routes中有如下定義:

# Hello action
GET  /hello/:name     controllers.Application.hello(name)

那么可以通過controllers.routes.Application實現控制反轉:

// Redirect to /hello/Bob
def helloBob = Action {
 Redirect(routes.Application.hello("Bob"))

}

默認控制器:

# Redirects to https://www.playframework.com/ with 303 See Other
GET  /about   controllers.Default.redirect(to = "https://www.playframework.com/")

# Responds with 404 Not Found
GET  /orders   controllers.Default.notFound

# Responds with 500 Internal Server Error
GET  /clients  controllers.Default.error

# Responds with 501 Not Implemented
GET  /posts   controllers.Default.todo

另外有需要云服務器可以了解下創(chuàng)新互聯scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。

網頁標題:Scala下Play框架學習筆記(HttpRouting)-創(chuàng)新互聯
文章地址:http://m.rwnh.cn/article0/dscooo.html

成都網站建設公司_創(chuàng)新互聯,為您提供小程序開發(fā)面包屑導航、網頁設計公司、電子商務、軟件開發(fā)、網站設計公司

廣告

聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯

成都定制網站網頁設計
仲巴县| 南安市| 同江市| 娄底市| 成武县| 台南市| 兰西县| 铅山县| 滁州市| 咸宁市| 济源市| 新昌县| 宜黄县| 白银市| 霍邱县| 龙井市| 胶南市| 瑞金市| 宕昌县| 天镇县| 临潭县| 承德市| 朝阳县| 陆河县| 井冈山市| 延川县| SHOW| 法库县| 巩留县| 抚顺县| 海阳市| 塔城市| 揭东县| 上饶市| 东辽县| 南郑县| 西城区| 金华市| 丽江市| 历史| 华蓥市|