Myteam--根
Struts中DispatchAction类的使用
马耿 发表于 2007-12-26 14:01:18
DispatchAction类是一个抽象类,它实现了父类(Action)的execute()方法,所以它的子类就不用来实现这个方法了,只需要专注与实际操作的方法,
1.首先要一个DispatchAction的子类,它含有一些方法,login,logout,method1,
package examples;
package examples;
import javax.servlet.http.*;
import org.apache.struts.action.*;
import org.apache.struts.actions.*;
public class AccountAction extends DispatchAction {
public ActionForward login(ActionMapping mapping,
ActionForm form,
HttpServletRequest request,
HttpServletResponse response)
throws Exception {
// 進行一些Login的邏輯
return mapping.findForward("success");
}
public ActionForward logout(ActionMapping mapping,
ActionForm form,
HttpServletRequest request,
HttpServletResponse response)
throws Exception {
// 進行一些Logout的邏輯
return mapping.findForward("success1");
}
public ActionForward method1(ActionMapping mapping,
ActionForm form,
HttpServletRequest request,
HttpServletResponse response)
throws Exception {
// 進行一些method1的邏輯
return mapping.findForward("success");
}
}
一定要注意在DispatchAction中你想执行的操作,都必须要有统一的参数(ActionMapping mapping, ActionForm form,HttpServletRequest request, HttpServletResponse response),是一个规定.
2.接下来是配置struts-config.xml
<action path="/login" type="examples.AccountAction"
name="logonForm"
scope="request"
parameter="action"
input="/pages/dispatch1.jsp">
<forward name="success" path="/pages/success.jsp" />
</action>
<action path="/logout" type="examples.AccountAction"
name="logonForm"
scope="request"
parameter="action"
input="/pages/dispatch1.jsp">
<forward name="success1" path="/pages/success1.jsp" />
</action>
这里需要注意的就是parameter属性的值,因为这个值要和页面传来的参数对应.
3.再来看看JSP页 pages/dispatch1.jsp
<%@ taglib uri="/tags/struts-html" prefix="html" %>
<html:link href="/DispathActionTest/login.do?action=login">login</html:link><br>
<html:link href="/DispathActionTest/logout.do?action=logout">logout</html:link>
这里要注意几点,首先 ?后面的KEY要和struts-config.xml中的parameter相同,还有它的VALUE要是你在action的一个方法名字,这里方法名为login, 那么在程序运行时就是调用login的操作,如果是logout,那程序就调用logout的操作.
设计模式学习笔记(三)——Abstract Factory抽象工厂模式
马耿 发表于 2007-12-24 10:14:45
抽象工厂是一种创建型模式,是为了解决实例化时所带来的问题。
我们先来看看是什么问题,有的时候我们会遇到这种情况,我们需要一系列的对象。举个例子,有一系列BMW汽车零部件的对象:轮子bmwwheel,油箱bmwoilbox,在一个管理函数中调用它们,代码如下
class BMWWheel
{
public BMWWheel(){};
}
class BMWOilbox
{
public BMWOilbox(){};
}
public void Manage()
{
BMWOilbox oilbox = new BMWOilbox();
BMWWheel wheel = new BMWWheel();
}
如果现在需求变了,我们要用大众一汽BORA的零件,不用BMW的,那么我们除了要再加上相应的零件对象外还要将Manage函数中的对象更改为BORA的零件对象。
那这时发现new会带来了一些问题:实现依赖,不能应对具体实例化类型的变化。
如何解决这类问题呢?封装变化点。(没有变化的就不需要封装)
工厂模式的缘起:
1、变化点在“对象创建”,因此就封装“对象创建”
2、面向接口编程
简单工厂问题:
1、不能应对“不同系列对象”的变化。如:我们要在上面的代码中加上其他的对象就不能很好的应对了
2、使用面向对象国内的技术来封装变化点
动机:在软件系统中,经常面临着“一系列相互依赖的对象”的创建工作;同时,由于需求的变化,往往存在更多系列对象的创建工作。面对这种问题,我们想绕过常规的对象创建方法,提供一种“封装机制”来避免客户程序和这种“多系列具体对象创建工作”的紧耦合。
对于“紧耦合”,我原来是不喜欢这个词的,但是今天明白了,不是程序紧耦合不好,而是面对频繁变化的需求,紧耦合会使程序的编写变得很吃力。如果面对一个不变的需求,松耦合和紧耦合在代码编写上应该是没什么区别的。
《设计模式》中解释这种模式的意图是:提供一个接口,让该接口负责创建一系列“相关或者相互依赖的对象”,无需指定他们的具体类。
下面我们来看看如何使用抽象工厂模式完成对这种变化的封装:
首先我们的需求是BMW的车轮和油箱,当然他们要继承各自的基类,代码如下
abstract class AbstractWheel
{
public AbstractWheel()
{
//Console.Write("Create a AbstractProduct");
}
}
abstract class AbstractOilBox
{
public AbstractOilBox()
{}
}
class BMWWheel:AbstractWheel
{
public BMWWheel()
{
Console.Write("Create a BMWwheel");
}
}
class BMWOilBox:AbstractOilBox
{
public BMWOilBox()
{
Console.Write("Create a BMWOilBox");
}
}
然后,我们在建立一个生产这些零件的工厂,它继承自一个抽象工厂
//抽象工厂
abstract class AbstractFactory
{
abstract public AbstractWheel CreatWheel();
abstract public AbstractOilBox CreatOilBox();
}
class BMWFactory:AbstractFactory
{
public override AbstractWheel CreatWheel()
{
return new BMWWheel();
}
public override AbstractOilBox CreatOilBox()
{
return new BMWOilBox();
}
}
现在我们在Main函数中调用它们:
static void Main(string[] args)
{
AbstractFactory factory = null;
factory = new BMWFactory();
factory.CreatWheel();
Console.Write("\n");
factory.CreatOilBox();
Console.Write("\n");
Console.Read();
}
显示结果:
Create a BMWwheel
Create a BMWOilBox
现在我们想不用BMW的零件,用BORA的零件了,先写一些BORA零件的类:
class BORAWheel:AbstractWheel
{
public BORAWheel()
{
Console.Write("Create a BORAWheel");
}
}
class BORAOilBox:AbstractOilBox
{
public BORAOilBox()
{
Console.Write("Create a BORAOilBox");
}
}
然后我们再创建BORA零件的工厂:
class BORAFactory:AbstractFactory
{
public override AbstractWheel CreatWheel()
{
return new BORAWheel();
}
public override AbstractOilBox CreatOilBox()
{
return new BORAOilBox();
}
}
再来看看如何在Main函数中修改使其调用BORA的零件;我们只要在将Main中的factory对象实例化为BORA的工厂BORAFactory就可以了:
static void Main(string[] args)
{
AbstractFactory factory = null;
factory = new BORAFactory();
factory.CreatWheel();
Console.Write("\n");
factory.CreatOilBox();
Console.Write("\n");
Console.Read();
}
结果如下:
Create a BORAWheel
Create a BORAOilBox
Abstract Factory模式的几个要点:
1、如果没有应对“多系列对象构建”的需求变化,则没有必要使用Abstract Factory模式。
2、“系列对象”指的是这项对象之间有相互依赖、或作用的关系。
3、Abstract Factory模式主要在于应对“新系列”的需求变动。缺点是难以应对“新对象”的需求变动。这一点应该注意,就像前面说的,如果我们现在要在加入其他系列的类,代码的改动会很大。
4、Abstract Factory模式经常和Factory Method模式共同组合来应对“对象创建”的需求变化。
PHP查询数据函数
马耿 发表于 2007-11-02 16:14:06
mysql_result()
mysql_fetch_row()
mysql_fetch_array()
mysql_fetch_assoc()
mysql_fetch_object()
<?php
//by Mr.Bool 2007.10.24
/*
PHP查询数据函数:
mysql_result()
mysql_fetch_row()
mysql_fetch_array()
mysql_fetch_assoc()
mysql_fetch_object()
*/
$conn=mysql_connect("localhost","root","");//连接数据库
mysql_select_db("test",$conn);//选择数据库test
//查询数据
$query="SELECT id,name,gender,phone,email FROM student";
mysql_query("set names 'gbk' ");
$result=mysql_query($query);
/*
// mysql_fetch_row() 函数用法一
while($rows=mysql_fetch_row($result))
{
echo "学号:".$rows[0]."<br>";
echo "姓名:".$rows[1]."<br>";
echo "性别:".$rows[2]."<br>";
echo "电话:".$rows[3]."<br>";
echo "E-mail:".$rows[4]."<br>";
echo "<br>";
}
*/
/*
//---------------------------------------------------------------------------
// mysql_fetch_row() 函数用法二
while(list($id,$name,$gender,$phone,$email)=mysql_fetch_row($result))
{
echo "学号:".$id."<br>";
echo "姓名:".$name."<br>";
echo "性别:".$gender."<br>";
echo "电话:".$phone."<br>";
echo "E-mail:".$email."<br>";
echo "<br>";
}
*/
//------------------------------------------------------------------------------
/*
// mysql_fetch_array() 函数用法
while($rows=mysql_fetch_array($result))
{
echo "学号:".$rows['id']."<br>";
echo "姓名:".$rows['name']."<br>";
echo "性别:".$rows['gender']."<br>";
echo "电话:".$rows['phone']."<br>";
echo "<br>";
}
*/
//------------------------------------------------------------------------------
/*
// mysql_fetch_assoc() 函数用法
while($rows=mysql_fetch_assoc($result))
{
echo "学号:".$rows['id']."<br>";
echo "姓名:".$rows['name']."<br>";
echo "性别:".$rows['gender']."<br>";
echo "电话:".$rows['phone']."<br>";
echo "<br>";
}
*/
//-----------------------------------------------------------------
// mysql_fetch_object() 函数用法
//以对象的形式返回查询结果
while($rows=mysql_fetch_object($result))
{
echo "学号:".$rows->id."<br>";
echo "姓名:".$rows->name."<br>";
echo "性别:".$rows->gender."<br>";
echo "电话:".$rows->phone."<br>";
echo "E-mail:".$rows->email."<br>";
echo "<br>";
}
?>
一段实现 自动分页的javascript
马耿 发表于 2007-11-02 10:25:01
为了以后方便查找 暂时博客放一下~~
<table width="980" border="0" align="center" cellpadding="0" cellspacing="0">
<tr>
<td><table width="100%" border="0" cellspacing="0" cellpadding="0">
<tr>
<td width="675" height="650" valign="top"><table width="95%" height="640" border="0" align="center" cellpadding="0" cellspacing="0">
<tr>
<td height="10"></td>
</tr>
<tr>
<td valign="top"><table width="100%" height="370" border="0" cellpadding="0" cellspacing="0">
<tr>
<td width="643" height="1" bgcolor="#CCCCCC"></td>
</tr>
<tr>
<td height="369" valign="top"><table cellspacing="0" cellpadding="0">
<tr>
<td><div align="center"><strong><br>标题</strong></div></td>
</tr>
<tr>
<td valign="top" align="left" height="246"><p><br />
<div id="divPagenation"></div>
<div id="divContent"></div>
<div id="Content" style="display: none;">
<?php
// 这段就是实现从数据库读取文件存放的路径;文章的格式还没做,所以还是按照txt的格式。排版很差。
$story_name=$row_rsNews['Path'];
@ $fp=fopen("$DOCUMENT_ROOT/$story_name",'r');
if (!$fp)
{
echo '<p><strong>该小说不存在</strong></p>';
exit;
}
$story= file("$DOCUMENT_ROOT/$story_name");
$number_of_story = count($story);
if ($number_of_story == 0)
{
echo '<p><strong>该小说不存在</strong></p>';
}
for ($i=0; $i<$number_of_story; $i++)
{
echo $story[$i].'<br />';
}
fclose($fp);
?>
</div>
</td>
</tr>
</table> </td>
</tr>
</table></td>
</tr>
<tr>
<td width="8"></td>
</tr>
<tr>
<td height="1" bgcolor="#CCCCCC"></td>
</tr>
<tr>
<td height="8"></td>
</tr>
<tr>
<td> </td>
</tr>
</table></td>
<td width="1"><table height="590" border="0" cellpadding="0" cellspacing="0" bgcolor="#CCCCCC">
<tr>
<td width="1"></td>
</tr>
</table></td>
</tr>
</table></td>
</tr>
<tr>
<td> </td>
</tr>
</table>
<SCRIPT LANGUAGE="JavaScript">
<!--
function DHTMLpagenation(content) {
// client static html file pagenation
this.content=content;
this.contentLength=content.length;
this.pageSizeCount;
this.perpageLength=100; //default perpage byte length.
this.currentPage=1;
//this.regularExp=/.+[\?\&]{1}page=(\d+)/;
this.regularExp=/\d+/;
this.divDisplayContent;
this.divDisplayPagenation;
this.contentStyle=null;
this.strDisplayContent="";
this.strDisplayPagenation="";
arguments.length==2?perpageLength=arguments[1]:'';
try {
divExecuteTime=document.createElement("DIV");
document.body.appendChild(divExecuteTime);
}
catch(e)
{
}
if(document.getElementById("divPagenation"))
{
divDisplayPagenation=document.getElementById("divPagenation");
}
else
{
try
{
divDisplayPagenation=document.createElement("DIV");
divDisplayPagenation.id="divPagenation";
document.body.appendChild(divDisplayPagenation);
}
catch(e)
{
return false;
}
}
if(document.getElementById("divContent"))
{
divDisplayContent=document.getElementById("divContent");
}
else
{
try
{
divDisplayContent=document.createElement("DIV");
divDisplayContent.id="divContent";
document.body.appendChild(divDisplayContent);
}
catch(e)
{
return false;
}
}
DHTMLpagenation.initialize();
return this;
};
DHTMLpagenation.initialize=function()
{
divDisplayContent.className=contentStyle!=null?contentStyle:"divContent";
if(contentLength<=perpageLength)
{
strDisplayContent=content;
divDisplayContent.innerHTML=strDisplayContent;
return null;
}
DHTMLpagenation.displayContent();
pageSizeCount=Math.ceil((contentLength/perpageLength));
DHTMLpagenation.goto(currentPage);
};
DHTMLpagenation.displayContent=function()
{
divDisplayContent.innerHTML=strDisplayContent;
};
DHTMLpagenation.displayPage=function()
{
strDisplayPagenation="分页:";
if(currentPage&¤tPage!=1)
strDisplayPagenation+='<a href="javascript:void(0)" onclick="DHTMLpagenation.previous()">上一页</a> ';
else
strDisplayPagenation+="上一页 ";
for(var i=1;i<=pageSizeCount;i++)
{
if(i!=currentPage)
strDisplayPagenation+='<a href="javascript:void(0)" onclick="DHTMLpagenation.goto('+i+');">'+i+'</a> ';
else
strDisplayPagenation+=i+" ";
}
if(currentPage&¤tPage!=pageSizeCount)
strDisplayPagenation+='<a href="javascript:void(0)" onclick="DHTMLpagenation.next()">下一页</a> ';
else
strDisplayPagenation+="下一页 ";
//strDisplayPagenation+="共 " + pageSizeCount + " 页,每页" + perpageLength + " 字符,调整字符数:<input type='text' value='"+perpageLength+"' id='ctlPerpageLength'><input type='button' value='确定' onclick='DHTMLpagenation.change(document.getElementById(\"ctlPerpageLength\").value);'>";
divDisplayPagenation.innerHTML=strDisplayPagenation;
};
DHTMLpagenation.previous=function()
{
DHTMLpagenation.goto(currentPage-1);
};
DHTMLpagenation.next=function()
{
DHTMLpagenation.goto(currentPage+1);
};
DHTMLpagenation.goto=function(iCurrentPage)
{
startime=new Date();
if(regularExp.test(iCurrentPage))
{
currentPage=iCurrentPage;
strDisplayContent=content.substr((currentPage-1)*perpageLength,perpageLength);
}
else
{
alert("page parameter error!");
}
DHTMLpagenation.displayContent();
DHTMLpagenation.displayPage();
};
DHTMLpagenation.change=function(iPerpageLength)
{
if(regularExp.test(iPerpageLength))
{
DHTMLpagenation.perpageLength=iPerpageLength;
DHTMLpagenation.currentPage=1;
DHTMLpagenation.initialize();
}
else
{
alert("请输入数字");
}
};
// method
// DHTMLpagenation(strContent,perpageLength)
DHTMLpagenation(document.getElementById('Content').innerHTML,5000);
//-->
</SCRIPT>
第一份辞职申请书
马耿 发表于 2007-10-31 13:40:09
辞职申请
亲爱的新致软件有限公司领导:
各位领导,我带着复杂的心情写这封次致信。由于您对我的能力的信任,使我得以加入公司,从今年1月至今,在短短的1年间获得了许多的机遇和挑战。经过这段时间在公司从事的JAVA软件开发工作,使我在JAVA软件开发,银行金融等领域学到了很多知识、积累了一定的经验。对此我深怀感激!
由于薪金以及其他一些的原因,我不得不向公司提出申请,并希望能与今年11月20日正式离职。
对于由此为公司造成的不便,我深感抱歉。但同时也希望公司能体谅我的个人实际,对我的申请予以考虑并批准为盼。
此致
敬礼
申请人:马耿
2007月
貌似有点短,我也不知道还能说啥了,感慨感慨~~
PHP页面跳转的3种方法
马耿 发表于 2007-10-31 13:35:14
一、用HTTP头信息
也就是用PHP的HEADER函数。PHP里的HEADER函数的作用就是向浏览器发出由HTTP协议规定的本来应该通过WEB服务器的控制指令,例如声明返回信息的类型("Context-type: xxx/xxx"),页面的属性("No cache", "Expire")等等。
用HTTP头信息重定向到另外一个页面的方法如下:
<?
if (isset($url))
{
Header("HTTP/1.1 303 See Other");
Header("Location: $url");
exit;
}
?>
注意一下,"Localtion:"后面有一个空格。
二、用HTML标记
用HTML标记,就是用META的REFRESH标记,举例如下:
<? if (!isset($url)) exit;?>
<HTML>
<HEAD>
<META HTTP-EQUIV="REFRESH" CONTENT="5; URL=<? echo $url;?>>
</HEAD>
<BODY>
</BODY>
</HTML>
三、用脚本来实现
举例如下:
<?
$url="http://www.PHPuser.com";
echo "<!--<SCRIPT LANGUAGE="JavaScript">";
echo "location.href='$url'";
echo "</SCRIPT>-->";
?>
睡了好几天 终于醒了
马耿 发表于 2007-10-17 22:28:19
起来第一件事就是看了西贝的对第八周的总结,感触很深也很感动,我吴亮同学一样,我也看了3遍,刚刚又看了一遍。不知道该怎么说,感觉有点对不起大家,是一个不负责任的人,其实我也不是一个不负责任的人,很多事情可能你们并不理解,我也不理解,当管理着一个几百人的游戏公会的运作,当在一个10000人的服务器中带领着40个人的固定小团队冲击服务器第一进度的时候,当协调着各种各样怪人的矛盾的时候,有时感觉很满足自豪,但是渐渐的当把游戏当作一种责任并坚持了2年之后,好累好累,曾经我考虑过离开这个游戏,其实只要离开这个公会 或者 这个服务器 离开这群熟悉的脸我就可以很休闲,这样我每天晚上可以有好多好多时间,但是一旦我离开 之前创造的辉煌将会随之而去,整个公会最优秀的团队可能一下子变成散沙,将是39个人等1个人的场面,那39个人什么都做不了。在那里我是一个很有地位的人,但是现实里我什么都不是。床上躺了4天想了很多,其实很可笑这场病也许就是游戏累出来的,其实游戏对我的压力早已胜过了现实(半年前压力更大),虽然是的的确确被游戏毒害了,但是留给我很多东西,也算一点补偿吧,4天想的东西太多太多了,考虑了很多问题,于是我找人交代了下,准备暂时不玩了,再玩确实不理智了,毕竟早已不是大学生了,4天第一次打开电脑 看了西贝的总结,不知道怎么答复,只是感觉有点对不起大家对我的这份“盲目”的信任,为了不想失去这次那么好的机会,也为了不让大家的努力变成一场肥皂剧,我会弥补大家的, 吴轶珩前面来找过我,担心西贝说的太严重(我觉得西贝说的挺到位,而且还是很客气的在说),怕打击我们没信心,信心我一直是有的,没得只是时间,现在时间也有了,就看我自己了。
SQL常用语句一览
马耿 发表于 2007-09-29 15:40:45
(1)数据记录筛选:
sql="select*from数据表where字段名=字段值orderby字段名[desc]"
sql="select*from数据表where字段名like'%字段值%'orderby字段名[desc]"
sql="selecttop10*from数据表where字段名orderby字段名[desc]"
sql="select*from数据表where字段名in('值1','值2','值3')"
sql="select*from数据表where字段名between值1and值2"
(2)更新数据记录:
sql="update数据表set字段名=字段值where条件表达式"
sql="update数据表set字段1=值1,字段2=值2……字段n=值nwhere条件表达式"
(3)删除数据记录:
sql="deletefrom数据表where条件表达式"
sql="deletefrom数据表"(将数据表所有记录删除)
(4)添加数据记录:
sql="insertinto数据表(字段1,字段2,字段3…)values(值1,值2,值3…)"
sql="insertinto目标数据表select*from源数据表"(把源数据表的记录添加到目标数据表)
Log4J学习笔记(1)
马耿 发表于 2007-09-26 11:11:46
1、log4j已经被移植到C, C++, C#, Perl, Python, Ruby, Eiffel 几种语言。
2、log4j有三种主要的组件:记录器,存放器,布局
3、记录器(记录器可不关心log数据存放的事哟)
log4j允许程序员定义多个记录器,每个记录器有自己的名字,记录器之间通过名字来表明隶属关系(或家族关系)。列如,记录器a.b,与记录器 a.b.c之间是父子关系,而记录器a与a.b.c之间是祖先与后代的关系,父子关系是祖先与后代关系的特例。通过这种关系,可以描述不同记录器之间的逻辑关系。
有一个记录器叫根记录器,它永远存在,且不能通过名字检索或引用,可以通过Logger.getRootLogger()方法取得它,而一般记录器通过Logger.getLogger(String name)方法。下面是Logger类的基本方法。
