j2ee面試知識
Jsp方面 1、jsp有哪些內置對象?作用分別是什麼? 答:JSP共有以下9種基本內置組件(可與ASP的6種內部組件相對應): request 用戶端請求,此請求會包含來自GET/POST請求的參數 response 網頁傳回用戶端的迴應 pageContext 網頁的屬性是在這裏管理 session 與請求有關的會話期 application servlet 正在執行的內容 out 用來傳送回應的輸出 config servlet的構架部件 page JSP網頁本身 exception 針對錯誤網頁,未捕捉的例外 2、jsp有哪些動作?作用分別是什麼? 答:JSP共有以下6種基本動作 jsp:include:在頁面被請求的時候引入一個文件。 jsp:useBean:尋找或者實例化一個JavaBean。 jsp:setProperty:設置JavaBean的屬性。 jsp:getProperty:輸出某個JavaBean的屬性。 jsp:forward:把請求轉到一個新的頁面。 jsp:plugin:根據瀏覽器類型爲Java插件生成OBJECT或EMBED標記 3、JSP中動態INCLUDE與靜態INCLUDE的區別? 答:動態INCLUDE用jsp:include動作實現 <jsp:include page=included.jsp flush=true />它總是會檢查所含文件中的變化,適合用於包含動態頁面,並且可以帶參數靜態INCLUDE用include僞碼實現,定不會檢查所含文件的變化,適用於包含靜態頁面 <%@ include file=included.htm %> 4、兩種跳轉方式分別是什麼?有什麼區別? 答:有兩種,分別爲: <jsp:include page=included.jsp flush=true> <jsp:forward page= nextpage.jsp/> 前者頁面不會轉向include所指的頁面,只是顯示該頁的結果,主頁面還是原來的頁面。執行完後還會回來,相當於函數調用。並且可以帶參數.後者完全轉向新頁面,不會再回來。相當於go to 語句。 Servlet方面 1、說一說Servlet的生命週期? 答:servlet有良好的生存期的定義,包括加載和實例化、初始化、處理請求以及服務結束。這個生存期由javax.servlet.Servlet接口的init,service和destroy方法表達。 2、Servlet版本間(忘了問的是哪兩個版本了)的不同? 3、JAVA SERVLET API中forward() 與redirect()的區別? 答:前者僅是容器中控制權的轉向,在客戶端瀏覽器地址欄中不會顯示出轉向後的地址;後者則是完全的跳轉,瀏覽器將會得到跳轉的地址,並重新發送請求鏈接。這樣,從瀏覽器的地址欄中可以看到跳轉後的鏈接地址。所以,前者更加高效,在前者可以滿足需要時,儘量使用forward()方法,並且,這樣也有助於隱藏實際的鏈接。在有些情況下,比如,需要跳轉到一個其它服務器上的資源,則必須使用 sendRedirect()方法。 4、Servlet的基本架構 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 { } } Jdbc、Jdo方面 1、可能會讓你寫一段Jdbc連Oracle的程序,並實現數據查詢. 答:程序如下: package hello.ant; 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對象持久化的新的規範,爲java data object的簡稱,也是一個用於存取某種數據倉庫中的對象的標準化API。JDO提供了透明的對象存儲,因此對開發人員來說,存儲數據對象完全不需要額外的代碼(如JDBC API的使用)。這些繁瑣的例行工作已經轉移到JDO產品提供商身上,使開發人員解脫出來,從而集中時間和精力在業務邏輯上。另外,JDO很靈活,因爲它可以在任何數據底層上運行。JDBC只是面向關係數據庫(RDBMS)JDO更通用,提供到任何數據底層的存儲功能,比如關係數據庫、文件、XML以及對象數據庫(ODBMS)等等,使得應用可移植性更強。 4、在ORACLE大數據量下的分頁解決方法。一般用截取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有哪些解析技術?區別是什麼? 答:有DOM,SAX,STAX等 DOM:處理大型文件時其性能下降的非常厲害。這個問題是由DOM的樹結構所造成的,這種結構佔用的內存較多,而且DOM必須在解析文件之前把整個文檔裝入內存,適合對XML的隨機訪問SAX:不現於DOM,SAX是事件驅動型的XML解析方式。它順序讀取XML文件,不需要一次全部裝載整個文件。當遇到像文件開頭,文檔結束,或者標籤開頭與標籤結束時,它會觸發一個事件,用戶通過在其回調事件中寫入處理代碼來處理XML文件,適合對XML的順序訪問 STAX:Streaming API for XML (StAX) 2、你在項目中用到了xml技術的哪些方面?如何實現的? 答:用到了數據存貯,信息配置兩方面。在做數據交換平臺時,將不能數據源的數據組裝成XML文件,然後將XML文件壓縮打包加密後通過網絡傳送給接收者,接收解密與解壓縮後再同XML文件中還原相關信息進行處理。在做軟件配置時,利用XML可以很方便的進行,軟件的各種配置參數都存貯在XML文件中。 3、用jdom解析xml文件時如何解決中文問題?如何解析? 答:看如下代碼,用編碼方式加以解決 package test; 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文件如下: <?xml version=1.0 encoding=gb2312?> <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> |
j2ee面試知識
日誌 > 技術交流
評論列表
溫馨提示:點擊驗證碼輸入框,以獲取驗證碼
請輸入驗證碼:
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.