发表于: sitebuild | 作者: | 日期: 2008/11/17 01:11
标签:

http://www.builder.com.cn/2008/0121/714534.shtml

评论关闭
发表于: sitebuild | 作者: | 日期: 2008/11/17 01:11
标签:

http://www.builder.com.cn/2007/1125/653149.shtml

评论关闭
发表于: sitebuild | 作者: | 日期: 2008/11/17 12:11
标签:

http://www.builder.com.cn/2007/1226/691123.shtml

评论关闭
发表于: lnmp | 作者: | 日期: 2008/11/17 12:11
标签: ,

1 第一次访问,检查该文件是否存在,如果没有缓存,从数据库中取出文件放到缓存里面,以后访问,就直接从缓存里面取。每一个静态页面都需要一个辅助的meta文件,例如wp-cache-12345.meta

为什么需要独立的meta?因为返回一个静态html还不够,还有很多信息,例如还需要这个页面的时间,content-type等信息。这些信息又不能存放在html中,所以需要辅助的.meta文件

meta文件中的内容是:
$meta_object->uri = $_SERVER[‘REQUEST_URI’];
$meta_object->post = wp_cache_post_id();
$meta_object->dynamic = true;
$meta_object->headers = array();

array_push($meta_object->headers, “Last-Modified: $value”);
array_push($meta_object->headers, “Content-Type: $value”);

2 如果某篇文章修改了,删除这篇文章的缓存,如果某个blog换主题了,删除整个blog的缓存。以后按照1的逻辑来。

wp-cache-phase1 检查某页面是否存在,如果存在直接去缓存。否则进入wp-cache-phase2,访问动态页面,生成缓存文件
其中用到
ob_start(‘wp_cache_ob_callback’);
register_shutdown_function(‘wp_cache_ob_end’);
wp_cache_ob_callback wp_cache_ob_end

wp-cache-phase2还有个作用是响应页面的事件,例如publish_post edit_post delete_post publish_phone trackback_post pingback_post comment_post edit_comment wp_set_comment_status delete_comment switch_theme,不管什么事件,本质就是将缓存里面的页清空

采用这种插件形式需要修改的地方
1 cache: 需要有一个include文件,根据URL,统一判断所有的访问
2 事件响应:

由于硬盘文件系统,同一目录下的文件数超过3000个,访问就会比较慢
所以缓存文件在硬盘上的结构:需要增加目录,这样可以提升索引速度,而且删除时候也比较方便
可以按照用户,分类,日期或其他属性建立目录

http://www.builder.com.cn/2008/0328/786511.shtml

评论关闭
发表于: sitebuild | 作者: | 日期: 2008/11/17 07:11


function add_qc_object(){
var height = 250;
var width = 800;
var top = (screen.availHeight – height)/2;
var left = (screen.availWidth – width)/2;
var param = ‘toolbar=no,location=no,directories=no,status=yes,menubar=no,scrollbars=yes,resizable=yes,’ +
‘width=’ + width + ‘,height=’ + height + ‘,left= ‘ + left + ‘,top=’ + top;
window.open(‘K230_add_qc_object.jsp’, ‘win_name’, param);
}

评论关闭
发表于: DB/ES | 作者: | 日期: 2008/11/16 03:11

Oracle number datatype 语法:
NUMBER[(precision [, scale])]

简称:
precision –> p
scale –> s

NUMBER(p, s)
范围: 1 <= p <=38, -84 <= s <= 127 保存数据范围:-1.0e-130 <= number value < 1.0e+126 保存在机器内部的范围: 1 ~ 22 bytes 有效位:从左边第一个不为0的数算起的位数,小数点和负号不计入有效位数。 s的情况: s > 0
精确到小数点右边s位,并四舍五入。然后检验有效位是否 <= p。 s < 0 精确到小数点左边s位,并四舍五入。然后检验有效位是否 <= p + |s|。 s = 0 此时NUMBER表示整数。 eg: Actual Data Specified As Stored As ---------------------------------------- 123.89 NUMBER 123.89 123.89 NUMBER(3) 124 123.89 NUMBER(6,2) 123.89 123.89 NUMBER(6,1) 123.9 123.89 NUMBER(4,2) exceeds precision (有效位为5, 5 > 4)
123.89 NUMBER(6,-2) 100
.01234 NUMBER(4,5) .01234 (有效位为4)
.00012 NUMBER(4,5) .00012
.000127 NUMBER(4,5) .00013
.0000012 NUMBER(2,7) .0000012
.00000123 NUMBER(2,7) .0000012
1.2e-4 NUMBER(2,5) 0.00012
1.2e-5 NUMBER(2,5) 0.00001
123.2564 NUMBER 123.2564
1234.9876 NUMBER(6,2) 1234.99
12345.12345 NUMBER(6,2) Error (有效位为5+2 > 6)
1234.9876 NUMBER(6) 1235 (s没有表示s=0)
12345.345 NUMBER(5,-2) 12300
1234567 NUMBER(5,-2) 1234600
12345678 NUMBER(5,-2) Error (有效位为8 > 7)
123456789 NUMBER(5,-4) 123460000
1234567890 NUMBER(5,-4) Error (有效位为10 > 9)
12345.58 NUMBER(*, 1) 12345.6
0.1 NUMBER(4,5) Error (0.10000, 有效位为5 > 4)
0.01234567 NUMBER(4,5) 0.01235
0.09999 NUMBER(4,5) 0.09999

http://dev.csdn.net/develop/article/70/70922.shtm

http://www.cublog.cn/u/19782/showart_207809.html

http://hi.baidu.com/tdskee/blog/item/5d59870a8f40f01b95ca6be4.html

评论关闭
发表于: lnmp | 作者: | 日期: 2008/11/15 01:11
标签:

在UNIX/LINUX中,普通进程用&符号就可以放到后台运行,如果启动该程序的控制台logout,则该进程随即终止。

在UNIX/LINUX中还有一种进程被称为守护进程,守护进程是脱离于终端并且在后台运行的进程。守护进程脱离于终端是为了避免进程在执行过程中的信息在任何终端上显示,并且进程也不会被任何终端所产生的终端信息所打断。 More …

评论关闭
发表于: java/j2ee | 作者: | 日期: 2008/11/14 06:11
标签:

方法一:导出到csv文件,存放在服务器端任一路径,然后给客户下载

优点:
1、可以进行身份认证后给客户下载,如果放到非web目录就没有对应的url,客户无法随时下载。
2、也是因为生成了文件,所以占用了服务器的空间,但是可以把文件名存放到数据库,再次给客户下载的时候不需要重复生成文件。
3、csv文件是文本文件,逗号隔开字段,回车隔开行,易于数据导入导出。

实现方法:
SqlConnection conn=new SqlConnection(System.Configuration.ConfigurationSettings.AppSettings[“conn”]);
SqlDataAdapter da=new SqlDataAdapter(“select * from tb1″,conn);
DataSet ds=new DataSet();
da.Fill(ds,”table1”);
DataTable dt=ds.Tables[“table1”];
string name=System.Configuration.ConfigurationSettings.AppSettings[“downloadurl”].ToString()+DateTime.Today.ToString(“yyyyMMdd”)+new Random(DateTime.Now.Millisecond).Next(10000).ToString()+”.csv”;//存放到web.config中downloadurl指定的路径,文件格式为当前日期+4位随机数
FileStream fs=new FileStream(name,FileMode.Create,FileAccess.Write);
StreamWriter sw=new StreamWriter(fs,System.Text.Encoding.GetEncoding(“gb2312”));
sw.WriteLine(“自动编号,姓名,年龄”);
foreach(DataRow dr in dt.Rows)
{
sw.WriteLine(dr[“ID”]+”,”+dr[“vName”]+”,”+dr[“iAge”]);
}
sw.Close();
Response.AddHeader(“Content-Disposition”, “attachment; filename=” + Server.UrlEncode(name));
Response.ContentType = “application/ms-excel”;// 指定返回的是一个不能被客户端读取的流,必须被下载
Response.WriteFile(name); // 把文件流发送到客户端
Response.End();
方法二:导出到csv文件,不存放到服务器,直接给浏览器输出文件流
优点:
1、随时生成,不需要占用资源
2、可以结合身份认证
3、同样利于数据交换

实现方法:
SqlConnection conn=new SqlConnection(System.Configuration.ConfigurationSettings.AppSettings[“conn”]);
SqlDataAdapter da=new SqlDataAdapter(“select * from tb1″,conn);
DataSet ds=new DataSet();
da.Fill(ds,”table1”);
DataTable dt=ds.Tables[“table1”];
StringWriter sw=new StringWriter();
sw.WriteLine(“自动编号,姓名,年龄”);
foreach(DataRow dr in dt.Rows)
{
sw.WriteLine(dr[“ID”]+”,”+dr[“vName”]+”,”+dr[“iAge”]);
}
sw.Close();
Response.AddHeader(“Content-Disposition”, “attachment; filename=test.csv”);
Response.ContentType = “application/ms-excel”;
Response.ContentEncoding=System.Text.Encoding.GetEncoding(“GB2312”);
Response.Write(sw);
Response.End();
对方法一,二补充一点,如果你希望导出的是xls文件分隔符用\t就可以了,不要用逗号
代码修改如下:
sw.WriteLine(“自动编号\t姓名\t年龄”);
foreach(DataRow dr in dt.Rows)
{
sw.WriteLine(dr[“ID”]+”\t”+dr[“vName”]+”\t”+dr[“iAge”]);
}
另外,修改输出的文件扩展名为xls即可。

方法三:从datagrid导出html代码,生成excel文件,给客户端下载

优点:
1、有固定的格式,样子好看(datagrid的样子)

局限性:
1、不适合数据交换,里面有html代码,比较乱,没有固定格式
2、datagrid不能有分页、排序等,否则出错

实现方法:
Response.Clear();
Response.Buffer= false;
Response.Charset=”GB2312″;
Response.AppendHeader(“Content-Disposition”,”attachment;filename=test.xls”);
Response.ContentEncoding=System.Text.Encoding.GetEncoding(“GB2312”); Response.ContentType = “application/ms-excel”; this.EnableViewState = false;
System.IO.StringWriter oStringWriter = new System.IO.StringWriter();
System.Web.UI.HtmlTextWriter oHtmlTextWriter = new System.Web.UI.HtmlTextWriter(oStringWriter);
this.DataGrid1.RenderControl(oHtmlTextWriter);
Response.Write(oStringWriter.ToString());
Response.End();
在这里说明一点:有的网友反映代码出现“没有dr[“id”]”之类的错误,这个代码是按照我的数据结构来写的,到时候相关的字段要换成你自己的才是。
还有就是如果文件名需要中文的话,这么修改Response.AddHeader(“Content-Disposition”, “attachment; filename=”+System.Web.HttpUtility.UrlEncode(“中文”,System.Text.Encoding.UTF8)+”.xls”);
Go to source web page: (原创)datagrid数据导出到excel文件给客户端下载的几种方法 – LoveCherry – 博客园

评论关闭
发表于: java/j2ee | 作者: | 日期: 2008/11/14 06:11
标签:

容器类可以大大提高编程效率和编程能力,在Java2中,所有的容器都由SUN公司的JoshuaBloch进行了重新设计,丰富了容器类库的功能。

Java2容器类类库的用途是“保存对象”,它分为两类:

Collection—-一组独立的元素,通常这些元素都服从某种规则。List必须保持元素特定的顺序,而Set不能有重复元素。

Map—-一组成对的“键值对”对象,即其元素是成对的对象,最典型的应用就是数据字典,并且还有其它广泛的应用。另外,Map可以返回其所有键组成的Set和其所有值组成的Collection,或其键值对组成的Set,并且还可以像数组一样扩展多维Map,只要让Map中键值对的每个“值”是一个Map即可。

1.迭代器

迭代器是一种设计模式,它是一个对象,它可以遍历并选择序列中的对象,而开发人员不需要了解该序列的底层结构。迭代器通常被称为“轻量级”对象,因为创建它的代价小。

Java中的Iterator功能比较简单,并且只能单向移动:

(1)使用方法iterator()要求容器返回一个Iterator。第一次调用Iterator的next()方法时,它返回序列的第一个元素。

(2)使用next()获得序列中的下一个元素。

(3)使用hasNext()检查序列中是否还有元素。

(4)使用remove()将迭代器新返回的元素删除。

Iterator是Java迭代器最简单的实现,为List设计的ListIterator具有更多的功能,它可以从两个方向遍历List,也可以从List中插入和删除元素。

2.List的功能方法

List(interface):次序是List最重要的特点;它确保维护元素特定的顺序。List为Collection添加了许多方法,使得能够向List中间插入与移除元素(只推荐LinkedList使用)。一个List可以生成ListIterator,使用它可以从两个方向遍历List,也可以从List中间插入和删除元素。

ArrayList:由数组实现的List。它允许对元素进行快速随机访问,但是向List中间插入与移除元素的速度很慢。ListIterator只应该用来由后向前遍历ArrayList,而不是用来插入和删除元素,因为这比LinkedList开销要大很多。

LinkedList:对顺序访问进行了优化,向List中间插入与删除得开销不大,随机访问则相对较慢(可用ArrayList代替)。它具有方法addFirst()、addLast()、getFirst()、getLast()、removeFirst()、removeLast(),这些方法(没有在任何接口或基类中定义过)使得LinkedList可以当作堆栈、队列和双向队列使用。

3.Set的功能方法

Set(interface):存入Set的每个元素必须是唯一的,因为Set不保存重复元素。加入Set的Object必须定义equals()方法以确保对象的唯一性。Set与Collection有完全一样的接口。Set接口不保证维护元素的次序。

HashSet:为快速查找而设计的Set。存入HashSet的对象必须定义hashCode()。

TreeSet:保持次序的Set,底层为树结构。使用它可以从Set中提取有序的序列。

LinkedHashSet:具有HashSet的查询速度,且内部使用链表维护元素的顺序(插入的次序)。于是在使用迭代器遍历Set时,结果会按元素插入的次序显示。

HashSet采用散列函数对元素进行排序,这是专门为快速查询而设计的;TreeSet采用红黑树的数据结构进行排序元素;LinkedHashSet内部使用散列以加快查询速度,同时使用链表维护元素的次序,使得看起来元素是以插入的顺序保存的。需要注意的是,生成自己的类时,Set需要维护元素的存储顺序,因此要实现Comparable接口并定义compareTo()方法。

Go to source: 两种Java容器类List和Set分析 – 我行我诉 – CSDNBlog

评论关闭
发表于: java/j2ee | 作者: | 日期: 2008/11/14 06:11

本文假设您的Eclipse已经配置完毕,Tomcat可以正常启动。
1.在Eclipse中启动Tomcat。
2.在待调试的代码段处设置断点。
3.在浏览器中运行你的Web程序,当程序执行到设置断点处时,会自动处于等待状态。

[1]快捷键(F8)直接执行程序。
[2]快捷键(F5)单步执行程序,遇到方法时进入。
[3]快捷键(F6)单步执行程序,遇到方法时跳过。
[4]快捷键(F7)单步执行程序,从当前方法跳出。

  若要改变变量的值,可以右击变量,在弹出的菜单中选择[change variable value],弹出修改画面。改变其值后,按下ok键即可。这时,变量的值就改为修改后的值了。
若要检查代码段是否正确,可以选择一句或一段代码,右键单击在弹出的菜单中选择Inspect项,这时,代码的执行结果就显示在Expressions窗口中。

  怎么样,跟调试Swing程序一样简单吧。

  在调试时出现source not find的提示信息,只要将window->preferences->tomcat->source path中相关的工程选中即可。
Go to source web page: 单步调试Jsp程序 – 梦想Java

评论关闭