web最后一天:完了。
Servlet3.0
一、要求
1.MyEclipse10.0或以上版本
2.发布到Tomcat7.0或以上版本
二、步骤
1.创建JavaEE6.0应用
三、概述
*注解代替web.xml配置文件
*异步处理
*对上传的支持
四、注解代替配置文件
1.删除web.xml
2.在Serlvet类上添加@WebServlet(urlPatterns={"/AServlet"})
总结:
*注解好处:配置信息少
*注解缺点:不方便修改
3.在Filter类上添加@WebFilter(urlPattern="/AFilter")
4.在Listener类上添加@WebListener
五、异步处理
1.什么是异步处理
在服务器没有结束响应之前,浏览器是看不到响应内容,只有响应结束时,浏览器才能显示结果,
现在异步处理的作用:在服务器开始响应后,浏览器就可以看到响应内容,不用等待服务器响应结束
2.实现异步的步骤
*得到AsyncContext,它异步上下文对象
AsyncContext ac = request.startAsync(request, response);
*给上下文一个Runnable对象,启动它。(给上下文一个任务,让它完成)
ac.start(new Runnable() {
public void run() {
...
}
});
*@WebServlet(urlPatterns="/AServlet", asyncSupporte=true)
*response.setContentType("text/html;charset=utf-8");
*IE如果不能正常输出,这说明响应体大小不足512B,那么你需要多输出点内容。
*AsyncContext#complete():通知Tomcat我们异步线程已经执行结束了。这让Tomcat才会及时的断开与浏览器的连接。
六、上传支持
1.上传
*上传对表单的要求:
>method="post"
>enctype="multipart/form-data",它的默认值是:application/x-www-form-urlencoded
>
*上传Servlet的使用:
>requset.getParameter()不能再用
>requset.getInputStream()使用它来获取整个表单的数据
*commons-fileUpload
>创建工厂
>解析器
>使用解析器来解析request对象,得到List
=========================
Servlet3.0对上传提供了支持
*表单不变
*在Servlet中不需要再使用commons-fileUpload,而是使用Servlet3.0提供的上传组件接口
========================
上传的步骤:
*使用request.getPart("字段名"),得到Part实例
*Part:
>String getContentType():获取上传文件的MIME类型
>String getName():获取表单项的名称,不是文件名称
>String getHeader(String header):获取指定头的值
>long getSize():获取上传文件的大小
>InputStream getInputStream():获取上传文件的内容
>void write(String fileName):把上传文件保存到指定路径下
*默认Servlet是不支持使用上传组件:需要给Servlet添加一个注释:@MultipartConfig
它没有提供获取上传文件名称的方法:
*这需要我们自己从Content-Disposition头中截取。
动态代理:
1.只学一个方法:
方法的作用:在运行时,动态创建一组指定的接口的实现类对象(在运行时,创建实现了指定的一组接口的对象)
interface A {
}
interface B {
}
Objcet obejct = 方法(new Class[]{A.class, B.class})
object 它实现了A和B两个接口
Objcet proxyObject = Proxy.newProxyInstance(ClassLoader classLoader, Class[]interfaces, InvocationHandler h);
1.方法作用:动态创建实现了interfaces数组中所有指定接口的实现类对象
参数:
1.ClassLoader:类加载器
*它是用来加载器的,把.Class文件加载到内存,形成Class对象
2.Class[] interfaces:指定要实现的接口们
3.InvocationHandler:代理对象的所有方法(个别不执行,getClass())都会调用InvocationHandler的invoke()方法。
---------------------------------------------------
2.动态代理作用
最终是学习AOP(面向切面编程),它与装饰者模式有点相似,它比装饰者模式还要灵活
-------------------------------------------------
InvocationHandler
public Object invoke(Objcet proxy, Method method, Object[] args);
这个invoke()方法在什么时候调用
1.在代理对象被创建就时?错误
2.在调用代理对象所实现接口中的方法时?正确
*Object proxy:当前对象,即代理对象。在调用谁的方法
*Method method:当前被调用的方法(目标方法)
*Object[] args:实参
--------------------------------------------------
目标对象:被增强的对象
代理对象:需要目标对象,然后在目标对象上添加了增强后的对象
目标方法:增强的内容
代理对象 = 目标对象 + 增强
类加载器
1.什么是类加载器
*把.class文件加载到JVM的方法区中,变成一个Class对象
2.得到类加载器
*Class#getClassLoader()
3.类加载器的分类
*引导:类库
*扩展:扩展jar包
*系统:应用下的class,包含开发人员写的类,和第三方的jar包,classpath下的类
系统类=加载器的上层领导:扩展
扩展类加载器的上层领导:引导
引导没上层,它是BOSS
4.类加载器的委托机制
*代码中出现了这么一行:new A();
>系统发现了自己加载的类,其中包含了new A(),这说明系统去加载A类
>系统会给自己的领导通知:让扩展去自己的所属加载A类
>扩展会给自己的领导通知:让引导去自己的地盘加载A类
>引导自己真的去rt.jar
中寻找A类
*如果找到了,那么加载,然后返回A对应的Class对象给扩展,扩展也会它这个Class返回给系统,结束了。
*如果没找到:
>引导给扩展返回一个null,扩展会去自己的所属,去寻找A类
*如果找到了,那么加载之,然后返回A的对应的Class对象给系统,结束了
*如果没找到
>扩展返回一个null给系统了,系统去自己的地盘(应用程序下)加载A类
*如果找到了,那么加载之,然后返回这个Calss,结束了
*如果没找到,抛出异常ClassNotFoundException
5.类的解析过程
class MyApp{//被系统加载
main(){
A a = new A();//也由系统加载
String s = new String();//也由系统加载
}
}
class String {//引导
private Integer i;//直接引导加载
}
=========================================
6.自定义类加载器
*继承ClassLoader
*重写findClass()
========================================
7.Tomcat的类加载器
Tomcat提供了两种类加载器
*服务器类加载器:${CATALINA_HOME}\lib,服务器类加载器,它负责加载这个下面的类
*应用类加载器:${CONTEXT_HOME}\WEB-INF\lib、${CONTEXT_HOME}\WEB-INF\classes、应用类加载器它负责加载这两个路径下的类
引导
扩展
系统
特性:
服务器类加载器:先自己动手,然后再去委托
应用类加载器:先自己动手,然后再去委托