Douyu 能让我们抛弃 ssh 吗?

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


Java代码 复制代码
  1. @Controller  
  2. public class HelloWorld {   
  3.     public void index(PrintWriter out) {   
  4.         out.println("Hello World!");   
  5.     }   
  6. }  
@Controller
public class HelloWorld {
	public void index(PrintWriter out) {
		out.println("Hello World!");
	}
}



自动提取表单参数:


Html代码 复制代码
  1. <FORM METHOD=POST ACTION="User/show">  
  2.     姓名:<INPUT TYPE="text" NAME="name">  
  3.     年龄:<INPUT TYPE="text" NAME="age">  
  4.     <INPUT TYPE="submit">  
  5. </FORM>  
<FORM METHOD=POST ACTION="User/show">
	姓名:<INPUT TYPE="text" NAME="name">
	年龄:<INPUT TYPE="text" NAME="age">
	<INPUT TYPE="submit">
</FORM>


Java代码 复制代码
  1. @Controller  
  2. public class User {   
  3.     public void show(String name, int age) {   
  4.         ...   
  5.     }   
  6. }  
@Controller
public class User {
	public void show(String name, int age) {
		...
	}
}


文件上传


Html代码 复制代码
  1. <FORM ENCTYPE="multipart/form-data" METHOD="POST" ACTION="FileUpload">  
  2.    文件1:<INPUT NAME="file1" TYPE="file"><br>  
  3. 说明 :<TEXTAREA NAME="description"></TEXTAREA><br>  
  4.    <INPUT TYPE="submit" VALUE="上传">  
  5.    </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>


Java代码 复制代码
  1. import com.douyu.http.UploadedFile;   
  2.   
  3. @Controller  
  4. public class FileUpload {   
  5.     public void index(UploadedFile file1, String description) {   
  6.         File f = new File("D:/Douyu/temp/uploadedFiles", file1.getSimpleName());   
  7.         file1.saveTo(f);   
  8.     }   
  9. }  
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操作


Java代码 复制代码
  1. create table pet(   
  2.   id  int not null auto_increment,   
  3.   name varchar(50) not null,   
  4.   age int,   
  5.   primary key(id)   
  6. );  
create table pet(
  id  int not null auto_increment,
  name varchar(50) not null,
  age int,
  primary key(id)
);


Java代码 复制代码
  1. import com.douyu.main.Context;   
  2. import sql.table.mysql.Pet;   
  3.   
  4. @Controller  
  5. public class Crud {   
  6.     public void index(Context c) {   
  7.         Pet pet = new Pet();   
  8.         pet.name("pet1");   
  9.         pet.age(3);   
  10.         c.insert(pet);   
  11.   
  12.         pet.name("MyPet");   
  13.         c.update(pet);   
  14.   
  15.         c.delete(pet);   
  16.   
  17.         Rows<Pet> rows = new Rows<Pet>(Pet.class);   
  18.         rows.offset = 1;   
  19.         rows.limit = 100;   
  20.         c.select(rows);   
  21.         for(Pet p : rows.rowList) {   
  22.             ...   
  23.         }   
  24.     }   
  25. }  
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) {
			...
		}
	}
}



横跨多个数据库的事务


Java代码 复制代码
  1. import com.douyu.main.Context;   
  2. import my.table.oracle.Table1;   
  3. import my.table.mysql.Table2;   
  4.   
  5. @Controller  
  6. public class Transaction {   
  7.     public void index(Context c) {   
  8.         Table1 t1 = new Table1();   
  9.         t1.f1("1234");   
  10.         Table2 t2 = new Table2();   
  11.         t2.f2("1234");   
  12.   
  13.         c.beginTransaction();   
  14.   
  15.         c.insert(t1);   
  16.         c.insert(t2);   
  17.   
  18.         c.setSavepoint();    
  19.   
  20.         t2.f2("abcd");   
  21.         c.update(t2);   
  22.   
  23.         c.endTransaction();   
  24.     }   
  25. }  
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的很多设计理念以及我个人的很多研究心得。

赶快去看看吧。。。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值