1、JSP中的<% %>和<%= %>有什么区别?
<% %>称为脚本段,可以包含任何符合语法的Java代码,可以同时包含多行代码。
而<%=%>称为输出脚本,=号后面是一个表达式,表达式后面不使用分号结束,表达式的值将被输出到浏览器中,每个<%= %>只能包含一个表达式。
2、JSP中都可以包含哪些元素?
静态内容(html和数据)
脚本元素(指令(<%@ %>include taglib page) 脚本段<% %> 声明<%! %> jsp表达式<%= %> 注释)
动作元素(jsp:forward jsp:include jsp:useBean)
EL表达式
3 java共享作用域
1、page当前页内有效
2、request一次请求和响应有效
3、session 会话范围内有效
4、application在整个应用范围内有效,从服务启动到服务停止都有效
有共同的方法 setAttribute getAttribute removeAttribute
3、HttpServletRequest对象的getAttribute方法和getParameter方法有什么区别?
getAttribute方法用来获取请求作用域中的数据。
getParameter方法用来获取请求报文中的参数信息。
4、请描述HttpServletResponse对象的作用?列出两个常用方法和说明?
HttpServletResponse对象由服务器创建,映射Http响应报文的内容。
作用:
向客户端输出响应信息;
设置响实现请求重定向;
设置报文实体部分的编码方式。
主要方法:
setContentType(String type):设置响应信息的内容类型。
setCharacterEncoding(String encode):设置响应报文实体部分的编码方式。
sendRedirect(String url):实现请求重定向。
response.addcookie(Cookie c)
5、HTTP是一种无状态的连接协议,web应用中,是采用什么手段,知道两次请求是同一个用户发出的?
可以使用cookie保存jsessionid。如果客户端禁用cookie,可以使用URL重写技术,在URL中携带jsessionID。
6、至少列举JSP中六种常用的内置对象,并说明该对象的作用。
1)request对象:客户端的请求信息被封装在request对象中,通过它才能了解到客户的需求。
2)response对象:response对象包含了响应客户请求的有关信息。
3)session对象:session对象指的是客户端与服务器的一次会话,从客户连到服务器的一个WebApplication开始,直到客户端与服务器断开连接为止。
4)out对象:out对象是JspWriter类的实例,是向客户端输出内容.
5)page对象:page对象就是指向当前JSP页面本身.
6)application对象:application对象实现了用户间数据的共享,可存放全局变量。
7)exception对象:exception对象是一个异常对象。
8)pageContext对象:pageContext对象提供了对JSP页面内其他八大对象的访问。
9)config对象:Servlet初始化时所要用到的参数
7、在服务器端如何设置可以使Cookie信息保存在客户端浏览器的缓存中,什么情况下保存在客户端的硬盘上?
在服务器端调用Cookie对象的setMaxAge(int time)方法,
当参数>0时,cookie会被保存在客户端的硬盘上,
当取值<0时,cookie会被保存在浏览器的临时内存中,默认保存在浏览器临时内存。
=0 时删除
8、什么是XML?
XML 是可扩展标记语言,其中所有的东西都要被正确的标记,以产生形式良好的文档。
9、转发重定向异同
相点:都能实现资源跳转
不同点:
请求发送次数上:转发一次 重定向两次
地址栏变化上: 转发地址栏不变化 重定向地址栏会变化为重定向的地址
请求范围: 转发只能是站内 重定向可以跳转到外部站点
性能上: 转发优于重定向。
10、get/post区别
请求数据长度:get为2048k post没有大小限制
编码类型: get:application/x-www-form-urlencoded
post:application/x-www-form-urlencoded 或 multipart/form-data。为二进制数据使用多重编码。
安全性:与 POST相比,GET 的安全性较差,因为所发送的数据是 URL 的一部分。在发送密码或其他敏感信息时绝不要 使用 GET !
POST 比 GET 更安全,因为参数不会被保存在浏览器历史或 web 服务器日志中。
可见性:get数据在 URL 中对所有人都是可见的。post数据不会显示在 URL 中。
11、session/cookie区别
1、cookie数据存放在客户端,session数据放在服务器上。
2、cookie不是很安全,别人可以分析存放在本地的cookie并进行cookie欺骗,考虑到安全应当使用session。
3、session会在一定时间内保存在服务器上。当访问增多,会比较占用你服务器的性能,考虑到减轻服务器性能方面,应当使用cookie。
4、单个cookie保存的数据不能超过4K,很多浏览器都限制一个站点最多保存20个cookie。
5、可以考虑将登陆信息等重要信息存放为session,其他信息如果需要保留,可以放在cookie中。
12、简述servlet生命周期
init()初始化方法
service()服务方法 :该方法会根据请求method为get/post把请求分发到 doGet()处理get请求/doPost()方法处理post请求
destroy()销毁方法
13、简述sesison生命周期
Session存储在服务器端,一般放置在服务器的内存中,session在用户第一次访问动态资源时创建.
session何时失效:超过设置的session超时时间,或者用户关闭浏览器,或者调用销毁invalidate()方法时标记session失效。
13、include 和<jsp:include>行为直接的区别
<jsp:include> :动态包含 先编译后包含
<%@ include>:静态包含 代码先整合到一起,然后翻译和编译
14、描述jsp的三种指令
page指令:对jsp页面属性进行设置
include指令:静态包含其他页面
tablib指令:引用jsp自定义标签库
问答题
<servlet></servlet>
<servlet-mapping></servlet-mapping>
<servlet>
<servlet-name>TestServlet</servlet-name>
<servlet-class>com.neuedu.javaweb.chap02.TestServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>TestServlet</servlet-name>
<url-pattern>/test.do</url-pattern>
</servlet-mapping>
<filter></filter>
<filter-mapping></filter-mapping>
<filter>
<filter-name>MyFilter</filter-name>
<filter-class>com.neuedu.utils.MyFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>MyFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
1、编写编码过滤器程序
2、servlet如何编写()
3、会编写简单jsp+servlet程序。比如用户注册
注册页面
jsp
servlet
web.xml
<servlet>
<servlet-name>TestServlet</servlet-name>
<servlet-class>com.neuedu.javaweb.chap02.TestServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>TestServlet</servlet-name>
<url-pattern>/test.do</url-pattern>
</servlet-mapping>
1、简述JSP的执行过程,jsp执行速度会比servlet 慢吗
1.客户端发出Request请求
2.如果是第一次访问,Tomcat将JSP翻译成Servlet的源代码,再编译成*.class,并加载到内存执行 ;不是第一次访问,直接把编译后的Servlet加载到内存执行
3.把结果Response(响应)至客户端
jsp第一次执行时会比servlet慢。本质上jsp是servlet
2、 [ 问答题 ]
javaweb应用程序的目录结构
答案:
– 网站根目录
– |-- WEB-INF目录:必须目录
– |-- web.xml:Web应用部署描述文件,必须文件
– |-- classes目录:存放字节码文件
– |-- lib目录:存放第三方类库文件
3、 [ 问答题 ]
对session的理解
答案: HttpSession是由JavaWeb提供的,用来会话跟踪的类。
session是服务器端对象,保存在服务器端
session是一个用户对服务器的多次连贯性请求
范围是某个用户从首次访问服务器开始,到该用户关闭浏览器结束
作用是多次请求中共享数据
3、**ajax执行过程(5步)
第一步,创建XMLHttpRequest对象
第二步,注册回调函数
第三步,配置请求信息,open()
第四步,发送请求 send
第五步,创建回调函数
4、 [ 问答题 ]
AJAX都有哪些优点和缺点
答案: 优点:
(1)页面局部刷新,提高用户体验度;
(2)使用异步方式与服务器通信,具有更加迅速的响应能力;
(3)减轻服务器负担;
(4)基于标准化的并被广泛支持的技术,不需要下载插件或者小程序
缺点:
(1)不支持浏览器 back按钮;
(2)安全问题;
3、page/request/session/application作用域区别
答案:
page:当前页面范围
request:当前页面范围+转发页面(forward)+包含页面(include)
session:当前会话:session在以下几种情况下失效
1) 销毁session:Session.invalidate();
2) 超过最大非活动间隔时间
3) 手动关闭浏览器(session并没有立刻失效,因为服务器端session
仍旧存在,超过最大非活动间隔时间后真正失效)
application:当前应用;服务器重新启动前一直有效
4、 转发和重定向的区别
a) 区别1:跳转效率的不同
转发效率相对高;重定向效率相对低
b) 区别2:实现语句不同
转发
request.getRequestDispatcher("xxxx").forward(request,response);
重定向 response.sendRedirect("xxxx")
c) 区别3:是否共有同一个request的数据
转发源组件与目标组件共有同一个request数据
重定向源组件与目标组件不共有同一个request数据(可使用session共
有数据)
d) 区别4:浏览器URL地址的不同
转发后浏览器URL地址保持不变(源组件地址)
重定向后浏览器URL地址改变为重定向后的地址(目标组件地址)
e) 区别5:"/"路径的含义不同
转发时"/"代表当前项目的根路径 ;重定向时"/"代表当前服务器的根
路径
f) 区别6:跳转范围的不同
只能转发到同一应用中的URL(默认) ;可以重定向任何服务器、任何
应用的URL
5、什么是cookie? cookie有什么作用?
答案: Cookie是一小段文本信息,伴随着用户请求和页面在Web服务器
和浏览器之间传递。用户每次访问站点时,Web应用程序都可以读取
Cookie包含的信息。
6、**在页面中添加文件上传输入项,form都需要注意哪些问题?
答案:
1、表单的提交方式必须是post
2、表单的enctype必须是multipart/form-data
3、表单项必须有name属性
7、为什么第一次运行JSP时会很慢
答案: 因为第一次访问JSP文件的时候,需要把JSP文件转换成Servlet并编译成字节码文件