J2EE 常见回答
1、jsp有哪些內置對象?作用分別是什么?
答:JSP共有以下9種基本內置組件(可與ASP的6種內部組件相對應):
request 用戶端請求,此請求會包含來自GET/POST請求的參數(shù)
response 網(wǎng)頁傳回用戶端的回應
pageContext 網(wǎng)頁的屬性是在這里管理
session 與請求有關的會話期
application servlet 正在執(zhí)行的內容
out 用來傳送回應的輸出
config servlet的構架部件
page JSP網(wǎng)頁本身
exception 針對錯誤網(wǎng)頁,未捕捉的例外
2、jsp有哪些動作?作用分別是什么?
答:JSP共有以下6種基本動作
jsp:include:在頁面被請求的時候引入一個文件。
jsp:useBean:尋找或者實例化一個JavaBean。
jsp:setProperty:設置JavaBean的屬性。
jsp:getProperty:輸出某個JavaBean的屬性。
jsp:forward:把請求轉到一個新的頁面。
jsp:plugin:根據(jù)瀏覽器類型為Java插件生成OBJECT或EMBED標記
3、JSP中動態(tài)INCLUDE與靜態(tài)INCLUDE的區(qū)別?
答:動態(tài)INCLUDE用jsp:include動作實現(xiàn)
<jsp:include page="included.jsp" flush="true" />它總是會檢查所含文件中的變化,適合用于包含動態(tài)頁面,并且可以帶參數(shù)
靜態(tài)INCLUDE用include偽碼實現(xiàn),定不會檢查所含文件的變化,適用于包含靜態(tài)頁面
<%@ include file="included.htm" %>
4、兩種跳轉方式分別是什么?有什么區(qū)別?
答:有兩種,分別為:
<jsp:include page="included.jsp" flush="true">
<jsp:forward page= "nextpage.jsp"/>
前者頁面不會轉向include所指的頁面,只是顯示該頁的結果,主頁面還是原來的頁面。執(zhí)行完后還會回來,相當于函數(shù)調用。并且可以帶參數(shù).后者完全轉向新頁面,不會再回來。相當于go to 語句。
Servlet方面
1、說一說Servlet的生命周期?
答:servlet有良好的生存期的定義,包括加載和實例化、初始化、處理請求以及服務結束。這個生存期由javax.servlet.Servlet接口的init,service和destroy方法表達。
2、Servlet版本間(忘了問的是哪兩個版本了)的不同?
希望大家補上,謝謝
3、JAVA SERVLET API中forward() 與redirect()的區(qū)別?
答:前者僅是容器中控制權的轉向,在客戶端瀏覽器地址欄中不會顯示出轉向后的地址;后者則是完全的跳轉,瀏覽器將會得到跳轉的地址,并重新發(fā)送請求鏈接。這樣,從瀏覽器的地址欄中可以看到跳轉后的鏈接地址。所以,前者更加高效,在前者可以滿足需要時,盡量使用forward()方法,并且,這樣也有助于隱藏實際的鏈接。在有些情況下,比如,需要跳轉到一個其它服務器上的資源,則必須使用sendRedirect()方法。
4、Servlet的基本架構?
Jdbc、Jdo方面
public?class?ServletName?extends?HttpServlet?...{?public?void?doPost(HttpServletRequest?request,?HttpServletResponse?response)?throws?
ServletException,?IOException?...{?
}?
public?void?doGet(HttpServletRequest?request,?HttpServletResponse?response)?throws?
ServletException,?IOException?...{?
}?
}
?
1、可能會讓你寫一段Jdbc連Oracle的程序,并實現(xiàn)數(shù)據(jù)查詢.
答:程序如下:
import?java.sql.*;?
public?class?jdbc?
...{?
String?dbUrl="jdbc:oracle:thin:@127.0.0.1:1521:orcl";?
String?theUser="admin";?
String?thePw="manager";?
Connection?c=null;?
Statement?conn;?
ResultSet?rs=null;?
public?jdbc()?
...{?
try...{?
Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();?
c?=?DriverManager.getConnection(dbUrl,theUser,thePw);?
conn=c.createStatement();?
}catch(Exception?e)...{?
e.printStackTrace();?
}?
}?
public?boolean?executeUpdate(String?sql)?
...{?
try?
...{?
conn.executeUpdate(sql);?
return?true;?
}?
catch?(SQLException?e)?
...{?
e.printStackTrace();?
return?false;?
}?
}?
public?ResultSet?executeQuery(String?sql)?
...{?
rs=null;?
try?
...{?
rs=conn.executeQuery(sql);?
}?
catch?(SQLException?e)?
...{?
e.printStackTrace();?
}?
return?rs;?
}?
public?void?close()?
...{?
try?
...{?
conn.close();?
c.close();?
}?
catch?(Exception?e)?
...{?
e.printStackTrace();?
}?
}?
public?static?void?main(String[]?args)?
...{?
ResultSet?rs;?
jdbc?conn?=?new?jdbc();?
rs=conn.executeQuery("select?*?from?test");?
try...{?
while?(rs.next())?
...{?
System.out.println(rs.getString("id"));?
System.out.println(rs.getString("name"));?
}?
}catch(Exception?e)?
...{?
e.printStackTrace();?
}?
}?
}?
?
2、Class.forName的作用?為什么要用?
答:調用該訪問返回一個以字符串指定類名的類的對象。
3、Jdo是什么?
答:JDO是Java對象持久化的新的規(guī)范,為java data object的簡稱,也是一個用于存取某種數(shù)據(jù)倉庫中的對象的標準化API。JDO提供了透明的對象存儲,因此對開發(fā)人員來說,存儲數(shù)據(jù)對象完全不需要額外的代碼(如JDBC API的使用)。這些繁瑣的例行工作已經(jīng)轉移到JDO產(chǎn)品提供商身上,使開發(fā)人員解脫出來,從而集中時間和精力在業(yè)務邏輯上。另外,JDO很靈活,因為它可以在任何數(shù)據(jù)底層上運行。JDBC只是面向關系數(shù)據(jù)庫(RDBMS)JDO更通用,提供到任何數(shù)據(jù)底層的存儲功能,比如關系數(shù)據(jù)庫、文件、XML以及對象數(shù)據(jù)庫(ODBMS)等等,使得應用可移植性更強。
4、在ORACLE大數(shù)據(jù)量下的分頁解決方法。一般用截取ID方法,還有是三層嵌套方法。
答:一種分頁方法
int?i=1;?
int?numPages=14;?
String?pages?=?request.getParameter("page")?;?
int?currentPage?=?1;?
currentPage=(pages==null)?(1):{Integer.parseInt(pages)}?
sql?=?"select?count(*)?from?tables";?
ResultSet?rs?=?DBLink.executeQuery(sql)?;?
while(rs.next())?i?=?rs.getInt(1)?;?
int?intPageCount=1;?
intPageCount=(i%numPages==0)?(i/numPages):(i/numPages+1);?
int?nextPage?;?
int?upPage;?
nextPage?=?currentPage+1;?
if?(nextPage>=intPageCount)?nextPage=intPageCount;?
upPage?=?currentPage-1;?
if?(upPage<=1)?upPage=1;?
rs.close();?
sql="select?*?from?tables";?
rs=DBLink.executeQuery(sql);?
i=0;?
while((i<numPages*(currentPage-1))&&rs.next()){i++;}?
%>?
//輸出內容?
//輸出翻頁連接?
合計:<%=currentPage%>/<%=intPageCount%><a?href="List.jsp?page=1">第一頁</a>
<a?href="List.jsp?page=<%=upPage%>">上一頁</a>?
<%......?
for(int?j=1;j<=intPageCount;j++){?
if(currentPage!=j){?
%>?
<a?href="list.jsp?page=<%=j%>">[<%=j%>]</a>?
<%......?
}else{?
out.println(j);?
}?
}?
%>?
<a?href="List.jsp?page=<%=nextPage%>">下一頁</a><a?href="List.jsp?page=<%=intPageCount%>">最后頁</a>?
Xml方面
1、xml有哪些解析技術?區(qū)別是什么?
答:有DOM,SAX,STAX等
DOM:處理大型文件時其性能下降的非常厲害。這個問題是由DOM的樹結構所造成的,這種結構占用的內存較多,而且DOM必須在解析文件之前把整個文檔裝入內存,適合對XML的隨機訪問SAX:不現(xiàn)于DOM,SAX是事件驅動型的XML解析方式。它順序讀取XML文件,不需要一次全部裝載整個文件。當遇到像文件開頭,文檔結束,或者標簽開頭與標簽結束時,它會觸發(fā)一個事件,用戶通過在其回調事件中寫入處理代碼來處理XML文件,適合對XML的順序訪問
STAX:Streaming API for XML (StAX)
2、你在項目中用到了xml技術的哪些方面?如何實現(xiàn)的?
答:用到了數(shù)據(jù)存貯,信息配置兩方面。在做數(shù)據(jù)交換平臺時,將不能數(shù)據(jù)源的數(shù)據(jù)組裝成XML文件,然后將XML文件壓縮打包加密后通過網(wǎng)絡傳送給接收者,接收解密與解壓縮后再同XML文件中還原相關信息進行處理。在做軟件配置時,利用XML可以很方便的進行,軟件的各種配置參數(shù)都存貯在XML文件中。
3、用jdom解析xml文件時如何解決中文問題?如何解析?
答:看如下代碼,用編碼方式加以解決
import?java.io.*;?
public?class?DOMTest?
...{?
private?String?inFile?=?"c:people.xml";?
private?String?outFile?=?"c:people.xml";?
public?static?void?main(String?args[])?
...{?
new?DOMTest();?
}?
public?DOMTest()?
...{?
try?
...{?
javax.xml.parsers.DocumentBuilder?builder?=?
javax.xml.parsers.DocumentBuilderFactory.newInstance().newDocumentBuilder();?
org.w3c.dom.Document?doc?=?builder.newDocument();?
org.w3c.dom.Element?root?=?doc.createElement("老師");?
org.w3c.dom.Element?wang?=?doc.createElement("王");?
org.w3c.dom.Element?liu?=?doc.createElement("劉");?
wang.appendChild(doc.createTextNode("我是王老師"));?
root.appendChild(wang);?
doc.appendChild(root);?
javax.xml.transform.Transformer?transformer?=?
javax.xml.transform.TransformerFactory.newInstance().newTransformer();?
transformer.setOutputProperty(javax.xml.transform.OutputKeys.ENCODING,?"gb2312");?
transformer.setOutputProperty(javax.xml.transform.OutputKeys.INDENT,?"yes");?
transformer.transform(new?javax.xml.transform.dom.DOMSource(doc),?
new?
javax.xml.transform.stream.StreamResult(outFile));?
}?
catch?(Exception?e)?
...{?
System.out.println?(e.getMessage());?
}?
}?
}?
4、編程用JAVA解析XML的方式.
答:用SAX方式解析XML,XML文件如下:
<person>?
<name>王小明</name>?
<college>信息學院</college>?
<telephone>6258113</telephone>?
<notes>男,1955年生,博士,95年調入海南大學</notes>?
</person>?
?
事件回調類SAXHandler.java?import?java.io.*;?
import?java.util.Hashtable;?
import?org.xml.sax.*;?
public?class?SAXHandler?extends?HandlerBase?
...{?
private?Hashtable?table?=?new?Hashtable();?
private?String?currentElement?=?null;?
private?String?currentValue?=?null;?
public?void?setTable(Hashtable?table)?
...{?
this.table?=?table;?
}?
public?Hashtable?getTable()?
...{?
return?table;?
}?
public?void?startElement(String?tag,?AttributeList?attrs)?
throws?SAXException?
...{?
currentElement?=?tag;?
}?
public?void?characters(char[]?ch,?int?start,?int?length)?
throws?SAXException?
...{?
currentValue?=?new?String(ch,?start,?length);?
}?
public?void?endElement(String?name)?throws?SAXException?
...{?
if?(currentElement.equals(name))?
table.put(currentElement,?currentValue);?
}?
}?
?
JSP內容顯示源碼,SaxXml.jsp:?<HTML>?
<HEAD>?
<TITLE>剖析XML文件people.xml</TITLE>?
</HEAD>?
<BODY>?
<%...@?page?errorPage="ErrPage.jsp"?
contentType="text/html;charset=GB2312"?%>?
<%...@?page?import="java.io.*"?%>?
<%...@?page?import="java.util.Hashtable"?%>?
<%...@?page?import="org.w3c.dom.*"?%>?
<%...@?page?import="org.xml.sax.*"?%>?
<%...@?page?import="javax.xml.parsers.SAXParserFactory"?%>?
<%...@?page?import="javax.xml.parsers.SAXParser"?%>?
<%...@?page?import="SAXHandler"?%>?
<%...?
File?file?=?new?File("c:people.xml");?
FileReader?reader?=?new?FileReader(file);?
Parser?parser;?
SAXParserFactory?spf?=?SAXParserFactory.newInstance();?
SAXParser?sp?=?spf.newSAXParser();?
SAXHandler?handler?=?new?SAXHandler();?
sp.parse(new?InputSource(reader),?handler);?
Hashtable?hashTable?=?handler.getTable();?
out.println("<TABLE?BORDER=2><CAPTION>教師信息表</CAPTION>");?
out.println("<TR><TD>姓名</TD>"?+?"<TD>"?+?
(String)hashTable.get(new?String("name"))?+?"</TD></TR>");?
out.println("<TR><TD>學院</TD>"?+?"<TD>"?+?
(String)hashTable.get(new?String("college"))+"</TD></TR>");?
out.println("<TR><TD>電話</TD>"?+?"<TD>"?+?
(String)hashTable.get(new?String("telephone"))?+?"</TD></TR>");?
out.println("<TR><TD>備注</TD>"?+?"<TD>"?+?
(String)hashTable.get(new?String("notes"))?+?"</TD></TR>");?
out.println("</TABLE>");?
%>?
</BODY>?
</HTML>?
?
EJB方面
1、EJB2.0有哪些內容?分別用在什么場合? EJB2.0和EJB1.1的區(qū)別?
答:規(guī)范內容包括Bean提供者,應用程序裝配者,EJB容器,EJB配置工具,EJB服務提供者,系統(tǒng)管理員。這里面,EJB容器是EJB之所以能夠運行的核心。EJB容器管理著EJB的創(chuàng)建,撤消,激活,去活,與數(shù)據(jù)庫的連接等等重要的核心工作。JSP,Servlet,EJB,JNDI,JDBC,JMS.....
2、EJB與JAVA BEAN的區(qū)別?
答:Java Bean 是可復用的組件,對Java Bean并沒有嚴格的規(guī)范,理論上講,任何一個Java類都可以是一個Bean。但通常情況下,由于Java Bean是被容器所創(chuàng)建(如Tomcat)的,所以Java Bean應具有一個無參的構造器,另外,通常Java Bean還要實現(xiàn)Serializable接口用于實現(xiàn)Bean的持久性。Java Bean實際上相當于微軟COM模型中的本地進程內COM組件,它是不能被跨進程訪問的。Enterprise Java Bean 相當于DCOM,即分布式組件。它是基于Java的遠程方法調用(RMI)技術的,所以EJB可以被遠程訪問(跨進程、跨計算機)。但EJB必須被布署在諸如Webspere、WebLogic這樣的容器中,EJB客戶從不直接訪問真正的EJB組件,而是通過其容器訪問。EJB容器是EJB組件的代理,EJB組件由容器所創(chuàng)建和管理。客戶通過容器來訪問真正的EJB組件。
3、EJB的基本架構
答:一個EJB包括三個部分:
package?Beans;?
import?javax.ejb.EJBObject;?
import?java.rmi.RemoteException;?
public?interface?Add?extends?EJBObject?
...{?
//some?method?declare?
}?
Home?Interface?接口的代碼?
package?Beans;?
import?java.rmi.RemoteException;?
import?jaax.ejb.CreateException;?
import?javax.ejb.EJBHome;?
public?interface?AddHome?extends?EJBHome?
...{?
//some?method?declare?
}?
EJB類的代碼?
package?Beans;?
import?java.rmi.RemoteException;?
import?javax.ejb.SessionBean;?
import?javx.ejb.SessionContext;?
public?class?AddBean?Implements?SessionBean?
...{?
//some?method?declare?
}?
?
J2EE,MVC方面
1、MVC的各個部分都有那些技術來實現(xiàn)?如何實現(xiàn)?
答:MVC是Model-View-Controller的簡寫。"Model" 代表的是應用的業(yè)務邏輯(通過JavaBean,EJB組件實現(xiàn)), "View" 是應用的表示面(由JSP頁面產(chǎn)生),"Controller" 是提供應用的處理過程控制(一般是一個Servlet),通過這種設計模型把應用邏輯,處理過程和顯示邏輯分成不同的組件實現(xiàn)。這些組件可以進行交互和重用。
2、應用服務器與WEB SERVER的區(qū)別?
希望大家補上,謝謝
3、J2EE是什么?
答:Je22是Sun公司提出的多層(multi-diered),分布式(distributed),基于組件(component-base)的企業(yè)級應用模型(enterpriese application model).在這樣的一個應用系統(tǒng)中,可按照功能劃分為不同的組件,這些組件又可在不同計算機上,并且處于相應的層次(tier)中。所屬層次包括客戶層(clietn tier)組件,web層和組件,Business層和組件,企業(yè)信息系統(tǒng)(EIS)層。
4、WEB SERVICE名詞解釋。JSWDL開發(fā)包的介紹。JAXP、JAXM的解釋。SOAP、UDDI,WSDL解釋。
答:Web Service描述語言WSDL
SOAP即簡單對象訪問協(xié)議(Simple Object Access Protocol),它是用于交換XML編碼信息的輕量級協(xié)議。
UDDI 的目的是為電子商務建立標準;UDDI是一套基于Web的、分布式的、為Web Service提供的、信息注冊中心的實現(xiàn)標準規(guī)范,同時也包含一組使企業(yè)能將自身提供的Web Service注冊,以使別的企業(yè)能夠發(fā)現(xiàn)的訪問協(xié)議的實現(xiàn)標準。
5、BS與CS的聯(lián)系與區(qū)別。
希望大家補上,謝謝
6、STRUTS的應用(如STRUTS架構)
答:Struts是采用Java Servlet/JavaServer Pages技術,開發(fā)Web應用程序的開放源碼的framework。 采用Struts能開發(fā)出基于MVC(Model-View-Controller)設計模式的應用構架。 Struts有如下的主要功能:
一.包含一個controller servlet,能將用戶的請求發(fā)送到相應的Action對象。
二.JSP自由tag庫,并且在controller servlet中提供關聯(lián)支持,幫助開發(fā)員創(chuàng)建交互式表單應用。
三.提供了一系列實用對象:XML處理、通過Java reflection APIs自動處理JavaBeans屬性、國際化的提示和消息。
設計模式方面
1、開發(fā)中都用到了那些設計模式?用在什么場合?
答:每個模式都描述了一個在我們的環(huán)境中不斷出現(xiàn)的問題,然后描述了該問題的解決方案的核心。通過這種方式,你可以無數(shù)次地使用那些已有的解決方案,無需在重復相同的工作。主要用到了MVC的設計模式。用來開發(fā)JSP/Servlet或者J2EE的相關應用。簡單工廠模式等。
2、UML方面
答:標準建模語言UML。用例圖,靜態(tài)圖(包括類圖、對象圖和包圖),行為圖,交互圖(順序圖,合作圖),實現(xiàn)圖,
JavaScript方面
1、如何校驗數(shù)字型?
var?str=document.form1.all(i).value;?
var?r=str.match(re);?
if?(r==null)?
...{?
sign=-4;?
break;?
}?
else...{?
document.form1.all(i).value=parseFloat(str);?
}?
CORBA方面
1、CORBA是什么?用途是什么?
答:CORBA 標準是公共對象請求代理結構(Common Object Request Broker Architecture),由對象管理組織 (Object Management Group,縮寫為 OMG)標準化。它的組成是接口定義語言(IDL), 語言綁定(binding:也譯為聯(lián)編)和允許應用程序間互操作的協(xié)議。 其目的為:
用不同的程序設計語言書寫
在不同的進程中運行
為不同的操作系統(tǒng)開發(fā)
總結