j2ee面試知識

日誌 > 技術交流
發表於:2008年3月4日 21時40分7秒閱讀(7)評論(0)特效:[信紙]本文鏈接:http://user.qzone.qq.com/592433424/blog/1204638007
j2ee面試知識


Jsp方面

1jsp有哪些內置對象?作用分別是什麼?
:JSP共有以下9種基本內置組件(可與ASP6種內部組件相對應):
request 用戶端請求,此請求會包含來自GET/POST請求的參數
response 網頁傳回用戶端的迴應
pageContext 網頁的屬性是在這裏管理
session 與請求有關的會話期
application servlet 正在執行的內容
out 用來傳送回應的輸出
config servlet的構架部件
page JSP網頁本身
exception 針對錯誤網頁,未捕捉的例外

2jsp有哪些動作?作用分別是什麼?
:JSP共有以下6種基本動作
jsp:include:在頁面被請求的時候引入一個文件。
jsp:useBean:尋找或者實例化一個JavaBean
jsp:setProperty:設置JavaBean的屬性。
jsp:getProperty:輸出某個JavaBean的屬性。
jsp:forward:把請求轉到一個新的頁面。
jsp:plugin:根據瀏覽器類型爲Java插件生成OBJECTEMBED標記

3JSP中動態INCLUDE與靜態INCLUDE的區別?
答:動態INCLUDEjsp:include動作實現
<jsp:include page=included.jsp flush=true />它總是會檢查所含文件中的變化,適合用於包含動態頁面,並且可以帶參數靜態INCLUDEinclude僞碼實現,定不會檢查所含文件的變化,適用於包含靜態頁面 <%@ 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,servicedestroy方法表達。

2Servlet版本間(忘了問的是哪兩個版本了)的不同?


3JAVA SERVLET APIforward() redirect()的區別?
:前者僅是容器中控制權的轉向,在客戶端瀏覽器地址欄中不會顯示出轉向後的地址;後者則是完全的跳轉,瀏覽器將會得到跳轉的地址,並重新發送請求鏈接。這樣,從瀏覽器的地址欄中可以看到跳轉後的鏈接地址。所以,前者更加高效,在前者可以滿足需要時,儘量使用forward()方法,並且,這樣也有助於隱藏實際的鏈接。在有些情況下,比如,需要跳轉到一個其它服務器上的資源,則必須使用
sendRedirect()方法。

4Servlet的基本架構
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 {
}
}
JdbcJdo方面

1、可能會讓你寫一段JdbcOracle的程序,並實現數據查詢.
:程序如下:
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();
}
}
}

2Class.forName的作用?爲什麼要用?
答:調用該訪問返回一個以字符串指定類名的類的對象。

3Jdo是什麼?
:JDOJava對象持久化的新的規範,爲java data object的簡稱,也是一個用於存取某種數據倉庫中的對象的標準化APIJDO提供了透明的對象存儲,因此對開發人員來說,存儲數據對象完全不需要額外的代碼(如JDBC API的使用)。這些繁瑣的例行工作已經轉移到JDO產品提供商身上,使開發人員解脫出來,從而集中時間和精力在業務邏輯上。另外,JDO很靈活,因爲它可以在任何數據底層上運行。JDBC只是面向關係數據庫(RDBMSJDO更通用,提供到任何數據底層的存儲功能,比如關係數據庫、文件、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方面

1xml有哪些解析技術?區別是什麼?
: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方式解析XMLXML文件如下:
<?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>
評論列表
請選擇道具
<textarea class="content" id="commentEditor" style="BORDER-RIGHT: #ccc 1px solid; BORDER-TOP: #ccc 1px solid; BORDER-LEFT: #ccc 1px solid; COLOR: gray! important; BORDER-BOTTOM: #ccc 1px solid" οnfοcus="getUBBeditor(this)" rows="13" cols="50" name="content">點擊這裏發表評論</textarea>
溫馨提示:點擊驗證碼輸入框,以獲取驗證碼
請輸入驗證碼:
     
<script type="text/javascript"> // function jumpToTop() { if(isSmall) { document.body.scrollTop = 0; } else parent.$('mbody').scrollTop = 0; } function _quote(s){ s=s.replace(//[quote/=引自:(.+?)(?:/x20|&nbsp;){1,2}於/x20(.+?)/x20發表的評論/]/g,"/x03引自:<cite>$1</cite>&nbsp;&nbsp;於 <ins>$2</ins> 發表的評論<br />/x02").replace(//[//quote/]/g,"/x01"); for(var i=0;i<2;i++) s=s.replace(//x03([^/x03/x01/x02]*?)/x02([^/x03/x01/x02]*?)/x01/g, function(a,b,c){ return '<blockquote style="width:400px;border:dashed 1px gray;margin:10px;padding:10px">'+b+'引用內容:<br /><br /><q>'+c+'</q></blockquote>'; }); return s.replace(/[/x03/x02/x01]/g,""); } var bLoaded = false; function checkMsgReply(obj) { if(!bLoaded) top.includeJS('/qzone/blog/script/common.js', function(){bLoaded=true;checkMsgReply(obj)}, document); else checkReply(obj); if(obj.checked){ MAX_COMMENT_LEN = 500; } else { MAX_COMMENT_LEN = 4500; } _fontCount = MAX_COMMENT_LEN; //字數限制 if(!window.sendCommentEditor) return; if(sendCommentEditor.editorArea.editMode == 1) toCountFont(sendCommentEditor.id, "html"); else toCountFont(sendCommentEditor.id, "text"); } function showMsgLeftCnt() { if(!bLoaded) top.includeJS('/qzone/blog/script/common.js', function(){bLoaded=true;showMsgLeftCnt();}, document); else showLeftSMS(); } function selectBlogPaper() { if(checkLogin() <= 10000) { top.showLoginBox("mall"); return; } if(!!top.g_JData["blogContent"]) { if(parent.g_iLoginUin == parent.g_iUin) { location.href="/qzone/newblog/blogeditor.html?paperid=" + parent.g_JData["blogContent"].data.lp_id + "&paperstyle=" + parent.g_JData["blogContent"].data.lp_style + "&paperdialog=1"; } else { parent.location.href="http://user.qzone.qq.com/" + parent.g_iLoginUin + "/addNewBlog?paperid=" + parent.g_JData["blogContent"].data.lp_id + "&paperstyle=" + parent.g_JData["blogContent"].data.lp_style; } } else { top.showMsgBox("抱歉,暫時無法獲取該信紙信息!", 1, 2000); } } /** * 批量刪除中選擇全選 */ function selectAllComments(bChecked) { var oList = document.getElementsByName("commentCheckBox"); if(oList.length==0) return; for(var i=0; i<oList.length; ++i){ oList[i].checked = !!bChecked; } } function showCommentCheckBoxs(bShow, bCheck){ var oList = document.getElementsByName("commentCheckBox"); if(oList.length==0) return; for(var i=0; i<oList.length; ++i){ oList[i].style.display = ((!!bShow) ? "" : "none"); if(!!bCheck) oList[i].checked = true; else oList[i].checked = false; } if(!!bCheck) $("batchSelAllInput").checked = true; else $("batchSelAllInput").checked = false; $("leftDeleteComParag").style.display = ((!!bShow) ? "" : "none"); $("batchDelComHref").style.display = ((!!bShow) ? "none" : ""); $("noBatchDelComHref").style.display = ((!!bShow) ? "" : "none"); } /** * 名博批量刪除評論 */ function deleteBatchComments() { if(!contentProperty) return; var oList = document.getElementsByName("commentCheckBox"); if(oList.length==0) { return; } var tmp; var strCommentList = ''; var strArchList = ''; var nDeleteCnt = 0; for(var i=0; i<oList.length; ++i){ if(oList[i].checked) { tmp = oList[i].value.split('_') strCommentList += ('-' + tmp[0]); strArchList += ('-' + tmp[1]); ++nDeleteCnt; } } strCommentList = strCommentList.substr(1); strArchList = strArchList.substr(1); if(nDeleteCnt == 0) { parent.showMsgbox("請選擇要刪除的評論", 0, 2000); return; } if(!!contentProperty && contentProperty.totalCommentNumber < nDeleteCnt) return; if(!confirm("您是否要刪除選中的用戶評論?")) return; parent.loadXMLAsyncNoCache("delBatchReply", "http://"+BLOG_DOMAIN+CGI_PATH+"blog_batch_del_comment", function(){ if(parent.g_XDoc["delBatchReply"].selectNodes("error").length > 0){ dalert(null, parent.g_XDoc["delBatchReply"].xml, 2000); delete parent.g_XDoc["delBatchReply"]; return; } dalert(null, parent.g_XDoc["delBatchReply"].xml, 2000, 2); contentProperty.totalCommentNumber -= nDeleteCnt; //清理cache with(contentProperty){ delete parent.g_XDoc["blogRoot"].contentHSList[currentBlogid]; pageList = {}; pageIndexMap = []; currentCommentPage = lastCommentPage = (!contentProperty.nowaPage)?0:nowaPage[3]; parent.g_XDoc["blogRoot"].replyNumUpdateHSmap[currentBlogid] = totalCommentNumber; parent.isRefreshTop = true; if(currentCommentPage == 0) { setTimeout(contentInit, 1000); } else{ var tp = Math.ceil(totalCommentNumber/PAGE_COMMENT_NUM); var num = totalCommentNumber%PAGE_COMMENT_NUM; if(num==0 || currentCommentPage<tp-1) num = PAGE_COMMENT_NUM; getOnePageComment(num, nowaPage[0], nowaPage[1], nowaPage[2], blogCommentListCallback, 1); $("commentCount3").innerHTML = totalCommentNumber; } } delete top.g_XDoc["delBatchReply"]; showCommentCheckBoxs(false, false); }, function(){ dalert(null, BUSY_MSG, 2000); delete parent.g_XDoc["delBatchReply"]; }, "uin="+parent.g_iLoginUin+"&blogid="+contentProperty.currentBlogid+"&archlist="+strArchList.URLencode()+"&replyidlist="+strCommentList.URLencode() ); } /** * 有評論或沒有時顯示/隱藏相關element */ function showElementsAnyReply(bShow) { var strCss = !!bShow ? "" : "none"; if(isStar && parent.g_iUin == parent.g_iLoginUin) { $("starDeleteComDiv").style.display = strCss; } if(parent.g_bBlogShowCheatHint == true) $("commentHintDiv").style.display = strCss; } /** * 關閉提防上當提示信息 */ function closeCheatHint() { parent.g_bBlogShowCheatHint = false; $('commentHintDiv').style.display = 'none'; } setLoginStatus(); var frmComment=document.getElementById("commendForm"); if(!isSmall) document.body.οnkeydοwn=scrollBlog; if((isStar || isBiz) && (top.g_iLoginUin!=top.g_iUin)){ frmComment.hassign.checked=false; $("startToolSelect").style.display="none"; } if(top.g_iLoginUin>10000 && top.g_iLoginUin!=top.g_iUin) { $("msgboardSelfReply").style.display = ""; $("blogSelPaper").title = "我也要使用此信紙寫日誌"; } setTimeout(contentInit,50); // </script>  
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章