[b:9e5a30927b]操作servlet[/b:9e5a30927b]
部署信息把以.do结尾的url映射到操作的servlet. jsp页面在引用的方法为:
action="<%=response.encodeurl("actions.loginaction.do")%>">
[b:9e5a30927b]用servlet把url映射到操作类[/b:9e5a30927b]
示例:actionservlet类 /web-inf/classes/ actionservlet
import javax.servlet.servletexception;
import javax.servlet.http.httpservlet;
import javax.servlet.http.httpservletrequest;
import javax.servlet.http.httpservletresponse;
import actions.action;
import actions.actionrouter;
import actions.actionfactory;
public class actionservlet extends httpservlet
{
private actionfactory factory=new actionfactory();
public void init(servletconfig config) throws servletexception
{
/*根据actionrouter类导读内容中对httpservlet类的描述来看,httpservlet规定了必须执行的方法,该时期调用了init()方法,当servlet被servlet引擎载入后,接下来就会执行init()这个方法,因此我们可以重载这个方法以做一些我们自己的初始化的工作。在servlet的生命期中,init()方法仅在服务器装入servlet时被执行一次,此后无论有多少客户机访问这个servlet,init()都不会被重复执行。*/
}
public void service(httpservletrequest req, httpservletresponse res)
throws java.io.ioexception, servletexception
{
/*在servlet被载入后,主要通过service()方法对外响应,该方法可以被同时、多次地呼叫。*/
try
{
action action=factory.getaction(getclassname(req),getclass().getclassloader());
actionrouter router=action.perform(this,req,res);
router.route(this,req,res);
}
catch(exception e)
{
throw new servletexception(e);
}
}
public string getclassname(httpservletrequest req)
{
string path=req.getservletpath();
int beginpos=path.lastindexof("/");
int endpos=path.lastindexof(".");
if (beginpos>-1 && endpos>beginpos)
{
path=path.substring(beginpos+1,endpos);
}
return path;
}
}
该类的service方法实现了:从操作库中获取操作,然后调用接口的perform方法。由perform的实现返回一个操作路径,最后由actionrouter类的route方法进行重定向操作。达到页面跳转的作用。
导读:getclassname(req)将获取操作类名,过程如下:
由req.getservletpath()获取servlet的路径为/ actions.loginaction.do通过截取得到类名:actions.loginaction。
getclass().getclassloader():getclass()方法是类的一个方法,主要用于返回一个类型为class的对象。该例中返回为:class actionservlet
getclassloader()是class类的一个方法,返回为classloader对象。本例返回为:sun.misc.launcher$appclassloader@92e78c。这说明加载actionservlet类的类的加载者(classloader的翻译)为appclassloader.那么appclassloader又是什么呢?下面我们来解答该问题:
首先要明确java虚拟机上所有的类,必须要加载才能运行。jvm在运行时会产生三个classloader, 它们分别是bootstrap classloader、extension classloader和appclassloader:
classloader 作 用
bootstrap classloader 加载核心类库static const char classpathformat[] ="%/lib/rt.jar:""%/lib/i18n.jar:""%/lib/sunrsasign.jar:""%/lib/jsse.jar:""%/lib/jce.jar:""%/lib/charsets.jar:""%/classes";这里我们可看到为什么在classpath里为什么不加载这些类
extension classloader 加载扩展类,即/lib/ext中的类。
appclassloader 加载classpath中指定的类。
从上面可以看出,所有web应用程序的类都是appclassloader来加载的,三者的关系为:appclassloader的parent是extclassloader,而extclassloader的parent为bootstrap classloader。加载一个类时,首先bootstrap先进行寻找,找不到再由extclassloader寻找,最后才是appclassloader。classloader这种加载类的模型被称为是委托模型。
下面我们要了解的问题是动态加载类原基本原理?或者说为什么我们要这么做?
闽公网安备 35060202000074号