# simplewebserver **Repository Path**: 94fzb/simplewebserver ## Basic Information - **Project Name**: simplewebserver - **Description**: SimpleWebServer 是一款使用Java基于NIO编写的超轻量级开源Web Application Server - **Primary Language**: Java - **License**: Apache-2.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 74 - **Forks**: 36 - **Created**: 2015-02-24 - **Last Updated**: 2025-09-21 ## Categories & Tags **Categories**: web-service **Tags**: None ## README # SimpleWebServer [![Maven Central](https://img.shields.io/maven-central/v/com.hibegin/simplewebserver.svg?label=Maven%20Central)](https://central.sonatype.com/artifact/com.hibegin/simplewebserver) > SimpleWebServer 是一款使用Java基于NIO编写的超轻量级开源Web Application Server 是否遇到有时候想做一些小的Web程序,但是迫于Java运行环境过于繁琐而迟迟没有下手,那么现在除了SpringBoot,广大的Java程序员又多了一个选择 ### 轻量级 并不基于servlet,源代码仅3000行左右,jar包仅 0.1m 左右,零依赖,无xml,极低的内存占用,所以不用担心程序能不能在嵌入式(树莓派)/Android 上能否正常运行 ### 完整 ``` 基本常用API都有,还是熟悉的配方,熟悉的味道,web程序编写更容易 ``` - Request - Response - Controller - Cookie/Session - Interceptor - Json - Freemarker 模板 - 文件上传 - GZip - 静态文件服务器 ### GraalVM Native Java21 loom + GraalVM Native 让应用有更小的内存占用和更快捷的运行体验 在使用 Native 后,单个可执行文件大概 15mb 左右,通过 zip 后程序在 5m 左右,足够小(对比完整 JDK) ### SimpleWebServer-Cli 快速体验:https://github.com/94fzb/simplewebserver-cli 基于 simplewebserver,使用 GraalVM Native Image,提供一个简单文件服务分享服务(无需 Java环境) 类似 python 的一行代码启动一个基于 http 的文件服务,比 python 更简单,无需 pip ### 快速上手 #### Java 版本 - 必须: Java8 及以上版本, - 推荐: Java11 及以上的版本 ```xml com.hibegin simplewebserver 4.0.107 ``` ```java public class DemoController extends Controller { public static void main(String[] args) { ServerConfig serverConfig = new ServerConfig(); serverConfig.getRouter().addMapper("", DemoController.class); new WebServerBuilder.Builder().serverConfig(serverConfig).build().startWithThread(); } public void index() { getResponse().renderText("Hello world/v" + ServerInfo.getVersion()); } } ``` 然后浏览器输入 http://localhost:6058 ### 打包 **推荐使用 maven-assembly-plugin** ```xml maven-assembly-plugin 2.5.5 com.hibegin.http.server.test.DemoController simplewebserver-demo jar-with-dependencies ``` `mvn clean compile assembly:single` ### 性能 简单与号称 “性能打爆网卡的tio” 对比,感兴趣移步到 https://gitee.com/94fzb/simplewebserver-performance ## Changelog [完整的版本变化日志](CHANGELOG.md) ## TODO - 支持HTTP2.0基本协议(不包含服务端推送) - ~~实现多线程解码HTTP请求~~ - 提供类似 SpringMVC 通过注解完成 Restful API的编写 - ~~提供多种 JSON 序列化工具包支持~~ - ~~提供HTTP错误码错误页面配置功能~~ ## 其他 * WebServer 默认端口为 `6058` 在 `conf/conf.properties` 中,或则通过代码的方式进行配置 * 使用 `FreeMarkerKit.init` 初始化模板文件根目录,`FreeMarkerKit.initClassTemplate` 初始模板相对jar中的根目录 * 服务器上时建议打包为 `jar` 文件运行(推荐使用 maven,jar文件路径与`conf` 文件夹同目录) * 依赖的json和freemarker的jar都是非必须 ## License SimpleWebServer is Open Source software released under the [Apache 2.0 license](https://www.apache.org/licenses/LICENSE-2.0.html).