Douyu是一种完全采用Java语言开发的、运行于JVM之上的新型基础开发平台。
在web层,Douyu完全抛弃了JSP/Servlet,
在数据库访问层,Douyu不依赖于任何ORM(对像关系映射)框架(如Hibernate)。
Douyu将Java语言编译器、Http服务器、MVC完美整合在一起,
几乎实现了ORM全自动化,同时在Java语言层面引入了权限管理模型。
Douyu内置的Java语言编译器基于OpenJDK Javac编译器(b60版),
并进行了修改和扩充,跟Http服务器结合之后能在控制器层发挥出强大的威力,
你只要修改Java源文件,然后刷新浏览器就能查看运行结果,
同时编译器也是实现ORM自动化的基石。
Douyu内置的Http服务器是基于NIO技术的,
是对Tomcat6及com.sun.net.httpserver(总共1300多个Java源文件)进行大刀阔斧的改造后得来的,
改造后的Http服务器目前只有60个左右的源文件,支持Http1.0/1.1协议。
Douyu内置的权限管理模型目前包含了功能权限、字段权限两类,
功能权限一般对应控制器类中的Action方法,Action方法可以与表单中的按钮关联,
字段权限能控制表单中的字段是否可以查看、修改或隐藏。
Douyu内置的ORM已几乎实现自动化,你只须建个数据库表(如pet),
然后在服务器配置文件中配置数据库驱动、并为每个数据库指定一个包名(如my.oracle.table),
然后就你可以在你的Java源文件中用import my.oracle.table.Pet导入模型类Pet。
Douyu还支持横跨多个数据库的事务,还支持保存点(Savepoint)。
Douyu项目主页目前放在:
http://code.google.com/p/douyu/
下面是一些简单的代码片断:
Hello World
自动提取表单参数:
文件上传
基本的CRUD操作
横跨多个数据库的事务
Douyu将使用两种开源协议:GPL2.0、 Apache License Version 2.0
所有与编译器有关的源代码使用GPL2.0协议(因为OpenJDK Javac编译器是使用这个协议的)
其他源代码使用Apache License Version 2.0协议开源。
不过目前Douyu的版本只是0.1.0,还不稳定,所以只是提供了二进制版,
目前我也并不推荐你研究Douyu的源代码,因为这可能会浪费你的时间,
因为Douyu的内部实现变动很频繁,在一年之内,大大小小的版本变更次数已超过100次了,
源代码中的注释也非常少,根本就来不急写,等过几个版本稳定先后再发布源代码。
目前Douyu的开发工作只有我一个人,全凭个人兴趣在家全职开发,
如果你对Douyu的实现有兴趣,想参与进来,我也是欢迎的,
但是你必须对Http协议、JDBC规范、Java语言编译器有相当程度的了解,
否则的话你可能在看Douyu的源代码时很吃力。
要想了解更多内容请看:
Without SSH/JSP/Servlet,不走寻常路,Java可以更酷
http://zhh2009.javaeye.com/blog/517796
这篇文章是昨晚在JavaEye刚发布的,详细说明了Douyu的更种用法,
里面也详细说明了Douyu的很多设计理念以及我个人的很多研究心得。
赶快去看看吧。。。
在web层,Douyu完全抛弃了JSP/Servlet,
在数据库访问层,Douyu不依赖于任何ORM(对像关系映射)框架(如Hibernate)。
Douyu将Java语言编译器、Http服务器、MVC完美整合在一起,
几乎实现了ORM全自动化,同时在Java语言层面引入了权限管理模型。
Douyu内置的Java语言编译器基于OpenJDK Javac编译器(b60版),
并进行了修改和扩充,跟Http服务器结合之后能在控制器层发挥出强大的威力,
你只要修改Java源文件,然后刷新浏览器就能查看运行结果,
同时编译器也是实现ORM自动化的基石。
Douyu内置的Http服务器是基于NIO技术的,
是对Tomcat6及com.sun.net.httpserver(总共1300多个Java源文件)进行大刀阔斧的改造后得来的,
改造后的Http服务器目前只有60个左右的源文件,支持Http1.0/1.1协议。
Douyu内置的权限管理模型目前包含了功能权限、字段权限两类,
功能权限一般对应控制器类中的Action方法,Action方法可以与表单中的按钮关联,
字段权限能控制表单中的字段是否可以查看、修改或隐藏。
Douyu内置的ORM已几乎实现自动化,你只须建个数据库表(如pet),
然后在服务器配置文件中配置数据库驱动、并为每个数据库指定一个包名(如my.oracle.table),
然后就你可以在你的Java源文件中用import my.oracle.table.Pet导入模型类Pet。
Douyu还支持横跨多个数据库的事务,还支持保存点(Savepoint)。
Douyu项目主页目前放在:
http://code.google.com/p/douyu/
下面是一些简单的代码片断:
Hello World
- @Controller
- public class HelloWorld {
- public void index(PrintWriter out) {
- out.println("Hello World!");
- }
- }
@Controller
public class HelloWorld {
public void index(PrintWriter out) {
out.println("Hello World!");
}
}
自动提取表单参数:
- <FORM METHOD=POST ACTION="User/show">
- 姓名:<INPUT TYPE="text" NAME="name">
- 年龄:<INPUT TYPE="text" NAME="age">
- <INPUT TYPE="submit">
- </FORM>
<FORM METHOD=POST ACTION="User/show">
姓名:<INPUT TYPE="text" NAME="name">
年龄:<INPUT TYPE="text" NAME="age">
<INPUT TYPE="submit">
</FORM>
- @Controller
- public class User {
- public void show(String name, int age) {
- ...
- }
- }
@Controller
public class User {
public void show(String name, int age) {
...
}
}
文件上传
- <FORM ENCTYPE="multipart/form-data" METHOD="POST" ACTION="FileUpload">
- 文件1:<INPUT NAME="file1" TYPE="file"><br>
- 说明 :<TEXTAREA NAME="description"></TEXTAREA><br>
- <INPUT TYPE="submit" VALUE="上传">
- </FORM>
<FORM ENCTYPE="multipart/form-data" METHOD="POST" ACTION="FileUpload">
文件1:<INPUT NAME="file1" TYPE="file"><br>
说明 :<TEXTAREA NAME="description"></TEXTAREA><br>
<INPUT TYPE="submit" VALUE="上传">
</FORM>
- import com.douyu.http.UploadedFile;
- @Controller
- public class FileUpload {
- public void index(UploadedFile file1, String description) {
- File f = new File("D:/Douyu/temp/uploadedFiles", file1.getSimpleName());
- file1.saveTo(f);
- }
- }
import com.douyu.http.UploadedFile;
@Controller
public class FileUpload {
public void index(UploadedFile file1, String description) {
File f = new File("D:/Douyu/temp/uploadedFiles", file1.getSimpleName());
file1.saveTo(f);
}
}
基本的CRUD操作
- create table pet(
- id int not null auto_increment,
- name varchar(50) not null,
- age int,
- primary key(id)
- );
create table pet(
id int not null auto_increment,
name varchar(50) not null,
age int,
primary key(id)
);
- import com.douyu.main.Context;
- import sql.table.mysql.Pet;
- @Controller
- public class Crud {
- public void index(Context c) {
- Pet pet = new Pet();
- pet.name("pet1");
- pet.age(3);
- c.insert(pet);
- pet.name("MyPet");
- c.update(pet);
- c.delete(pet);
- Rows<Pet> rows = new Rows<Pet>(Pet.class);
- rows.offset = 1;
- rows.limit = 100;
- c.select(rows);
- for(Pet p : rows.rowList) {
- ...
- }
- }
- }
import com.douyu.main.Context;
import sql.table.mysql.Pet;
@Controller
public class Crud {
public void index(Context c) {
Pet pet = new Pet();
pet.name("pet1");
pet.age(3);
c.insert(pet);
pet.name("MyPet");
c.update(pet);
c.delete(pet);
Rows<Pet> rows = new Rows<Pet>(Pet.class);
rows.offset = 1;
rows.limit = 100;
c.select(rows);
for(Pet p : rows.rowList) {
...
}
}
}
横跨多个数据库的事务
- import com.douyu.main.Context;
- import my.table.oracle.Table1;
- import my.table.mysql.Table2;
- @Controller
- public class Transaction {
- public void index(Context c) {
- Table1 t1 = new Table1();
- t1.f1("1234");
- Table2 t2 = new Table2();
- t2.f2("1234");
- c.beginTransaction();
- c.insert(t1);
- c.insert(t2);
- c.setSavepoint();
- t2.f2("abcd");
- c.update(t2);
- c.endTransaction();
- }
- }
import com.douyu.main.Context;
import my.table.oracle.Table1;
import my.table.mysql.Table2;
@Controller
public class Transaction {
public void index(Context c) {
Table1 t1 = new Table1();
t1.f1("1234");
Table2 t2 = new Table2();
t2.f2("1234");
c.beginTransaction();
c.insert(t1);
c.insert(t2);
c.setSavepoint();
t2.f2("abcd");
c.update(t2);
c.endTransaction();
}
}
Douyu将使用两种开源协议:GPL2.0、 Apache License Version 2.0
所有与编译器有关的源代码使用GPL2.0协议(因为OpenJDK Javac编译器是使用这个协议的)
其他源代码使用Apache License Version 2.0协议开源。
不过目前Douyu的版本只是0.1.0,还不稳定,所以只是提供了二进制版,
目前我也并不推荐你研究Douyu的源代码,因为这可能会浪费你的时间,
因为Douyu的内部实现变动很频繁,在一年之内,大大小小的版本变更次数已超过100次了,
源代码中的注释也非常少,根本就来不急写,等过几个版本稳定先后再发布源代码。
目前Douyu的开发工作只有我一个人,全凭个人兴趣在家全职开发,
如果你对Douyu的实现有兴趣,想参与进来,我也是欢迎的,
但是你必须对Http协议、JDBC规范、Java语言编译器有相当程度的了解,
否则的话你可能在看Douyu的源代码时很吃力。
要想了解更多内容请看:
Without SSH/JSP/Servlet,不走寻常路,Java可以更酷
http://zhh2009.javaeye.com/blog/517796
这篇文章是昨晚在JavaEye刚发布的,详细说明了Douyu的更种用法,
里面也详细说明了Douyu的很多设计理念以及我个人的很多研究心得。
赶快去看看吧。。。