# Storm-Server **Repository Path**: mirrors/Storm-Server ## Basic Information - **Project Name**: Storm-Server - **Description**: Storm-Server,以 Jetty 为 Servlet 容器的一个 Java Web 框架,主要用于为前端提供 API 服务,具有快速开发的优势 - **Primary Language**: Java - **License**: Apache-2.0 - **Default Branch**: master - **Homepage**: https://www.oschina.net/p/storm-server - **GVP Project**: No ## Statistics - **Stars**: 4 - **Forks**: 2 - **Created**: 2017-09-15 - **Last Updated**: 2026-01-03 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README > @author stormma > @date 2017/09/15 --- > storm-server使用指南 #### storm-server ##### storm-server介绍 > storm-server, 以jetty为servlet容器的一个java web框架, 主要用于为前端提供api服务, 具有快速开发的优势。storm-server之后会提供一些操作mysql, redis的工具, storm-server旨在快速开发一些小型的web应用, 以及用于日常学习。storm-server github地址: https://github.com/stormmaybin/storm-server.git, 欢迎各位star和参与开发,storm-server期待你的参与与建议。 ##### 小试牛刀 ###### 引入storm-server依赖(最新版本1.0,后期会跟进升级和维护) ```xml 4.0.0 com.github.stormmaybin storm-server-test 1.0-SNAPSHOT 1.0 me.stormma storm-server ${storm-server.version} ``` ###### 添加storm.properties配置文件 ```properties storm.server.port=8057 # 端口默认为8057 storm.server.module=storm_server_test #模块名 storm.ansi.output.enabled=true # 不同级别日志显示颜色不同 ``` > storm-server默认去classpath下读取storm.properties配置文件, 当然, 你也可以指定配置文件的路径和名字, 如果你选择这么做了,那么你要在运行启动类时候传入配置文件的完整路径, 例如: 假如我的配置文件名字叫application.properties, 放在resources/config/,那么你需要在运行启动类(下面会说到)的时候传入参数'resources/config/application.properties'。 ###### 添加logback.xml ```xml ``` > storm-server使用logback日志系统,storm-server已经提供了base.xml, 你只需要新建logback.xml,添加base.xml即可,当然你也可以加入自己的配置。 ###### 启动storm-server ``` java package com.github.stormmaybin.controller; import me.stormma.StormApplication; import me.stormma.annotation.Application; import me.stormma.annotation.ComponentScan; /** * @description 启动类 * @author stormma * @date 2017/09/15 */ @ComponentScan @Application(StormServerTestApplication.class) public class StormServerTestApplication { public static void main(String[] args) { StormApplication.run(args); } } ``` ###### 新建service ``` package com.github.stormmaybin.controller.service.impl; import com.github.stormmaybin.controller.model.User; import com.github.stormmaybin.controller.service.ITestService; import me.stormma.ioc.annotation.Service; /** * @description * @author stormma * @date 2017/09/15 */ @Service public class TestService implements ITestService { @Override public User getUserById(int uid) { //模拟dao层操作 User user = new User(); user.setUsername("stormma"); user.setPassword("stormma"); return user; } } ``` > @Service注解声明此类是一个service, 这与spring mvc/boot保持一致 ###### 新建controller ``` package com.github.stormmaybin.controller.controller; import com.github.stormmaybin.controller.model.User; import com.github.stormmaybin.controller.service.ITestService; import me.stormma.core.http.annotation.Api; import me.stormma.core.http.annotation.JsonParam; import me.stormma.core.http.annotation.RequestParam; import me.stormma.core.http.enums.RequestMethod; import me.stormma.core.http.model.HttpContext; import me.stormma.core.http.response.Response; import me.stormma.core.http.response.builder.ResponseBuilder; import me.stormma.ioc.annotation.AutoWired; import me.stormma.ioc.annotation.Controller; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import java.util.Date; /** * @author stormma * @date 2017/09/15 */ @Controller("/api") public class TestController { @AutoWired private ITestService testService; private static final Logger logger = LoggerFactory.getLogger(TestController.class); /** * 测试无参数情况的数据响应 * @return */ @Api(url = "/hello", method = RequestMethod.GET) public Response hello() { return ResponseBuilder.success("hello storm-server"); } /** * 测试绑定HttpContext * @param context * @return */ @Api(url = "/date", method = RequestMethod.GET) public Response getCurrentDate(HttpContext context) { logger.info("访问路径:{}", context.requestPath); return ResponseBuilder.success(new Date()); } @Api(url = "/array/int", method = RequestMethod.GET) public Response testIntArray(@RequestParam(name = "id") int[] ids) { for (int id: ids) { logger.info("{}", id); } return ResponseBuilder.success(); } @Api(url = "/array/Integer", method = RequestMethod.GET) public Response testIntegerArray(@RequestParam(name = "id") Integer[] ids) { for (Integer id: ids) { logger.info("{}", id); } return ResponseBuilder.success(); } @Api(url = "array/float", method = RequestMethod.GET) public Response testFloatArray(@RequestParam(name = "id") float[] ids) { for (float id: ids) { logger.info("{}", id); } return ResponseBuilder.success(); } @Api(url = "array/Float", method = RequestMethod.GET) public Response testFloatArray(@RequestParam(name = "id") Float[] ids) { for (Float id: ids) { logger.info("{}", id); } return ResponseBuilder.success(); } @Api(url = "array/Double", method = RequestMethod.GET) public Response testDoubleArray(@RequestParam(name = "id") Double[] ids) { for (Double id: ids) { logger.info("{}", id); } return ResponseBuilder.success(); } @Api(url = "array/double", method = RequestMethod.GET) public Response testDoubleArray(@RequestParam(name = "id") double[] ids) { for (double id: ids) { logger.info("{}", id); } return ResponseBuilder.success(); } @Api(url = "array/boolean", method = RequestMethod.GET) public Response testBooleanArray(@RequestParam(name = "id") boolean[] ids) { for (boolean id: ids) { logger.info("{}", id); } return ResponseBuilder.success(); } @Api(url = "array/Boolean", method = RequestMethod.GET) public Response testBooleanArray(@RequestParam(name = "id") Boolean[] ids) { for (Boolean id: ids) { logger.info("{}", id); } return ResponseBuilder.success(); } /** * 测试query string参数类型,和json参数类型结合的绑定 * @param id * @param user * @return */ @Api(url = "/get/user", method = RequestMethod.POST) public Response test(@RequestParam(name = "id") int id, @JsonParam User user) { System.out.println(user); User result = testService.getUserById(id); logger.info("json 参数: {}", user); logger.info("{}", result); return ResponseBuilder.success(result); } } ``` > storm-server建议响应数据统一化,controller method返回值都是Response 类型,Response是storm-server提供的一个响应数据封装类。 ```java public class Response { /** * error code :错误是1、成功是0 */ private Integer code; /** * 本次请求的status */ private Integer status; /** * 要返回的数据 */ private T data; /** * 本次请求的说明信息 */ private String msg; ``` > controller的用法和spring boot/mvc差别不大,storm-server提供了参数自动绑定,内部提供了String2Boolean, 默认的String2Date,还有String2Number三种转换器, 当然,如果这三种转换器不够满足你项目的需求,你也可以自定义一个converter, 实现Converter接口即可,具体的步骤为: ``` public class DefaultStringToDateConverter implements Converter { @Override public Date convert(String source) throws StormServerException { SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd"); Date date = null; try { date = simpleDateFormat.parse(source); } catch (ParseException e) { throw new StormServerException("string convert to date failed, because param is not valid."); } return date; } } ``` > 同样,storm-server提供了json参数自动绑定到对象上,@JsonParam注解可以帮你完成这个冗余的操作。 ###### 启动storm-server ![](http://blog.stormma.me/2017/09/15/storm-server%E4%BD%BF%E7%94%A8%E6%8C%87%E5%8D%97/storm-server.jpeg) ###### 使用maven打成可执行jar - 添加打包插件 ```xml org.apache.maven.plugins maven-jar-plugin 2.4 true lib/ com.github.stormmaybin.controller.StormServerTestApplication org.apache.maven.plugins maven-dependency-plugin copy package copy-dependencies ${project.build.directory}/lib ``` > 你要做的就是修改```MainClass```为你的启动类, 也就是调用```StormApplication.run(args)```的那个类。 ```java mvn clean package ``` > 打包结束之后会出现一个xxx.jar,然后执行java -jar xxx.jar即可运行。 ![](http://blog.stormma.me/2017/09/15/storm-server%E4%BD%BF%E7%94%A8%E6%8C%87%E5%8D%97/storm-server-jar-run.jpeg) ##### 结束语 > storm-server从开始开发到1.0版本的发布历经了1个月,这一个月其中的两周因为一些事情一行代码都没写,所以今天匆匆茫茫发布了1.0版本之后,甚是心虚,我深知storm-server现在还远远不够完善,但是作为学习资料足够了。我相信,storm-server后期的升级与维护,离不开你的支持、参与和建议,如果你对storm-server感兴趣,欢迎参与讨论,本人企鹅号: 1325338799, email: stormmaybin@gmail.com。 **storm-server对您有帮助? 求赞赏鼓励支持。** 支付宝: 18292817803