```xml
<dependency>
    <groupId>org.noear</groupId>
    <artifactId>solon-i18n</artifactId>
</dependency>
```

#### 1、 描述

基础扩展插件，为国际化语言服务支持。约定 `resources/i18n` 为本地国际化语言配置目录。

#### 2、 配置示例

resources/i18n/messages.properties

```properties
login.title=登录
```


resources/i18n/messages_en_CN.properties

```properties
login.title=Login
```


#### 3、 代码应用

* 使用国际化工具类，获取默认消息

```java
@Controller
public class DemoController {
    @Mapping("/demo/")
    public String demo(Locale locale) {
        return I18nUtil.getMessage(locale, "login.title");
    }
}
```

* 使用国际化服务类，获取特定语言包

```java
@Controller
public class LoginController {
    I18nService i18nService = new I18nService("i18n.login");

    @Mapping("/demo/")
    public String demo(Locale locale) {
        return i18nService.get(locale, "login.title");
    }
}
```


* 使用国际化注解，为视图模板提供支持

```java
@I18n("i18n.login") //可以指定语言包
//@I18n //或不指定（默认消息）
@Controller
public class LoginController {
    @Mapping("/login/")
    public ModelAndView login() {
        return new ModelAndView("login.ftl");
    }
}
```

在各种模板里的使用方式


beetl::
```html
i18n::${i18n["login.title"]}
i18n::${@i18n.get("login.title")}
i18n::${@i18n.getAndFormat("login.title",12,"a")}
```

enjoy::
```html
i18n::#(i18n.get("login.title"))
i18n::#(i18n.getAndFormat("login.title",12,"a"))
```

freemarker::
```html
i18n::${i18n["login.title"]}
i18n::${i18n.get("login.title")}
i18n::${i18n.getAndFormat("login.title",12,"a")}
```

thymeleaf::
```html
i18n::<span th:text='${i18n.get("login.title")}'></span>
i18n::<span th:text='${i18n.getAndFormat("login.title",12,"a")}'></span>
```

velocity::
```html
i18n::${i18n["login.title"]}
i18n::${i18n.get("login.title")}
i18n::${i18n.getAndFormat("login.title",12,"a")}
```
