可以说是Java界最精简的框架,不到1M的jar包可以替代Tomcat、Spring/Spring Boot、Hibernate/MyBatis、JackJson/fastjson、Netty的集合,四两拨千斤。低调开源一年多,经过两次大的改善后终于达到让自己满意的地步。Redkale不仅仅提供简易的API,还附有很多不同于传统思维的设计思路。由于时间有限,一年多也没写入门教程,现在开始抽点时间写一些教程,希望能给想学Redkale的同学一点帮助。 废话不多说,下面进入正题。
创建工程
首先创建一个Maven项目。
创建完项目后会自动打开pom.xml文件, 按下Alt+Insert组合键添加redkale依赖。
然后将redkale下的bin和conf文件夹(可以通过github或者maven里解压得到)复制到工程的目录下。
编写HelloService类。
package com.redkale.examples.hello;import org.redkale.net.http.*;import org.redkale.service.Service;@RestService(automapping = true)public class HelloService implements Service { public String sayHello() { return "Hello World!"; } public String hi(String name) { return "Hi, " + name + "!"; }}
然后开始调试运行。
在浏览器输入: http://127.0.0.1:6060/pipes/hello/say 可以看到结果:
在浏览器输入: http://127.0.0.1:6060/pipes/hello/hi?name=Redkale 可以看到结果:
访问地址的端口6060和前缀pipes是通过conf/application.xml文件进行配置:
至此,一个简单的Hello服务就开发和调试完成了。可以看出,代码简单很多,不需要太多配置、maven和其他依赖包。
可能有人会疑惑: HelloServie为什么能分配到hello前缀? sayHello为什么会映射到/pipes/hello/say 请求? Redkale为了减少Annotation配置采取了一些默认值的策略, 在Redkale里, 一个Service视为一个模块或服务,所以需要有模块(服务)名的概念,用于服务管理和鉴权,通常需要通过@RestServie.name来指定模块名,没有指定则默认将Service类名的Service字样之前的字符串视为模块名,如HelloService和HelloServiceImpl都会采用hello作为模块名。方法名的默认值策略也是类似,将模块名字样之前的字符串作为方法名,如sayHello和sayHelloMe 都会用say作为默认值。参数名如果没有指定@RestParam.name会自动采用代码的变量名。 完全标记Rest注解的HelloService源码如下:package com.redkale.examples.hello;import org.redkale.net.http.*;import org.redkale.service.Service;@RestService(name = "hello")public class HelloService implements Service { @RestMapping(name = "say") public String sayHello() { return "Hello World!"; } @RestMapping(name = "hi") public String hi(@RestParam(name = "name") String name) { return "Hi, " + name + "!"; }}
这段代码与上面那段是等价的。部署也很简单, 将项目编译后的jar和redkale-1.9.5.jar复制到lib下(也可通过修改pom.xml让maven来处理),运行bin/start.bat 即可启动HTTP服务。
本工程源码可以在 下载。
转载请注明出处: