さぁーて、今週のPlayは?
前回PlayでAPIもどきを作成できたので、今度はテンプレートを使ってhtmlを返し&DB接続をしてみます。
待てあわてるな、これは準備だ
application.comfに接続情報を。
ローカルで動いているMySQLのplaydbという名前のデータベースに接続する場合です。
conf/application.conf
# (省略)
libraryDependencies += jdbc
play.db {
config = "db"
default = "default"
prototype {
}
}
db {
default.driver=com.mysql.jdbc.Driver
default.url="jdbc:mysql://localhost/playdb"
default.username = user123
default.password = "password123"
}
データはこのように入れてみました。
+----+----------------------+--------------------------------------+---------------------------+
| id | company_name | company_copy | addr |
+----+----------------------+--------------------------------------+---------------------------+
| 1 | 独立行政法人サンプル | 私たちはサンプルのためのサンプルです | 〒000-0123 銀河の果てまで |
| 2 | なんとか株式会社 | なんとかせんといかん会社 | 〒000-2222 東京都XXX |
| 3 | テスト企業 01 | 企業1です! | 〒000-1111 東京都ほげほげ |
+----+----------------------+--------------------------------------+---------------------------+
build.sbtのlibraryDependenciesにmysql-connector-javaを追加します。
build.sbt
libraryDependencies ++= Seq(
...(省略)
"mysql" % "mysql-connector-java" % "5.1.34"
)
よろしい、ならばコーディングだ
MySQLのDBからデータを取ってきて表示するページを作ってみます。
まずはroutes
conf/routes
GET /companies controllers.CompaniesController.index
CompaniesControllerはこんな感じ
app/controllers/CompaniesController.scala
package controllers
import javax.inject._
import play.api._
import play.api.mvc._
import play.api.db._
import models.Company
@Singleton
class CompaniesController @Inject() (db1: Database) extends Controller {
def index = Action {
var str = ""
var coms = List[Company]()
val conn = db1.getConnection
try {
val stmt = conn.createStatement
val rs = stmt.executeQuery("select * from companies order by id ASC limit 3")
while (rs.next()) {
coms = coms :+ new Company(rs)
}
} finally {
conn.close
}
Ok(views.html.companies(coms))
}
}
何気なく出てきたCompanyはこんな感じ。
stmt.executeQuery はResultSet型を返してくるので、ResultSetを引数にするコンストラクタも作ってみました。
(こんな設計で大丈夫かなあ?)
models/Company.scala
package models
import java.sql.ResultSet
case class Company(_id: Int, _company_name: String, _company_copy: String, _addr: String) {
var id = _id
var company_name = _company_name
var company_copy = _company_copy
var addr = _addr
def this() = {
this(0, "", "", "")
}
def this(rs: ResultSet) = {
this(rs.getInt("id"), rs.getString("company_name"), rs.getString("company_copy"), rs.getString("addr"))
}
def getId: Int = {
return this.id
}
def getName: String = {
return this.company_name
}
def getCopy: String = {
return this.company_copy
}
def getAddr: String = {
return this.addr
}
}
viewはこんな感じで。スタイルがしょぼいのは気にしないでください。
views/companies.scala.html
@(coms: List[Company])
<!DOCTYPE html>
<html lang="ja">
<head>
<title>Companies</title>
<link rel="shortcut icon" type="image/png" href="@routes.Assets.versioned("images/favicon.png")">
<style>
div.com{
margin: 4px 12px;
padding: 4px 8px;
border: 2px solid rgb(127,191,191);
border-radius: 2px;
}
p.name{
border-left: 2px solid rgb(63,63,127);
padding-left: 8px;
font-size:110%;
}
p.addr{
font-size: 90%;
}
</style>
</head>
<body>
<header></header>
<main>
<h1>企業一覧</h1>
@for(com <- coms){
<div class="com">
<p class="name">@com.getName</p>
<p class="copy">@com.getCopy</p>
<p class="addr">@com.getAddr</p>
</div>
}
</main>
<footer></footer>
</body>
</html>