首先到你的
MyEclipse文件下去搜索
server.xml 這個(gè)文件
修改這個(gè)文件里面的一個(gè)參數(shù)
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" />
2.在
Myeclipse中,在(工具欄吧叫做,就是有
File Edit 的那一行),選
window -> Preferences -> Myeclipse -> Servers -> Integrated Sandbox -> Myeclipse Tomcat 6修改相應(yīng)端口號(hào)
alter table test
add ( test_column varchar2(20) )
comment on column test_column
is 'test'
example:
Point p1 = new Point(1,2);
Point p2 = new Point(3,4);
p2 = p1 ; 此時(shí) 是p2指針的內(nèi)容指向了p1,p1和p2的內(nèi)容相等,但是p1的地址可能是1000,p2的地址是2000,p1,p2地址內(nèi)容值都指向同一內(nèi)容(1,2),此時(shí)(1,2)是heap,p2和p1的地址存向stack
Point p3 = null;
p3.moveto(1,2)此時(shí)報(bào)錯(cuò),p3沒對(duì)象;
摘要: 首先我將所有需要的文件引入:
Code highlighting produced by Actipro CodeHighlighter (freeware)http://www.CodeHighlighter.com/-->loging.jsp${error} <body> <form metho...
閱讀全文

public void invokeActionHandler(ModelAndView mv , HttpServletRequest request) throws Exception
{
String className = mv.getClassName();
String methodName = mv.getMethodName();
//load class
Class controllerClass = cache.loadClass(className);//== Class.forName(className);java反射機(jī)制,jvm加載lassName類
Class parentControllerClass = cache.loadClass(baseControllerClass);//class org.bluechant.mvc.controller.Controller
//load method參數(shù)1類,創(chuàng)建一個(gè)方法為setRequest參數(shù)為HttpServletRequest.class的方法與method = clazz.getDeclaredMethod(setRequest, HttpServletRequest.class);與HttpServletRequest的setRequest方法一致的方法.

Method setRequest = cache.loadMethod(parentControllerClass, "setRequest", new Class[]
{ HttpServletRequest.class }); //HttpServletRequest.class,java的反射機(jī)制得到自己的類,能夠擁有自己的方法值,(Method setRequest獲取成員函數(shù))

Method setModelAndView = cache.loadMethod(parentControllerClass, "setModelAndView", new Class[]
{ ModelAndView.class });//org.bluechant.mvc.controller.Controller-setModelAndView@6024418 public void org.bluechant.mvc.controller.Controller.setModelAndView(org.bluechant.mvc.controller.ModelAndView)

Method targetMethod = cache.loadMethod(controllerClass, methodName, new Class[]
{});
//buiid controller instance and invoke target method以上setRequest,setModelAndView,targetMethod都放在cache(hashMap中)
Object instance = controllerClass.newInstance();//加載className類

setRequest.invoke(instance, new Object[]
{ request });//對(duì)帶有指定參數(shù)的指定對(duì)象調(diào)用由此 Method 對(duì)象表示的基礎(chǔ)方法

setModelAndView.invoke(instance, new Object[]
{ mv });//instance立即為原型指針

targetMethod.invoke(instance, new Object[]
{});
//調(diào)用instance類中targetMethod這個(gè)方法,Object[]{}這個(gè)作為參數(shù)..
//invoke根據(jù)實(shí)體獲得方法,添加所要造的參數(shù),就是個(gè)找實(shí)例的方法克隆工廠,由Method獲得實(shí)例模型,由方法鍛造樣子,傳入?yún)?shù)得出想要結(jié)果
}
方法說明實(shí)例:
}
class ClassB{
public ClassB(){
System.out.println("this is ClassB");
}
public Object invokeMehton(Object owner,String methodName,Object[] args) throws Exception{
//根據(jù)methodName獲得owner里面的方法。args是對(duì)應(yīng)方案參數(shù)。
Class wnerClass=owner.getClass();
Class[] argsClass=new Class[args.length];
for(int i=0,j=args.length;i<j;i++){
argsClass[i] = args[i].getClass();
}
Method method = ownerClass.getMethod(methodName, argsClass);
return method.invoke(owner, args);
}
}
輸出為
this is ClassB
300
outabccc
說明c調(diào)用Class方法成功。
import java.lang.reflect.Method;
public class ClassA {
//ClassA里面有add、和StringAdd兩個(gè)不同方法。c是ClassB的Object
ClassB c=new ClassB();
public void add(Integer param1, Integer param2) {
System.out.println(param1 + param2);
}
public void StringAdd(String abc){
System.out.println("out"+abc);
}
public static void main(String[] args){
ClassA a=new ClassA();
try {
a.c.invokeMehton(a, "add",new Object[] {new Integer(100),new Integer(200)});//反射調(diào)用方法add
a.c.invokeMehton(a, "StringAdd",new Object[] {new String("abccc")});//反射調(diào)用方法StringAdd
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
需要聯(lián)系的幾個(gè)文件:DaosupportController,extents Controller,BeanFactory,CoreDispatcherController,appcontext.xml.
有web.xml中
<servlet>
<!-- servlet獲得控制文件Class的名字,類名 -->
<servlet-name>smvcCoreDispatcher</servlet-name>
<servlet-class>org.bluechant.mvc.core.CoreDispatcherController</servlet-class>
.....
</servlet>
有CoreDispatcherController開始-->

public void invokeActionHandler(ModelAndView mv , HttpServletRequest request) throws Exception
{
String className = mv.getClassName();
String methodName = mv.getMethodName();
//load class
Class controllerClass = cache.loadClass(className);//== Class.forName(className);java反射機(jī)制,jvm加載lassName類
Class parentControllerClass = cache.loadClass(baseControllerClass);//class org.bluechant.mvc.controller.Controller
//load method參數(shù)1類,創(chuàng)建一個(gè)方法為setRequest參數(shù)為HttpServletRequest.class的方法與method = clazz.getDeclaredMethod(setRequest, HttpServletRequest.class);與HttpServletRequest的setRequest方法一致的方法.

Method setRequest = cache.loadMethod(parentControllerClass, "setRequest", new Class[]
{ HttpServletRequest.class }); //HttpServletRequest.class,java的反射機(jī)制得到自己的類,能夠擁有自己的方法值,(Method setRequest獲取成員函數(shù))

Method setModelAndView = cache.loadMethod(parentControllerClass, "setModelAndView", new Class[]
{ ModelAndView.class });//org.bluechant.mvc.controller.Controller-setModelAndView@6024418 public void org.bluechant.mvc.controller.Controller.setModelAndView(org.bluechant.mvc.controller.ModelAndView)

Method targetMethod = cache.loadMethod(controllerClass, methodName, new Class[]
{});
//buiid controller instance and invoke target method以上setRequest,setModelAndView,targetMethod都放在cache(hashMap中)
Object instance = controllerClass.newInstance();//加載className類;//此方法引入數(shù)據(jù)庫(kù)連接
//以上剛進(jìn)入頁面的時(shí)候instance調(diào)用三個(gè)類初始化,分別是繼承關(guān)系DaosupportController ,controller,和BeanFactory

/**//*--->>>其中DaoSupportController類中protected ObjectDao dao = (ObjectDao)BeanFactory.getBean("objectDao");
--->>>調(diào)用:getBean 方法public class BeanFactory {
public static ApplicationContext context = new ClassPathXmlApplicationContext("appcontext.xml") ;//此方法引入數(shù)據(jù)庫(kù)連接 
public static Object getBean(String beanId) {
return context.getBean(beanId);
}
}*/

setRequest.invoke(instance, new Object[]
{ request });//對(duì)帶有指定參數(shù)的指定對(duì)象調(diào)用由此 Method 對(duì)象表示的基礎(chǔ)方法

setModelAndView.invoke(instance, new Object[]
{ mv });//instance立即為原型指針
// --->>>執(zhí)行指定的targetMethod方法實(shí)則為AccountController的login()登陸方法此時(shí)開始調(diào)用數(shù)據(jù)庫(kù)

targetMethod.invoke(instance, new Object[]
{});
//調(diào)用instance類中targetMethod這個(gè)方法,Object[]{}這個(gè)作為參數(shù)..
//invoke根據(jù)實(shí)體獲得方法,添加所要造的參數(shù),就是個(gè)找實(shí)例的方法克隆工廠,由Method獲得實(shí)例模型,由方法鍛造樣子,傳入?yún)?shù)得出想要結(jié)果
}
}
Class.forName(xxx.xx.xx) 返回的是一個(gè)類
首先你要明白在java里面任何class都要裝載在虛擬機(jī)上才能運(yùn)行。這句話就是裝載類用的(和new 不一樣,要分清楚)。
至于什么時(shí)候用,你可以考慮一下這個(gè)問題,給你一個(gè)字符串變量,它代表一個(gè)類的包名和類名,你怎么實(shí)例化它?只有你提到的這個(gè)方法了,不過要再加一點(diǎn)。
A a = (A)Class.forName("pacage.A").newInstance();
這和你
A a = new A();
是一樣的效果。
關(guān)于補(bǔ)充的問題
答案是肯定的,jvm會(huì)執(zhí)行靜態(tài)代碼段,你要記住一個(gè)概念,靜態(tài)代碼是和class綁定的,class裝載成功就表示執(zhí)行了你的靜態(tài)代碼了。而且以后不會(huì)再走這段靜態(tài)代碼了。
Class.forName(xxx.xx.xx) 返回的是一個(gè)類
Class.forName(xxx.xx.xx);的作用是要求JVM查找并加載指定的類,也就是說JVM會(huì)執(zhí)行該類的靜態(tài)代碼段
動(dòng)態(tài)加載和創(chuàng)建Class 對(duì)象,比如想根據(jù)用戶輸入的字符串來創(chuàng)建對(duì)象
String str = 用戶輸入的字符串
Class t = Class.forName(str);
t.newInstance();
在初始化一個(gè)類,生成一個(gè)實(shí)例的時(shí)候,newInstance()方法和new關(guān)鍵字除了一個(gè)是方法,一個(gè)是關(guān)鍵字外,最主要有什么區(qū)別?它們的區(qū)別在于創(chuàng)建對(duì)象的方式不一樣,前者是使用類加載機(jī)制,后者是創(chuàng)建一個(gè)新類。那么為什么會(huì)有兩種創(chuàng)建對(duì)象方式?這主要考慮到軟件的可伸縮、可擴(kuò)展和可重用等軟件設(shè)計(jì)思想。
Java中工廠模式經(jīng)常使用newInstance()方法來創(chuàng)建對(duì)象,因此從為什么要使用工廠模式上可以找到具體答案。 例如:
class c = Class.forName(“Example”);
factory = (ExampleInterface)c.newInstance();
其中ExampleInterface是Example的接口,可以寫成如下形式:
String className = "Example";
class c = Class.forName(className);
factory = (ExampleInterface)c.newInstance();
進(jìn)一步可以寫成如下形式:
String className = readfromXMlConfig;//從xml 配置文件中獲得字符串
class c = Class.forName(className);
factory = (ExampleInterface)c.newInstance();
上面代碼已經(jīng)不存在Example的類名稱,它的優(yōu)點(diǎn)是,無論Example類怎么變化,上述代碼不變,甚至可以更換Example的兄弟類Example2 , Example3 , Example4……,只要他們繼承ExampleInterface就可以。
從JVM的角度看,我們使用關(guān)鍵字new創(chuàng)建一個(gè)類的時(shí)候,這個(gè)類可以沒有被加載。但是使用newInstance()方法的時(shí)候,就必須保證:1、這個(gè)類已經(jīng)加載;2、這個(gè)類已經(jīng)連接了。而完成上面兩個(gè)步驟的正是Class的靜態(tài)方法forName()所完成的,這個(gè)靜態(tài)方法調(diào)用了啟動(dòng)類加載器,即加載 java API的那個(gè)加載器。
現(xiàn)在可以看出,newInstance()實(shí)際上是把new這個(gè)方式分解為兩步,即首先調(diào)用Class加載方法加載某個(gè)類,然后實(shí)例化。 這樣分步的好處是顯而易見的。我們可以在調(diào)用class的靜態(tài)加載方法forName時(shí)獲得更好的靈活性,提供給了一種降耦的手段。
最后用最簡(jiǎn)單的描述來區(qū)分new關(guān)鍵字和newInstance()方法的區(qū)別:
newInstance: 弱類型。低效率。只能調(diào)用無參構(gòu)造。
new: 強(qiáng)類型。相對(duì)高效。能調(diào)用任何public構(gòu)造。
過濾器可截取和修改進(jìn)入一個(gè)servlet或JSP頁面的請(qǐng)求或從一個(gè)servlet或JSP頁面發(fā)出的相應(yīng)。在執(zhí)行一個(gè) servlet或JSP頁面之前,必須執(zhí)行第一個(gè)相關(guān)的過濾器的doFilter方法。在該過濾器對(duì)其FilterChain對(duì)象調(diào)用doFilter 時(shí),執(zhí)行鏈中的下一個(gè)過濾器。如果沒有其他過濾器,servlet或JSP頁面被執(zhí)行。過濾器具有對(duì)到來的ServletRequest對(duì)象的全部訪問權(quán),因此,它們可以查看客戶機(jī)名、查找到來的cookie等。為了訪問servlet或JSP頁面的輸出,過濾器可將響應(yīng)對(duì)象包裹在一個(gè)替身對(duì)象(stand-in object)中,比方說把輸出累加到一個(gè)緩沖區(qū)。在調(diào)用FilterChain對(duì)象的doFilter方法之后,過濾器可檢查緩沖區(qū),如有必要,就對(duì)它進(jìn)行修改,然后傳送到客戶機(jī)。
<filter>
<filter-name>adminFilter</filter-name>
<filter-class>org.bluechant.mvc.filter.AdminFilter</filter-class><!--服務(wù)器部署的時(shí)候,adminFilter開始加載初始化-->
<init-param>
<param-name>loginAction</param-name>
<param-value>/account!login.do</param-value>
</init-param>
<init-param>
<param-name>loginPage</param-name>
<param-value>/login.html</param-value>
</init-param>
<init-param>
<param-name>userLoginTag</param-name>
<param-value>account_login_check</param-value>
</init-param>
</filter>
<filter>
<filter-name>userSourceFilter</filter-name>
<filter-class>org.bluechant.mvc.filter.AccountRoleFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>adminFilter</filter-name>
<url-pattern>*.do</url-pattern><!-- 表明凡是訪問跳轉(zhuǎn)*.do形式的跳轉(zhuǎn),都要運(yùn)行名字為adminFilter的過濾器 -->
</filter-mapping>
<filter-mapping>
<filter-name>userSourceFilter</filter-name>
<url-pattern>*.do</url-pattern>
</filter-mapping>
<!--接著順序加載servlet被初始化-->