ModelMapper

  PropertyMap<Source, Dest> propertyMap = new PropertyMap<Source, Dest>() {
           @Override
           protected void configure() {
               map().setNames(source.getName());
           }
       };
 map() -> { map().setNames(source.getName()); };

20170922 チェック

例外ハンドラー

認証関連

チェック

       return new Jackson2ObjectMapperBuilder()
               .serializationInclusion(JsonInclude.Include.NON_NULL)

DIの基本

Singletonとなるが、Request単位に作成してほしいなどがあるはず。スコープは4種類?

http://jappy.hatenablog.com/entry/2016/06/04/042200

リクエスト単位にしてほしいBeanの設定

@Bean
@Scope(value = WebApplicationContext.SCOPE_REQUEST, proxyMode = ScopedProxyMode.TARGET_CLASS)

properitiesのConfigへの読み込み

   @Bean
   @ConfigurationProperties(prefix = "myprop.hoge")
   public HogeProperties hogeProperties() {
       return new HogeProperties();
   }
myprop:
  hoge:
    prop1: prop1
   

環境の切り替え

java -jar spring-boot-config-0.0.1-SNAPSHOT.jar --spring.profiles.active=production

プロジェクト新規作成

Spring Bootの雛形をWeb上で作成可能

http://start.spring.io/

Document

http://terasolunaorg.github.io/guideline/5.3.0.RELEASE/ja/ArchitectureInDetail/WebApplicationDetail/Validation.html

特徴

起動

mvn spring-boot:run
./gradlew bootRun

注意点

以下の設定だとDBデータを全部消すので、間違っても利用中のDBに向けてはいけない。

spring.jpa.hibernate.ddl-auto=create

updateにしておくと消すことはない。

none何もしない。updateはentityの差分を反映。createは作成するが、消すことはない。create-dropは起動時に作成して、終了時にdropする。

トラブル

MACで設定翌日にWebアプリケーションが一切起動しない(どのプロジェクトも)トラブルで死亡。原因不明。ワークスペースを変更してもダメ。

propertiesファイル

application.propertiesに設定が必要だった。あとリソースファイルもクラスパスにないとだめ。全自動でできるのかは要調査!

検索対象のパッケージ

デフォルトやデモだと同じパッケージを検索する。 サービスには@ComponentScan("パッケージ名")

http://yyama1556.hateblo.jp/entry/2016/08/10/175948

設定

application.propertiesとapplication.yml

  1. src/main/resources/config/application.ymlがあるとそれを優先。
  2. src/main/resources/application.propertiesが次に利用されるが、同じ項目がある場合は無視される。

application.yml

設定ファイルではスネークケースもキャメルケースもチェーンケース(driver-class-name)もOK

server:
  port: 9020
spring:
  datasource:
    url: jdbc:mysql://mysql.example.com/test
    username: User
    password: Password
    driverClassName: com.mysql.jdbc.Driver
  jpa:
    hibernate:
      ddl-auto: update

Spring Boot Batch

デフォルトでは@SpringBootApplicationが存在するパッケージ以下を検索する。それ以外のパッケージにRepositoryがある場合は@EnableJpaRepositories and its type-safe basePackageClasses=MyRepository.class parameter.を利用する。

Spring DATA

http://qiita.com/tag1216/items/55742fdb442e5617f727

トラブルを防ぐために

SQLログ出力

# for logging
logging.level.org.hibernate.SQL=DEBUG
logging.level.org.hibernate.type.descriptor.sql.BasicBinder=TRACE

Thymeleaf

Tips

エスケープしないth:utext

Enum出力

<select>
   <option th:each="state : ${T(com.rutake.enums.Direction).values()}"
           th:value="${state.value}"
           th:text="${state.label}">
   </option>
</select>
Counter: 3777, today: 1, yesterday: 2

トップ   新規 一覧 検索 最終更新   ヘルプ   最終更新のRSS