# blade
**Repository Path**: stc/blade
## Basic Information
- **Project Name**: blade
- **Description**: blade 是一个简洁强大的web框架,它内置了IOC管理,拦截器配置,REST API开发等众多主流web特性,集成了模板引擎,缓存插件,数据库操作,邮件发送,HTTP请求等常用功能
- **Primary Language**: Unknown
- **License**: Not specified
- **Default Branch**: master
- **Homepage**: http://bladejava.com
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 168
- **Created**: 2015-08-18
- **Last Updated**: 2024-11-23
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
#Blade
[](http://bladejava.com)
[English](https://github.com/biezhi/blade/blob/master/README.md)
[](http://weibo.com/u/5238733773)
[](http://www.apache.org/licenses/LICENSE-2.0.html)
[](https://travis-ci.org/biezhi/blade)
[](https://circleci.com/gh/biezhi/blade/tree/master)
[](http://search.maven.org/#search%7Cga%7C1%7Cg%3A%22com.bladejava%22)
**blade** 是一个简洁强大的web框架,它内置了`IOC`管理,拦截器配置,`REST API`开发等众多主流web特性,集成了模板引擎,缓存插件,数据库操作,邮件发送等常用功能,简洁的源码值得你阅读和学习。如果你喜欢,欢迎[Star and Fork](https://github.com/biezhi/blade) !
## Blade特性
* 简洁的MVC
* RESTful
* 多种路由配置方式
* 微内核IOC容器
* 实用工具类
* 编码/JSON/配置文件
* 模板引擎支持
* 支持JDK1.6+
* 插件扩展机制
* 缓存支持
* 不到100K的源码
## 快速入门
第一步、用maven构建一个webapp,加入blade的依赖,推荐获取[最新版本](LAST_VERSION.md)
```xml
com.bladejava
blade-core
1.2.7-alpha
```
第二步、在`web.xml`中配置Blade核心过滤器并设置你的初始化类,你也可以不配置(使用jetty启动)
```xml
BladeFilter
blade.BladeFilter
applicationClass
hello.App
BladeFilter
/*
```
第三步、编写App.java和路由文件,下面是一个示例
```java
public class App extends BladeApplication{
Logger logger = Logger.getLogger(App.class);
@Override
public void init() {
// 注册函数式路由
Blade.regRoute("/hello", SayHi.class, "hello");
// 匿名路由,java8方式更简化
Blade.get("/get", new RouteHandler() {
@Override
public String run(Request request, Response response) {
System.out.println("进入get!!");
System.out.println(request.query("name"));
return "get";
}
});
}
}
```
#### 函数式路由
```java
public class SayHi {
public String hello(Request request, Response response){
System.out.println("进入hello~");
request.attribute("name", "rose baby");
return "hi";
}
}
```
#### 注解路由
```java
@Path("/")
public class Hello {
@Route("hello")
public String hello() {
System.out.println("hello");
return "hello.jsp";
}
@Route(value = "post", method = HttpMethod.POST)
public void post(Request request) {
String name = request.query("name");
System.out.println("name = " + name);
}
@Route("users/:name")
public ModelAndView users(Request request, Response response) {
System.out.println("users");
String name = request.pathParam(":name");
ModelAndView modelAndView = new ModelAndView("users");
modelAndView.add("name", name);
return modelAndView;
}
@Route("index")
public String index(Request request) {
request.attribute("name", "jack");
return "index.jsp";
}
}
```
OK,这一切看起来多么的简单,查阅使用指南更多现成的例子供你参考:
+ [hello](https://github.com/bladejava/hello)
+ [api docs](http://bladejava.com/apidocs/)
+ [使用指南](https://github.com/biezhi/blade/wiki)
+ [更多例子](https://github.com/bladejava)
### 计划
1. 完善文档
2. 单用户博客系统
3. web聊天系统
4. 优化代码性能
## 更新日志
[更新日志](https://github.com/biezhi/blade/blob/master/UPDATE_LOG.md)
## 开源协议
Blade框架基于 [Apache2 License](http://www.apache.org/licenses/LICENSE-2.0.html)
## 联系我
OSC Blog:[http://my.oschina.net/biezhi](http://my.oschina.net/biezhi)
Mail: biezhi.me#gmail.com
Java交流群: [1013565](http://shang.qq.com/wpa/qunwpa?idkey=932642920a5c0ef5f1ae902723c4f168c58ea63f3cef1139e30d68145d3b5b2f)