??xml version="1.0" encoding="utf-8" standalone="yes"?> 对于开发对于页面连接尤如蜘蛛网一Pl常会有一堆具有千头万l的兌面l成的大中型Web应用来说Q如何组l及处理面的蟩转成Z个MVC框架非常关键因素。Struts1之所以能得到大家的认可,是因Z基本解决了数据与视图分离的问题,之所以Struts升一个版本到Struts2后不?#8220;Struts”了,核心原因除了框架核心技术落后、很多地方受限制以外Q一个原因是他无法很好地l织及处理页面蟩转问题。当然尽升U到了Struts2Q但相对于Rails{新兴MVC的框架来_昑־L了很多?br />
而EasyJWeb在页面组l及处理面跌{{方面,提供了很多更加灵zȝ功能Q很多思想来自于Spring MVC、Rails{一些新兴Web框架的精髓,他能让你用比较简z的代码、甚至不用代码来实现面的蟩转?br />
在Web应用E序开发中Q我们经帔R到如下的需求: 可以_现在很少有框架能完全满或者ؓ用户考虑到如此复杂多变而对于我们国人来说应用性又非常q泛的需求。一些框架即使提供上面一些功能也是以书写复杂的代码及配置文gZL。在EasyJWeb中,提供了上面所列的q些功能Qƈ提供了非常简z的调用接口及方法?br />
针对上面的几点,EasyJWeb的解x案:
1、从q个面q接到另外一个页面;
2、在服务器执行完某一D늨序后Q把输出导向另外一个页面;
3、在服务器端执行完某一D늨序后Q把输出导向到另外一D늨序l执行;
4、在服务器程序执行完后,选择使用一个页面呈现用戯出;
5、页面蟩转要h较强的环境适应能力Q比如部|在跟目录下跟部|到其它Context目录下都能执行正的跌{Q?br />
6、还有更变态的Q比如EasyJF官网Q要求?a target="_blank">动态地址讉K的时候,看到的地址全是动态,当?a target="_blank">静态地址讉K的时候,地址全是静态的QJava Web服务器不能工作了QApache或IIS也要保证|页能正常访问?br />
7、有的h喜欢使用/user/edit/1q样的urlQ有的h喜欢使用/user.ejf?cmd=edit&id=1q样的urlQ我们要求不用哪一Uurl样式讉K面Q连接都会非常友好的变成用户喜爱的Ş式?/p>
1,q个?lt;a>标签Q不用说了?br />
2、在服务器执行完某一D늨序后Q把输出导向另外一个页面;
q回htmlcd的Page对象?br />
3、在服务器端执行完某一D늨序后Q把输出导向到另外一D늨序l执行;
使用forward或者goҎ?/strong>
4、在服务器程序执行完后,选择使用一个页面呈现用戯出;
使用pageҎ?br />
5、页面蟩转要h较强的环境适应能力Q比如部|在跟目录下跟部|到其它Context目录下都能执行正的跌{Q?br />
在页面模板中使用$html.urlQ比如:<a href="$html.url('user.list')">用户列表</a>?br />
6、不同地址样式转移
在页面模板中使用$html.forwardQ比?lt;a href="$html. forward'('news.technic')">技术前?lt;/a>。这样动态的时候访问到的是news.ejf?cmd= technicQ静态的时候访问到的是/news/technic.html?/strong>
7、传l及C的URL样式转换
仍然是?html.urlQ或$html.forward标签Q他能感知你的url样式。比如:<a href="$html.url('user.add')">d用户</a>。你使用user.ejf?cmd=lsit,讉K应用Q则当点duser.ejf?cmd=add。而如果你使用/ejf/user/list讉K应用Q则~辑按钮的连接变成ejf/user/add?br />
在代码中Q除了可以用最原始的return new Page()方式q回用户的视图模板以外,q可以用一些快h法来实现灉|的视图查询及跌{。比如,go、forward、page{方法。下面看一个用h删改查的CZ中的Action代码如下Q?br />
import com.easyjf.container.annonation.Inject;
import com.easyjf.core.support.query.QueryObject;
import com.easyjf.util.CommUtil;
import com.easyjf.web.WebForm;
import com.easyjf.web.core.AbstractPageCmdAction;
import com.easyjf.web.tools.IPageList;
public class UserAction extends AbstractPageCmdAction {
@Inject
private UserService service;
public void setService(UserService service) {
this.service = service;
}
/**
* 昄d用户的界面user/edit.html
*/
public void add()
{
page("edit");
}
public void edit(WebForm form)
{
String id=(String)form.get("id");
User user=this.service.getUser(new Long(id));
form.addPo(user);
}
public void save(WebForm form)
{
User user=form.toPo(User.class);
if(hasErrors())
{
page("edit");
return;
}
service.saveUser(user);
forward("list");
}
public void update(WebForm form)
{
String id=(String)form.get("id");
User user=this.service.getUser(new Long(id));
form.toPo(user,true);
if(hasErrors())
{
page("edit");
return;
}
service.updateUser(user);
forward("list");
}
public void delete(WebForm form)
{
String id=(String)form.get("id");
User user=this.service.getUser(new Long(id));
service.delUser(user);
go("list");
}
public void list(WebForm form)
{
QueryObject qo=form.toPo(QueryObject.class);
IPageList pageList=service.queryUser(qo);
CommUtil.saveIPageList2WebForm(pageList, form);
}
}
UserService接口Q?br />
public interface UserService {
/**
* Ҏid查询用户
*
* @param id
* @return
*/
User getUser(Long id);
/**
* 保存用户
*
* @param user
*/
void saveUser(User user);
/**
* 修改用户信息
*
* @param user
*/
void updateUser(User user);
/**
* 删除用户
*
* @param user
*/
void delUser(User user);
/**
* 查询用户信息
* @param query
* @return 分页信息及记录集
*/
IPageList queryUser(IQueryObject query);
}
import java.util.List;
import java.util.Random;
public class PrimeNumberTest {
/** Creates a new instance of PrimeNumberTest */
public PrimeNumberTest() { }
public static void main(String[] args){
//获得一?位数的随机大素数
long longVar4 = createRadomPrimeNunber(4);
System.out.println(longVar4);
//获得一?位数的随机大素数
long longVar5 = createRadomPrimeNunber(5);
System.out.println(longVar5);
}
public static long createRadomPrimeNunber(int n){
long recLong = 0;
List list = listAllPrimeNumber(n);
Random rd = new Random();
int randomIndex = Math.abs( rd.nextInt()%list.size());
recLong = ((Long)list.get(randomIndex)).longValue();
return recLong;
}
public static List listAllPrimeNumber(int n){
List list = new ArrayList();
long low = (long)Math.pow(10,n-1);
long high = (long)Math.pow(10,n) - 1;
for(long i= low;i < high;i++){
if( isSushu(i)) {
list.add(new Long(i));
} }
return list;
}
public static boolean isSushu(long x){
//定义一个判断一个数是否是素数的函数
if(x<2) return false; if( x==2)return true;
for(long i=2;
i<= (long)Math.sqrt(x);i++)
if(x%i==0)
return false;
return true;
}}
import java.util.Random;
/**
* Java实用工具cd中的cjava.util.Random提供了生各U类型随机数的方法?br />
* 它可以生int、long、float、double以及Goussian{类型的随机数?br />
* java.lang.Math中的Ҏrandom()只生double型的随机数?br />
*/
public class RandomNumber{
public static void main(String[] args) {
// 使用java.lang.Math的randomҎ生成随机?br /> System.out.println("Math.random(): " + Math.random());
// 使用不带参数的构造方法构造java.util.Random对象
System.out.println("使用不带参数的构造方法构造的Random对象:");
Random rd1 = new Random();
// 产生各种cd的随机数
// 按均匀分布产生整数
System.out.println("int: " + rd1.nextInt());
// 按均匀分布产生长整?br />
System.out.println("long: " + rd1.nextLong());
// 按均匀分布产生大于{于0Q小?的float数[0, 1)
System.out.println("float: " + rd1.nextFloat());
// 按均匀分布产生[0, 1)范围的double?br />
System.out.println("double: " + rd1.nextDouble());
// 按正态分布生随机数
System.out.println("Gaussian: " + rd1.nextGaussian());
// 生成一pd随机?br />
System.out.print("随机整数序列:");
for (int i = 0; i < 5; i++) {
System.out.print(rd1.nextInt() + " ");
}
System.out.println();
// 指定随机C生的范围
System.out.print("[0,10)范围内随机整数序? ");
for (int i = 0; i < 10; i++) {
// Random的nextInt(int n)Ҏq回一个[0, n)范围内的随机?br />
System.out.print(rd1.nextInt(10) + " ");
}
System.out.println();
System.out.print("[5,23)范围内随机整数序? ");
for (int i = 0; i < 10; i++) {
// 因ؓnextInt(int n)Ҏ的范围是?开始的Q?br />
// 所以需要把区间[5,28)转换? + [0, 23)?br />
System.out.print(5 + rd1.nextInt(23) + " ");
}
System.out.println();
System.out.print("利用nextFloat()生成[0,99)范围内的随机整数序列: ");
for (int i = 0; i < 10; i++) {
System.out.print((int) (rd1.nextFloat() * 100) + " ");
}
System.out.println();
System.out.println();
// 使用带参数的构造方法构造Random对象
// 构造函数的参数是longcdQ是生成随机数的U子?br />
System.out.println("使用带参数的构造方法构造的Random对象:");
Random ran2 = new Random(10);
// 对于U子相同的Random对象Q生成的随机数序列是一L?br />
System.out.println("使用U子?0的Random对象生成[0,10)内随机整数序? ");
for (int i = 0; i < 10; i++) {
System.out.print(ran2.nextInt(10) + " ");
}
System.out.println();
Random ran3 = new Random(10);
System.out.println("使用另一个种子ؓ10的Random对象生成[0,10)内随机整数序? ");
for (int i = 0; i < 10; i++) {
System.out.print(ran3.nextInt(10) + " ");
}
System.out.println();
// ran2和ran3生成的随机数序列是一LQ如果用两个没带参数构造函数生成的Random对象Q?br />
// 则不会出现这U情况,q是因ؓ在没带参数构造函数生成的Random对象的种子缺省是当前pȝ旉的毫U数?/p>
// 另外Q直接用Random无法避免生成重复的数字,如果需要生成不重复的随机数序列Q需要借助数组和集合类
//本书W?章将l出解决Ҏ?br />
}
}
q行l果Q?br />
C:\>java RandomNumber
Math.random(): 0.525171492959965
使用不带参数的构造方法构造的Random对象:
int: 636539740
long: -752663949229005813
float: 0.87349784
double: 0.4065973309853902
Gaussian: 0.4505871918488808
随机整数序列:1936784917 1339857386 -1185229615 1883411721 1409219372
[0,10)范围内随机整数序? 1 1 5 5 9 0 1 0 2 4
[5,23)范围内随机整数序? 9 13 26 18 11 27 26 12 21 8
利用nextFloat()生成[0,99)范围内的随机整数序列: 1 47 72 59 49 86 80 88 55 82
使用带参数的构造方法构造的Random对象:
使用U子?0的Random对象生成[0,10)内随机整数序?
3 0 3 0 6 6 7 8 1 4
使用另一个种子ؓ10的Random对象生成[0,10)内随机整数序?
3 0 3 0 6 6 7 8 1 4
例三:带随机种子的随机?br />
import java.util.*;
public class test {
public static void main(String[] args) {
Random rand = new Random();
for(int i = 0; i < 10; i++) {
rand.setSeed(i);
System.out.println(rand.nextInt());
}
}
}
USE tempdb
GO
-- 创徏试?/span>
CREATE TABLE tb(id char(8))
-- 创徏用于自动qo重复值的唯一索引
CREATE UNIQUE INDEX IX_tb ON tb(id)
WITH IGNORE_DUP_KEY
GO
-- 试数据插入的处理时?/span>, 记录开始处理的旉?/span>
DECLARE @dt datetime
SET @dt = GETDATE()
-- 插入随机数据
SET NOCOUNT ON
DECLARE @row int
SET @row = 1000000 -- 讄总记录数
WHILE @row >0
BEGIN
-- 昄提示信息, 表示q需要插入多行数?/span>
RAISERROR('need %d rows', 10, 1, @row) WITH NOWAIT
-- 插入随机的位~码数据
SET ROWCOUNT @row
INSERT tb SELECT
id = RIGHT(100000000 + CONVERT(bigint, ABS(CHECKSUM(NEWID()))), 8)
FROM syscolumns c1, syscolumns c2
SET @row = @row - @@ROWCOUNT
END
-- 昄插入数据使用的时?/span>
SELECT BeginDate = @dt, EndDate = GETDATE(),
Second = DATEDIFF(Second, @dt, GETDATE()),
GO
-- 昄最l的l果记录是否正确
SELECT COUNT(*) FROM tb
GO
-- 删除试
DROP TABLE tb
解决中用到的技巧:
1Q?/font> 控制产生的数据不重复Q直接用唯一索引中的IGNORE_DUP_KEY选项Q插入数据中的重复D动过滤,避免手工处理重复
2Q?/font> 使用CHECKSUM配合NEWID()函数Q生成的数据尽量随机,一般生成随机数会考虑使用RAND()函数Q但q个函数是生伪随机|用下面的语句试一下,会发C生的数据全部是一LQ这不适用于想扚w生成多个随机敎ͼ?/span>NEWID()函数生成的是GUIDQ基本上不会有重复的Q再通过CHECKSUM其转化成数字,q样产生重复的可能性会比较?/span>
SELECT TOP 10
RAND()
FROM sysobjects
3Q?/font> 在效率控Ӟ使用循环+扚w生成的方式,而不是传l的逐个生成。在SQL Server中,每个插入语句都会有一个内部的事务处理Q如果逐条插入Q则事务的开销太大Q效率势必非怽Q不考虑一ơ性生?/span>100万数据,一则因为生成的数据可能有重复的Q去掉重复就没有100万了Q二则一ơ性生?/span>100万数据,消耗的内存?/span>CPU资源也很高,一般的电脑可能承受不住