• 沒有找到結果。

Java web 部分

在文檔中 3、说说&和&&的区别。 (頁 107-142)

var value =eleText.value;

var len =value.length;

for(vari=0;i<len;i++) {

if(value.charAt(i)>"9"|| value.charAt(i)<"0") {

alert("含有非数字字符");

eleText.focus();

break;

} }

}

</script>

除了写完代码,还应该在网页上写出实验步骤和在代码中加入实现思路,让面试官一看就明 白你的意图和检查你的结果。

5、说说你用过那些 ajax 技术和框架,说说它们的区别

四. Java web 部分

1、Tomcat 的优化经验

答:去掉对 web.xml 的监视,把 jsp 提前编辑成 Servlet。

有富余物理内存的情况,加大 tomcat 使用的 jvm 的内存

2、HTTP 请求的 GET 与 POST 方式的区别

答:servlet 有良好的生存期的定义,包括加载和实例化、初始化、处理请求以及服务结束。

这个生存期由 javax.servlet.Servlet 接口的 init,service 和 destroy 方法表达。

108 / 166

3、解释一下什么是 servlet;

答:servlet 有良好的生存期的定义,包括加载和实例化、初始化、处理请求以及服务结束。

这个生存期由 javax.servlet.Servlet 接口的 init,service 和 destroy 方法表达。

4、说一说 Servlet 的生命周期?

答:servlet 有良好的生存期的定义,包括加载和实例化、初始化、处理请求以及服务结束。

这个生存期由 javax.servlet.Servlet 接口的 init,service 和 destroy 方法表达。

Servlet 被服务器实例化后,容器运行其 init 方法,请求到达时运行其 service 方法,service 方法自动派遣运行与请求对应的 doXXX 方法(doGet,doPost)等,当服务器决定将实例 销毁的时候调用其 destroy 方法。

web 容器加载 servlet,生命周期开始。通过调用 servlet 的 init()方法进行 servlet 的初始化。

通过调用 service()方法实现,根据请求的不同调用不同的 do***()方法。结束服务,web 容 器调用 servlet 的 destroy()方法。

5、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 {

} }

6、SERVLET API 中 forward()与 redirect()的区别?

答:前者仅是容器中控制权的转向,在客户端浏览器地址栏中不会显示出转向后的地址;后 者则是完全的跳转,浏览器将会得到跳转的地址,并重新发送请求链接。这样,从浏览器的 地址栏中可以看到跳转后的链接地址。所以,前者更加高效,在前者可以满足需要时,尽量 使用 forward()方法,并且,这样也有助于隐藏实际的链接。在有些情况下,比如,需要跳 转到一个其它服务器上的资源,则必须使用

sendRedirect()方法。

7、什么情况下调用 doGet()和 doPost()?

109 / 166

Jsp 页面中的 FORM 标签里的 method 属性为 get 时调用 doGet(),为 post 时调用 doPost()。

8、Request 对象的主要方法:

setAttribute(String name,Object):设置名字为 name 的 request 的参数值 getAttribute(String name):返回由 name 指定的属性值

getAttributeNames():返回 request 对象所有属性的名字集合,结果是一个枚举的实例 getCookies():返回客户端的所有 Cookie 对象,结果是一个 Cookie 数组

getCharacterEncoding():返回请求中的字符编码方式 getContentLength():返回请求的 Body 的长度

getHeader(String name):获得 HTTP 协议定义的文件头信息

getHeaders(String name):返回指定名字的 request Header 的所有值,结果是一个枚举的 实例

getHeaderNames():返回所以 request Header 的名字,结果是一个枚举的实例 getInputStream():返回请求的输入流,用于获得请求中的数据

getMethod():获得客户端向服务器端传送数据的方法

getParameter(String name):获得客户端传送给服务器端的有 name 指定的参数值

getParameterNames():获得客户端传送给服务器端的所有参数的名字,结果是一个枚举的 实例

getParametervalues(String name):获得有 name 指定的参数的所有值 getProtocol():获取客户端向服务器端传送数据所依据的协议名称 getQueryString():获得查询字符串

getRequestURI():获取发出请求字符串的客户端地址 getRemoteAddr():获取客户端的 IP 地址

getRemoteHost():获取客户端的名字

getSession([Boolean create]):返回和请求相关 Session getServerName():获取服务器的名字

getServletPath():获取客户端所请求的脚本文件的路径 getServerPort():获取服务器的端口号

removeAttribute(String name):删除请求中的一个属性

110 / 166

9、forward 和 redirect 的区别

forward 是服务器请求资源,服务器直接访问目标地址的 URL,把那个 URL 的响应内容读 取过来,然后把这些内容再发给浏览器,浏览器根本不知道服务器发送的内容是从哪儿来的,

所以它的地址栏中还是原来的地址。

redirect就是服务端根据逻辑,发送一个状态码,告诉浏览器重新去请求那个地址,一般来 说浏览器会用刚才请求的所有参数重新请求,所以 session,request 参数都可以获取。

10、request.getAttribute()和 request.getParameter()有何区别?

11. jsp 有哪些内置对象?作用分别是什么?分别有什么方法?

答:JSP 共有以下9个内置的对象:

request 用户端请求,此请求会包含来自 GET/POST 请求的参数 response 网页传回用户端的回应

pageContext 网页的属性是在这里管理 session 与请求有关的会话期

application servlet 正在执行的内容 out 用来传送回应的输出

config servlet的构架部件 page JSP 网页本身

exception 针对错误网页,未捕捉的例外

request 表示 HttpServletRequest 对象。它包含了有关浏览器请求的信息,并且提供了几个 用于获取 cookie, header,和 session 数据的有用的方法。

response表示 HttpServletResponse 对象,并提供了几个用于设置送回浏览器的响应的 方法(如 cookies,头信息等)

out对象是 javax.jsp.JspWriter 的一个实例,并提供了几个方法使你能用于向浏览器回送 输出结果。

pageContext表示一个 javax.servlet.jsp.PageContext 对象。它是用于方便存取各种范 围的名字空间、servlet 相关的对象的 API,并且包装了通用的 servlet 相关功能的方法。

session表示一个请求的 javax.servlet.http.HttpSession 对象。Session 可以存贮用户的 状态信息

applicaton 表示一个 javax.servle.ServletContext 对象。这有助于查找有关 servlet 引擎 和 servlet 环境的信息

111 / 166

config表示一个 javax.servlet.ServletConfig 对象。该对象用于存取 servlet 实例的初始 化参数。

page表示从该页面产生的一个 servlet 实例

12. jsp 有哪些动作?作用分别是什么?

(这个问题似乎不重要,不明白为何有此题)

答:JSP 共有以下6种基本动作

jsp:include:在页面被请求的时候引入一个文件。

jsp:useBean:寻找或者实例化一个 JavaBean。

jsp:setProperty:设置 JavaBean 的属性。

jsp:getProperty:输出某个 JavaBean 的属性。

jsp:forward:把请求转到一个新的页面。

jsp:plugin:根据浏览器类型为 Java 插件生成 OBJECT 或 EMBED 标记

13、JSP 的常用指令

isErrorPage(是否能使用 Exception 对象),isELIgnored(是否忽略表达式)

14. JSP 中动态 INCLUDE 与静态 INCLUDE 的区别?

答:动态 INCLUDE 用 jsp:include 动作实现

<jsp:include page=included.jsp flush=true />它总是会检查所含文件中的变化,适合用于包 含动态页面,并且可以带参数 静态 INCLUDE 用 include 伪码实现,定不会检查所含文件的 变化,适用于包含静态页面 <%@include file=included.htm %>

15、两种跳转方式分别是什么?有什么区别?

(下面的回答严重错误,应该是想问 forward 和 sendRedirect 的区别,毕竟出题的人不是 专业搞文字艺术的人,可能表达能力并不见得很强,用词不一定精准,加之其自身的技术面 也可能存在一些问题,不一定真正将他的意思表达清楚了,严格意思上来讲,一些题目可能 根本就无人能答,所以,答题时要掌握主动,只要把自己知道的表达清楚就够了,而不要去 推敲原始题目的具体含义是什么,不要一味想着是在答题)

答:有两种,分别为:

<jsp:include page=included.jsp flush=true>

<jsp:forward page= nextpage.jsp/>

112 / 166

前者页面不会转向 include 所指的页面,只是显示该页的结果,主页面还是原来的页面。执 行完后还会回来,相当于函数调用。并且可以带参数.后者完全转向新页面,不会再回来。

相当于 go to 语句。

16、页面间对象传递的方法

request,session,application,cookie 等

17、JSP 和 Servlet 有哪些相同点和不同点,他们之间的联系是什么?

JSP 是 Servlet 技术的扩展,本质上是 Servlet 的简易方式,更强调应用的外表表达。JSP 编译后是"类 servlet"。Servlet 和 JSP 最主要的不同点在于,Servlet 的应用逻辑是在 Java 文件中,并且完全从表示层中的 HTML 里分离开来。而 JSP 的情况是 Java 和 HTML 可以 组合成一个扩展名为.jsp 的文件。JSP 侧重于视图,Servlet 主要用于控制逻辑。

18、MVC 的各个部分都有那些技术来实现?如何实现?

答:MVC 是 Model-View-Controller 的简写。Model 代表的是应用的业务逻辑(通过 JavaBean,EJB 组件实现),View 是应用的表示面(由 JSP 页面产生),Controller 是提供 应用的处理过程控制(一般是一个 Servlet),通过这种设计模型把应用逻辑,处理过程和显 示逻辑分成不同的组件实现。这些组件可以进行交互和重用。

19、我们在 web 应用开发过程中经常遇到输出某种编码的字符,如 iso8859-1 等,如何输出一个某种编码的字符串?

Public String translate(String str) { String tempStr ="";

try {

tempStr = newString(str.getBytes("ISO-8859-1"), "GBK");

tempStr =tempStr.trim();

}

catch (Exception e) {

System.err.println(e.getMessage());

}

return tempStr;

}

113 / 166

20.现在输入 n 个数字,以逗号,分开;然后可选择升或者降序排序;按提交 键就在另一页面显示按什么排序,结果为,提供 reset

五.数据库部分

1、用两种方式根据部门号从高到低,工资从低到高列出每个员工的信息。

employee:

eid,ename,salary,deptid;

select * from employeeorder by deptid desc,salary

2、列出各个部门中工资高于本部门的平均工资的员工数和部门号,并按部门号 排序

创建表:

mysql> createtable employee921(id int primary key auto_increment,name varchar(5

0),salary bigint,deptid int);

插入实验数据:

mysql> insert into employee921values(null,'zs',1000,1),(null,'ls',1100,1),(null ,'ww',1100,1),(null,'zl',900,1) ,(null,'zl',1000,2), (null,'zl',900,2),(null,'z

l',1000,2) , (null,'zl',1100,2);

编写 sql 语句:

()select avg(salary) from employee921 group by deptid;

()mysql>

selectemployee921.id,employee921.name,employee921.salary,employee921.dep tid tid from employee921where salary > (select avg(salary) from employee921 where deptid = tid);

114 / 166

效率低的一个语句,仅供学习参考使用(在 group by 之后不能使用 where,只能使用 having,在 group by 之前可以使用 where,即表示对过滤后的结果分组):

mysql>

selectemployee921.id,employee921.name,employee921.salary,employee921.dep

tid tid from employee921where salary > (select avg(salary) from employee921 group by deptid havingdeptid = tid);

()select count(*) ,tid from (

selectemployee921.id,employee921.name,employee921.salary,employee921.deptid tid from employee921

where salary>

(selectavg(salary) from employee921 where deptid = tid) ) as t

group by tid ;

另外一种方式:关联查询

select a.ename,a.salary,a.deptid from emp a,

(selectdeptd,avg(salary) avgsal from emp group by deptid ) b where a.deptid=b.deptidand a.salary>b.avgsal;

3、存储过程与触发器必须讲,经常被面试到?

create procedure insert_Student (_name varchar(50),_age int ,out_id int) begin

insert into studentvalue(null,_name,_age);

select max(stuId)into _id from student;

end;

call insert_Student('wfz',23,@id);

select @id;

115 / 166

mysql> create trigger update_Student BEFORE update on studentFOR EACH ROW -> select * from student;

触发器不允许返回结果

create trigger update_StudentBEFORE update on student FOR EACH ROW insert into student value(null,'zxx',28);

mysql 的触发器目前不能对当前表进行操作

create trigger update_StudentBEFORE update on student FOR EACH ROW delete from articles where id=8;

这个例子不是很好,最好是用删除一个用户时,顺带删除该用户的所有帖子 这里要注意使用 OLD.id

触发器用处还是很多的,比如校内网、开心网、Facebook,你发一个日志,自动通知好友,

其实就是在增加日志时做一个后触发,再向通知表中写入条目。因为触发器效率高。而 UCH 没有用触发器,效率和数据处理能力都很低。

存储过程的实验步骤:

mysql> delimiter |

mysql> create procedure insertArticle_Procedure (pTitle varchar(50),pBid int,out pId int)

-> begin

-> insert into article1value(null,pTitle,pBid);

-> select max(id) into pId fromarticle1;

-> end;

-> |

Query OK, 0 rows affected (0.05sec)

mysql> callinsertArticle_Procedure('传智播客',1,@pid);

-> |

Query OK, 0 rows affected (0.00sec)

116 / 166 mysql> delimiter ;

mysql> select @pid;

+---+

| @pid | +---+

| 3 | +---+

1 row in set (0.00 sec)

mysql> select * fromarticle1;

+----+---+---+

| id | title | bid | +----+---+---+

| 1 | test | 1 |

| 2 | chuanzhiboke | 1 |

| 3 | 传智播客 | 1 | +----+---+---+

3 rows in set (0.00 sec)

触发器的实验步骤:

create table board1(id intprimary key auto_increment,name varchar(50),ar ticleCount int);

create table article1(id intprimary key auto_increment,title varchar(50) ,bid int referencesboard1(id));

delimiter |

create triggerinsertArticle_Trigger after insert on article1 for each ro w begin

-> update board1 setarticleCount=articleCount+1 where id= NEW.bid;

117 / 166 -> end;

-> |

delimiter ;

insert into board1 value(null,'test',0);

insert into article1value(null,'test',1);

还有,每插入一个帖子,都希望将版面表中的最后发帖时间,帖子总数字段进行同步更新,

用触发器做效率就很高。下次课设计这样一个案例,写触发器时,对于最后发帖时间可能需 要用 declare 方式声明一个变量,或者是用 NEW.posttime 来生成。

4、数据库三范式是什么?

第一范式(1NF):字段具有原子性,不可再分。所有关系型数据库系统都满足第一范式)

数据库表中的字段都是单一属性的,不可再分。例如,姓名字段,其中的姓和名必 须作为一个整体,无法区分哪部分是姓,哪部分是名,如果要区分出姓和名,必须设计成两 个独立的字段。

第二范式(2NF):

第二范式(2NF)是在第一范式(1NF)的基础上建立起来的,即满足第二范式(2NF)必 须先满足第一范式(1NF)。

要求数据库表中的每个实例或行必须可以被惟一地区分。通常需要为表加上一个列,以存储

要求数据库表中的每个实例或行必须可以被惟一地区分。通常需要为表加上一个列,以存储

在文檔中 3、说说&和&&的区别。 (頁 107-142)

相關文件