j2ee面试知识JAVAWord格式文档下载.docx
- 文档编号:16551621
- 上传时间:2022-11-24
- 格式:DOCX
- 页数:13
- 大小:21.46KB
j2ee面试知识JAVAWord格式文档下载.docx
《j2ee面试知识JAVAWord格式文档下载.docx》由会员分享,可在线阅读,更多相关《j2ee面试知识JAVAWord格式文档下载.docx(13页珍藏版)》请在冰豆网上搜索。
includepage=included.jspflush=true/>
它总是会检查所含文件中的变化,适合用于包含动态页面,并且可以带参数静态INCLUDE用include伪码实现,定不会检查所含文件的变化,适用于包含静态页面<
%@includefile=included.htm%>
4、两种跳转方式分别是什么?
有什么区别?
有两种,分别为:
includepage=included.jspflush=true>
forwardpage=nextpage.jsp/>
前者页面不会转向include所指的页面,只是显示该页的结果,主页面还是原来的页面。
执行完后还会回来,相当于函数调用。
并且可以带参数.后者完全转向新页面,不会再回来。
相当于goto语句。
Servlet方面
1、说一说Servlet的生命周期?
servlet有良好的生存期的定义,包括加载和实例化、初始化、处理请求以及服务结束。
这个生存期由javax.servlet.Servlet接口的init,service和destroy方法表达。
2、Servlet版本间(忘了问的是哪两个版本了)的不同?
3、JAVASERVLETAPI中forward()与redirect()的区别?
前者仅是容器中控制权的转向,在客户端浏览器地址栏中不会显示出转向后的地址;
后者则是完全的跳转,浏览器将会得到跳转的地址,并重新发送请求链接。
这样,从浏览器的地址栏中可以看到跳转后的链接地址。
所以,前者更加高效,在前者可以满足需要时,尽量使用forward()方法,并且,这样也有助于隐藏实际的链接。
在有些情况下,比如,需要跳转到一个其它服务器上的资源,则必须使用
sendRedirect()方法。
4、Servlet的基本架构
publicclassServletNameextendsHttpServlet{
publicvoiddoPost(HttpServletRequestrequest,HttpServletResponseresponse)throws
ServletException,IOException{
}
publicvoiddoGet(HttpServletRequestrequest,HttpServletResponseresponse)throws
Jdbc、Jdo方面
1、可能会让你写一段Jdbc连Oracle的程序,并实现数据查询.
程序如下:
packagehello.ant;
importjava.sql.*;
publicclassjdbc
{
StringdbUrl=jdbc:
oracle:
thin:
@127.0.0.1:
1521:
orcl;
StringtheUser=admin;
StringthePw=manager;
Connectionc=null;
Statementconn;
ResultSetrs=null;
publicjdbc()
try{
Class.forName(oracle.jdbc.driver.OracleDriver).newInstance();
c=DriverManager.getConnection(dbUrl,theUser,thePw);
conn=c.createStatement();
}catch(Exceptione){
e.printStackTrace();
publicbooleanexecuteUpdate(Stringsql)
try
conn.executeUpdate(sql);
returntrue;
catch(SQLExceptione)
returnfalse;
publicResultSetexecuteQuery(Stringsql)
rs=null;
rs=conn.executeQuery(sql);
returnrs;
publicvoidclose()
conn.close();
c.close();
catch(Exceptione)
publicstaticvoidmain(String[]args)
ResultSetrs;
jdbcconn=newjdbc();
rs=conn.executeQuery(select*fromtest);
while(rs.next())
System.out.println(rs.getString(id));
System.out.println(rs.getString(name));
}catch(Exceptione)
2、Class.forName的作用?
为什么要用?
调用该访问返回一个以字符串指定类名的类的对象。
3、Jdo是什么?
JDO是Java对象持久化的新的规范,为javadataobject的简称,也是一个用于存取某种数据仓库中的对象的标准化API。
JDO提供了透明的对象存储,因此对开发人员来说,存储数据对象完全不需要额外的代码(如JDBCAPI的使用)。
这些繁琐的例行工作已经转移到JDO产品提供商身上,使开发人员解脱出来,从而集中时间和精力在业务逻辑上。
另外,JDO很灵活,因为它可以在任何数据底层上运行。
JDBC只是面向关系数据库(RDBMS)JDO更通用,提供到任何数据底层的存储功能,比如关系数据库、文件、XML以及对象数据库(ODBMS)等等,使得应用可移植性更强。
4、在ORACLE大数据量下的分页解决方法。
一般用截取ID方法,还有是三层嵌套方法。
一种分页方法
%
inti=1;
intnumPages=14;
Stringpages=request.getParameter(page);
intcurrentPage=1;
currentPage=(pages==null)?
(1):
{Integer.parseInt(pages)}
sql=selectcount(*)fromtables;
ResultSetrs=DBLink.executeQuery(sql);
while(rs.next())i=rs.getInt
(1);
intintPageCount=1;
intPageCount=(i%numPages==0)?
(i/numPages):
(i/numPages+1);
intnextPage;
intupPage;
nextPage=currentPage+1;
if(nextPage>
=intPageCount)nextPage=intPageCount;
upPage=currentPage-1;
if(upPage<
=1)upPage=1;
rs.close();
sql=select*fromtables;
rs=DBLink.executeQuery(sql);
i=0;
while((i<
numPages*(currentPage-1))&
&
rs.next()){i++;
%>
//输出内容
//输出翻页连接
合计:
%=currentPage%>
/<
%=intPageCount%>
ahref=List.jsp?
page=1>
第一页<
/a>
a
href=List.jsp?
page=<
%=upPage%>
>
上一页<
for(intj=1;
j<
=intPageCount;
j++){
if(currentPage!
=j){
ahref=list.jsp?
%=j%>
[<
]<
}else{
out.println(j);
%=nextPage%>
下一页<
最后页
Xml方面
1、xml有哪些解析技术?
区别是什么?
有DOM,SAX,STAX等
DOM:
处理大型文件时其性能下降的非常厉害。
这个问题是由DOM的树结构所造成的,这种结构占用的内存较多,而且DOM必须在解析文件之前把整个文档装入内存,适合对XML的随机访问SAX:
不现于DOM,SAX是事件驱动型的XML解析方式。
它顺序读取XML文件,不需要一次全部装载整个文件。
当遇到像文件开头,文档结束,或者标签开头与标签结束时,它会触发一个事件,用户通过在其回调事件中写入处理代码来处理XML文件,适合对XML的顺序访问
STAX:
StreamingAPIforXML(StAX)
2、你在项目中用到了xml技术的哪些方面?
如何实现的?
用到了数据存贮,信息配置两方面。
在做数据交换平台时,将不能数据源的数据组装成XML文件,然后将XML文件压缩打包加密后通过网络传送给接收者,接收解密与解压缩后再同XML文件中还原相关信息进行处理。
在做软件配置时,利用XML可以很方便的进行,软件的各种配置参数都存贮在XML文件中。
3、用jdom解析xml文件时如何解决中文问题?
如何解析?
看如下代码,用编码方式加以解决
packagetest;
importjava.io.*;
publicclassDOMTest
privateStringinFile=c:
\people.xml;
privateStringoutFile=c:
publicstaticvoidmain(Stringargs[])
newDOMTest();
publicDOMTest()
javax.xml.parsers.DocumentBuilderbuilder=
javax.xml.parsers.DocumentBuilderFactory.newInstance().newDocumentBuilder();
org.w3c.dom.Documentdoc=builder.newDocument();
org.w3c.dom.Elementroot=doc.createElement(老师);
org.w3c.dom.Elementwang=doc.createElement(王);
org.w3c.dom.Elementliu=doc.createElement(刘);
wang.appendChild(doc.createTextNode(我是王老师));
root.appendChild(wang);
doc.appendChild(root);
javax.xml.transform.Transformertransformer=
javax.xml.transform.TransformerFactory.newInstance().newTransformer();
transformer.setOutputProperty(javax.xml.transform.OutputKeys.ENCODING,gb2312);
transformer.setOutputProperty(javax.xml.transform.OutputKeys.INDENT,yes);
transformer.transform(newjavax.xml.transform.dom.DOMSource(doc),
new
javax.xml.transform.stream.StreamResult(outFile));
System.out.println(e.getMessage());
4、编程用JAVA解析XML的方式.
用SAX方式解析XML,XML文件如下:
?
xmlversion=1.0encoding=gb2312?
person>
name>
王小明<
/name>
college>
信息学院<
/college>
telephone>
6258113<
/telephone>
notes>
男,1955年生,博士,95年调入海南大学<
/notes>
/person>
事件回调类SAXHandler.java
importjava.util.Hashtable;
importorg.xml.sax.*;
publicclassSAXHandlerextendsHandlerBase
privateHashtabletable=newHashtable();
privateStringcurrentElement=null;
privateStringcurrentValue=null;
publicvoidsetTable(Hashtabletable)
this.table=table;
publicHashtablegetTable()
returntable;
publicvoidstartElement(Stringtag,AttributeListattrs)
throwsSAXException
currentElement=tag;
publicvoidcharacters(char[]ch,intstart,intlength)
currentValue=newString(ch,start,length);
publicvoidendElement(Stringname)throwsSAXException
if(currentElement.equals(name))
table.put(currentElement,currentValue);
JSP内容显示源码,SaxXml.jsp:
HTML>
HEAD>
TITLE>
剖析XML文件people.xml<
/TITLE>
/HEAD>
BODY>
%@pageerrorPage=ErrPage.jsp
contentType=text/html;
charset=GB2312%>
%@pageimport=java.io.*%>
%@pageimport=java.util.Hashtable%>
%@pageimport=org.w3c.dom.*%>
%@pageimport=org.xml.sax.*%>
%@pageimport=javax.xml.parsers.SAXParserFactory%>
%@pageimport=javax.xml.parsers.SAXParser%>
%@pageimport=SAXHandler%>
Filefile=newFile(c:
\people.xml);
FileReaderreader=newFileReader(file);
Parserparser;
SAXParserFactoryspf=SAXParserFactory.newInstance();
SAXParsersp=spf.newSAXParser();
SAXHandlerhandler=newSAXHandler();
sp.parse(newInputSource(reader),handler);
HashtablehashTable=handler.getTable();
out.println(<
TABLEBORDER=2>
CAPTION>
教师信息表<
/CAPTION>
);
TR>
TD>
姓名<
/TD>
+<
+
(String)hashTable.get(newString(name))+<
/TR>
学院<
(String)hashTable.get(newString(college))+<
电话<
(String)hashTable.get(newString(telephone))+<
备注<
(String)hashTable.get(newString(notes))+<
/TABLE>
/BODY>
/HTML>
EJB方面
1、EJB2.0有哪些内容?
分别用在什么场合?
EJB2.0和EJB1.1的区别?
规范内容包括Bean提供者,应用程序装配者,EJB容器,EJB配置工具,EJB服务提供者,系统管理员。
这里面,EJB容器是EJB之所以能够运行的核心。
EJB容器管理着EJB的创建,撤消,激活,去活,与数据库的连接等等重要的核心工作。
JSP,Servlet,EJB,JNDI,JDBC,JMS.....
2、EJB与JAVABEAN的区别?
JavaBean是可复用的组件,对JavaBean并没有严格的规范,理论上讲,任何一个Java类都可以是一个Bean。
但通常情况下,由于Java
Bean是被容器所创建(如Tomcat)的,所以JavaBean应具有一个无参的构造器,另外,通常JavaBean还要实现Serializable接口用于实现Bean的持久性。
JavaBean实际上相当于微软COM模型中的本地进程内COM组件,它是不能被跨进程访问的。
EnterpriseJavaBean相当于DCOM,即分布式组件。
它是基于Java的远程方法调用(RMI)技术的,所以EJB可以被远程访问(跨进程、跨计算机)。
但EJB必须被布署在诸如Webspere、WebLogic这样的容器中,EJB客户从不直接访问真正的EJB组件,而是通过其容器访问。
EJB容器是EJB组件的代理,EJB组件由容器所创建和管理。
客户通过容器来访问真正的EJB组件。
3、EJB的基本架构
一个EJB包括三个部分:
RemoteInterface接口的代码
packageBeans;
importjavax.ejb.EJBObject;
importjava.rmi.RemoteException;
publicinterfaceAddextendsEJBObject
//somemethoddeclare
HomeInterface接口的代码
importjaax.ejb.CreateException;
importjavax.ejb.EJBHome;
publicinterfaceAddHomeextendsEJBHome
EJB类的代码
importjavax.ejb.SessionBean;
importjavx.ejb.SessionContext;
publicclassAddBeanImplementsSessionBean
J2EE,MVC方面
1、MVC的各个部分都有那些技术来实现?
如何实现?
MVC是Model-View-Controller的简写。
Model代表的是应用的业务逻辑(通过JavaBean,EJB组件实现),View是应用的表示面(由JSP页面产生),Controller是提供应用的处理过程控制(一般是一个Servlet),通过这种设计模型把应用逻辑,处理过程和显示逻辑分成不同的组件实现。
这些组件可以进行交互和重用。
2、应用服务器与WEBSERVER的区别?
3、J2EE
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- j2ee 面试 知识 JAVA
![提示](https://static.bdocx.com/images/bang_tan.gif)