springMVC教程-学习文档-doc

上传人:无*** 文档编号:162876770 上传时间:2022-10-20 格式:DOC 页数:42 大小:559KB
收藏 版权申诉 举报 下载
springMVC教程-学习文档-doc_第1页
第1页 / 共42页
springMVC教程-学习文档-doc_第2页
第2页 / 共42页
springMVC教程-学习文档-doc_第3页
第3页 / 共42页
资源描述:

《springMVC教程-学习文档-doc》由会员分享,可在线阅读,更多相关《springMVC教程-学习文档-doc(42页珍藏版)》请在装配图网上搜索。

1、Spring MVC 教程,快速入门,深入分析 博客分类: SPRINGSpring MVC 教程快速入门资源下载:Spring_MVC_教程_快速入门_深入分析V1.1.pdf SpringMVC核心配置文件示例.rar 作者:赵磊博客:目录 一、前言二、spring mvc 核心类与接口三、spring mvc核心流程图四、spring mvcDispatcherServlet说明五、spring mvc 父子上下文的说明六、springMVC-mvc.xml 配置文件片段讲解 七、spring mvc如何访问到静态的文件,如jpg,js,css八、spring mvc请求如何映射到具体的

2、Action中的方法九、 spring mvc中的拦截器:十、 spring mvc如何使用拦截器十一、 spring mvc如何实现全局的异常处理十二、 spring mvc如何把全局异常记录到日志中十三、 如何给spring3 MVC中的Action做JUnit单元测试 十四、 spring mvc转发与重定向 (带参数重定向)十五、 spring mvc处理ajax请求十六、 spring mvc关于写几个配置文件的说明十七、 spring mvc如何取得Spring管理的bean十八、 spring mvc多视图控制器十九、 到底做了什么工作 二十、 本文中springMVC.xml配

3、置文件是核心,这里给一个下载地址 说明:本作者是文章的原创作者,转载请注明出处:本文地址: 一、前言: 为开发团队选择一款优秀的MVC框架是件难事儿,在众多可行的方案中决择需要很高的经验和水平。你的一个决定会影响团队未来的几年。要考虑方面太多:1、简单易用,以提高开发效率。使小部分的精力在框架上,大部分的精力放在业务上。2、性能优秀,这是一个最能吸引眼球的话题。3、尽量使用大众的框架(避免使用小众的、私有的框架),新招聘来的开发人员有一些这方面技术积累,减低人员流动再适应的影响。如果你还在为这件事件发愁,本文最适合你了。选择Spring MVC吧。Spring MVC是当前最优秀的MVC框架,

4、自从Spring 2.5版本发布后,由于支持注解配置,易用性有了大幅度的提高。Spring 3.0更加完善,实现了对Struts 2的超越。现在越来越多的开发团队选择了Spring MVC。Struts2也是非常优秀的MVC构架,优点非常多比如良好的结构,拦截器的思想,丰富的功能。但这里想说的是缺点,Struts2由于采用了值 栈、OGNL表达式、struts2标签库等,会导致应用的性能下降,应避免使用这些功能。而Struts2的多层拦截器、多实例action性能都很 好。可以参考我写的一篇关于Spring MVC与Struts2与Servlet比较的文章Struts2、SpringMVC、S

5、ervlet(Jsp)性能对比 测试 Spring3 MVC的优点:1、Spring3 MVC使用简单,学习成本低。学习难度小于Struts2,Struts2用不上的多余功能太多。呵呵,当然这不是决定因素。2、Spring3 MVC很容易就可以写出性能优秀的程序,Struts2要处处小心才可以写出性能优秀的程序(指MVC部分)3、Spring3 MVC的灵活是你无法想像的,Spring框架的扩展性有口皆碑,Spring3 MVC当然也不会落后,不会因使用了MVC框架而感到有任何的限制。Struts2的众多优点:1、老牌的知名框架,从Struts1起积累了大量用户群体。技术文档丰富。2、其它方面

6、略. (呵呵,是不是不公平?)Spring的官方下载网址是:http:/www.springsource.org/download (本文使用是的Spring 3.0.5版本)转载请注明出处:原文地址: 二、核心类与接口: 先来了解一下,几个重要的接口与类。现在不知道他们是干什么的没关系,先混个脸熟,为以后认识他们打个基础。DispatcherServlet - 前置控制器HandlerMapping接口 - 处理请求的映射HandlerMapping接口的实现类:SimpleUrlHandlerMapping 通过配置文件,把一个URL映射到ControllerDefaultAnnotati

7、onHandlerMapping 通过注解,把一个URL映射到Controller类上HandlerAdapter接口 - 处理请求的映射AnnotationMethodHandlerAdapter类,通过注解,把一个URL映射到Controller类的方法上Controller接口 - 控制器由于我们使用了Controller注解,添加了Controller注解注解的类就可以担任控制器(Action)的职责,所以我们并没有用到这个接口。HandlerInterceptor 接口-拦截器无图,我们自己实现这个接口,来完成拦截的器的工作。ViewResolver接口的实现类UrlBasedVie

8、wResolver类 通过配置文件,把一个视图名交给到一个View来处理InternalResourceViewResolver类,比上面的类,加入了JSTL的支持View接口JstlView类LocalResolver接口HandlerExceptionResolver接口 -异常处理SimpleMappingExceptionResolver实现类ModelAndView类无图。三、核心流程图 本图是我个人画的,有不严谨的地方,大家对付看吧。总比没的看强。转载请注明出处:本文地址: 四、DispatcherServlet说明 使用Spring MVC,配置DispatcherServlet

9、是第一步。DispatcherServlet是一个Servlet,所以可以配置多个DispatcherServlet。DispatcherServlet是前置控制器,配置在web.xml文件中的。拦截匹配的请求,Servlet拦截匹配规则要自已定义,把拦截下来的请求,依据某某规则分发到目标Controller(我们写的Action)来处理。“某某规则”:是根据你使用了哪个HandlerMapping接口的实现类的不同而不同。先来看第一个例子:Xml代码 1. 2. 3. example4. org.springframework.web.servlet.DispatcherServlet5.

10、16. 7. 8. example9. *.form10. 11. 1是启动顺序,让这个Servlet随Servletp容器一起启动。*.form 会拦截*.form结尾的请求。example这个Servlet的名字是 example,可以有多个DispatcherServlet,是通过名字来区分的。每一个DispatcherServlet有自己的 WebApplicationContext上下文对象。同时保存的ServletContext中和Request对象中,关于key,以后说明。在DispatcherServlet的初始化过程中,框架会在web应用的 WEB-INF文件夹下寻找名为se

11、rvlet-name-servlet.xml 的配置文件,生成文件中定义的bean。第二个例子:Xml代码 1. 2. springMVC3. org.springframework.web.servlet.DispatcherServlet4. 5. contextConfigLocation6. classpath*:/springMVC.xml7. 8. 19. 10. 11. springMVC12. /13. 指明了配置文件的文件名,不使用默认配置文件名,而使用springMVC.xml配置文件。其中*.xml 这里可以使用多种写法1、不写,使用默认值:/WEB-INF/-servl

12、et.xml2、/WEB-INF/classes/springMVC.xml3、classpath*:springMVC-mvc.xml4、多个值用逗号分隔Servlet拦截匹配规则可以自已定义,拦截哪种URL合适? 当映射为RequestMapping(/user/add)时,为例:1、拦截*.do、*.htm, 例如:/user/add.do 这是最传统的方式,最简单也最实用。不会导致静态文件(jpg,js,css)被拦截。2、拦截/,例如:/user/add可以实现现在很流行的REST风格。很多互联网类型的应用很喜欢这种风格的URL。弊端:会导致静态文件(jpg,js,css)被拦截后不

13、能正常显示。想实现REST风格,事情就是麻烦一些。后面有解决办法还算简单。3、拦截/*,这是一个错误的方式,请求可以走到Action中,但转到jsp时再次被拦截,不能访问到jsp。转载请注明出处:本文地址: 五、父子上下文(WebApplicationContext) 如果你使用了listener监听器来加载配置,一般在Struts+Spring+Hibernate的项目中都是使用listener监听器的。如下Java代码 1. 2. org.springframework.web.context.ContextLoaderListener3. Spring会创建一个WebApplicatio

14、nContext上下文,称为父上下文(父容器) ,保存在 ServletContext中,key是 WebApplicationContext.ROOT_WEB_APPLICATION_CONTEXT_ATTRIBUTE的值。可以使用Spring提供的工具类取出上下文对象:WebApplicationContextUtils.getWebApplicationContext(ServletContext);DispatcherServlet是一个Servlet,可以同时配置多个,每个 DispatcherServlet有一个自己的上下文对象(WebApplicationContext),称为子

15、上下文(子容器),子上下文可以访问 父上下文中的内容,但父上下文不能访问子上下文中的内容。 它也保存在 ServletContext中,key 是org.springframework.web.servlet.FrameworkServlet.CONTEXT+Servlet名称。当一 个Request对象产生时,会把这个子上下文对象(WebApplicationContext)保存在Request对象中,key是 DispatcherServlet.class.getName() + .CONTEXT。可以使用工具类取出上下文对象:RequestContextUtils.getWebAppli

16、cationContext(request);说明 :Spring 并没有限制我们,必须使用父子上下文。我们可以自己决定如何使用。方案一,传统型: 父上下文容器中保存数据源、服务层、DAO层、事务的Bean。子上下文容器中保存Mvc相关的Action的Bean.事务控制在服务层。由于父上下文容器不能访问子上下文容器中内容,事务的Bean在父上下文容器中,无法访问子上下文容器中内容,就无法对子上下文容器中Action进行AOP(事务)。当然,做为“传统型”方案,也没有必要这要做。方案二,激进型: Java世界的“面向接口编程”的思想是正确的,但在增删改查为主业务的系统里,Dao层接口,Dao层实

17、现类,Service层接 口,Service层实现类,Action父类,Action。再加上众多的O(vopobo)和jsp页面。写一个小功能 7、8个类就写出来了。 开发者说我就是想接点私活儿,和PHP,ASP抢抢饭碗,但我又是Java程序员。最好的结果是大项目能做好,小项目能做快。所以“激进型”方案就出现了 -没有接口、没有Service层、还可以没有众多的O(vopobo)。那没有Service层事务控制在哪一层?只好上升的Action 层。本文不想说这是不是正确的思想,我想说的是Spring不会限制你这样做。由于有了父子上下文,你将无法实现这一目标。解决方案是只使用子上下文容器,不要父

18、上下文容器 。所以数据源、服务层、DAO层、事务的Bean、Action的Bean都放在子上下文容器中。就可以实现了,事务(注解事务)就正常工作了。这样才够激进。总结:不使用listener监听器来加载spring的配置文件,只使用DispatcherServlet来加载spring的配置,不要父子上下文,只使用一个DispatcherServlet,事情就简单了,什么麻烦事儿也没有了。Java-大项目能做好-按传统方式做,规规矩矩的做,好扩展,好维护。Java-小项目能做快-按激进方式做,一周时间就可以出一个版本,先上线接受市场(用户)的反馈,再改进,再反馈,时间就是生命(成本)。转载请注明

19、出处:原文地址: 六、springMVC-mvc.xml 配置文件片段讲解 (未使用默认配置文件名) Xml代码 1. 2. 16. 17. 18. 19. 20. 21. 22. 23. 24. 25. 26. 27. 28. 29. 30. 31. 32. 33. 34. 35. 36. 37. 38. 39. 40. 41. 42. 43. 44. 扫描指定的包中的类上的注解,常用的注解有:Controller 声明Action组件Service 声明Service组件 Service(myMovieLister) Repository 声明Dao组件Component 泛指组件, 当不

20、好归类时. RequestMapping(/menu) 请求映射Resource 用于注入,( j2ee提供的 ) 默认按名称装配,Resource(name=beanName) Autowired 用于注入,(srping提供的) 默认按类型装配 Transactional( rollbackFor=Exception.class) 事务管理ResponseBodyScope(prototype) 设定bean的作用域 是一种简写形式,完全可以手动配置替代这种简写形式,简写形式可以让初学都快速应用默认配置方案。 会自动注册DefaultAnnotationHandlerMapping与Ann

21、otationMethodHandlerAdapter 两个bean,是spring MVC为Controllers分发请求所必须的。并提供了:数据绑定支持,NumberFormatannotation支持,DateTimeFormat支持,Valid支持,读写XML的支持(JAXB),读写JSON的支持(Jackson)。后面,我们处理响应ajax请求时,就使用到了对json的支持。后面,对action写JUnit单元测试时,要从spring IOC容器中取DefaultAnnotationHandlerMapping与AnnotationMethodHandlerAdapter 两个bea

22、n,来完成测试,取的时候要知道是这一句注册的这两个bean。如何替换 ?他到底做了什么工作,请看,最后面的 十九节 到底做了什么工作。 是一种简写形式。通过看前面的大图,知道,我们可以配置多个HandlerMapping。会为每一 个HandlerMapping,注入一个拦截器。其实我们也可以手动配置为每个HandlerMapping注入一个拦截器。 使用默认的Servlet来响应静态文件。 匹配URL /images/* 的URL被当做静态资源,由Spring读出到内存中再响应http。 转载请注明出处:本文地址: 七、如何访问到静态的文件,如jpg,js,css? 如何你的Dispatch

23、erServlet拦截*.do这样的有后缀的URL,就不存在访问不到静态资源的问题。如果你的DispatcherServlet拦截/,为了实现REST风格,拦截了所有的请求,那么同时对*.js,*.jpg等静态文件的访问也就被拦截了。我们要解决这个问题。 目的:可以正常访问静态文件,不可以找不到静态文件报404。 方案一:激活Tomcat的defaultServlet来处理静态文件Xml代码 1. 2. default3. *.jpg4. 5. 6. default7. *.js8. 9. 10. default11. *.css12. 13. 要配置多个,每种文件配置一个要写在Dispatc

24、herServlet的前面, 让 defaultServlet先拦截请求,这样请求就不会进入Spring了,我想性能是最好的吧。 Tomcat, Jetty, JBoss, and GlassFish 自带的默认Servlet的名字 - defaultGoogle App Engine 自带的 默认Servlet的名字 - _ah_defaultResin 自带的 默认Servlet的名字 - resin-fileWebLogic 自带的 默认Servlet的名字 - FileServletWebSphere 自带的 默认Servlet的名字 - SimpleFileServlet 方案二:

25、在spring3.0.4以后版本提供了mvc:resources , 使用方法:Xml代码 1. 2. /images/*映射到 ResourceHttpRequestHandler进行处理,location指定静态资源的位置.可以是web application根目录下、jar包里面,这样可以把静态资源压缩到jar包中。cache-period 可以使得静态资源进行web cache如果出现下面的错误,可能是没有配置的原因。 报错WARNING: No mapping found for HTTP request with URI /mvc/user/findUser/lisi/770 in

26、 DispatcherServlet with name springMVC 使用元素,把mapping的URI注册到SimpleUrlHandlerMapping的urlMap中,key为mapping的URI pattern值,而value为ResourceHttpRequestHandler,这样就巧妙的把对静态资源的访问由HandlerMapping转到ResourceHttpRequestHandler处理并返回,所以就支持classpath目录,jar包内静态资源的访问.另外需要注意的一点是,不要对SimpleUrlHandlerMapping设置defaultHandler.因为

27、对static uri的defaultHandler就是ResourceHttpRequestHandler,否则无法处理static resources request. 方案三 ,使用Xml代码 1. 会把/* url,注册到SimpleUrlHandlerMapping的urlMap中,把对静态资源的访问由HandlerMapping转到 org.springframework.web.servlet.resource.DefaultServletHttpRequestHandler 处理并返回.DefaultServletHttpRequestHandler使用就是各个Servlet容

28、器自己的默认Servlet.补充说明:多个HandlerMapping的执行顺序问题:DefaultAnnotationHandlerMapping的order属性值是:0自动注册的 SimpleUrlHandlerMapping的order属性值是: 2147483646自动注册 的SimpleUrlHandlerMapping 的order属性值是: 2147483647 spring会先执行order值比较小的。当访问一个a.jpg图片文件时,先通过 DefaultAnnotationHandlerMapping 来找处理器,一定是找不到的,因为我们没有叫a.jpg的Action。然后再

29、按order值升序找,由于最后一个 SimpleUrlHandlerMapping 是匹配 /*的,所以一定会匹配上,就可以响应图片。访问一个图片,还要走层层匹配。不知性能如何? 最后再说明一下,方案二、方案三 在访问静态资源时,如果有匹配的(近似)总拦截器,就会走拦截器。如果你在拦截中实现权限检查,要注意过滤这些对静态文件的请求。如何你的DispatcherServlet拦截 *.do这样的URL后缀,就不存上述问题了。还是有后缀方便。转载请注明出处:原文地址: 八、请求如何映射到具体的Action中的方法?方案一:基于xml配置映射,可以利用SimpleUrlHandlerMapping、

30、BeanNameUrlHandlerMapping进行Url映射和拦截请求。配置方法略。方案二:基于注解映射,可以使用DefaultAnnotationHandlerMapping。 Xml代码 1. 但前面我们配置了,他会自动注册这个bean,就不须要我们显示的注册这个bean了。 如何替换 ?他到底做了什么工作,请看,最后面的 十九节 到底做了什么工作。 以上都可以注入interceptors,实现权限控制等前置工作。我们使用第2种,基于注解来使用spring MVC 并在action类上使用:ControllerRequestMapping(/user) 转载请注明出处:原文地址: 九、

31、Spring中的拦截器:Spring为我们提供了:org.springframework.web.servlet.HandlerInterceptor接口, org.springframework.web.servlet.handler.HandlerInterceptorAdapter适配器,实现这个接口或继承此类,可以非常方便的实现自己的拦截器。有以下三个方法:Action之前执行:public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler);生成视图之前

32、执行public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView);最后执行,可用于释放资源public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)分别实现预处理、后处理(调用了Service并返回ModelAndView,但未进行页面渲染)

33、、返回处理(已经渲染了页面) 在preHandle中,可以进行编码、安全控制等处理; 在postHandle中,有机会修改ModelAndView; 在afterCompletion中,可以根据ex是否为null判断是否发生了异常,进行日志记录。 参数中的Object handler是下一个拦截器。转载请注明出处:原文地址: 十、如何使用拦截器?自定义一个拦截器,要实现HandlerInterceptor接口:Java代码 1. publicclassMyInteceptorimplementsHandlerInterceptor2. 略。3. Spring MVC并没有总的拦截器,不能对所有

34、的请求进行前后拦截。Spring MVC的拦截器,是属于HandlerMapping级别的,可以有多个HandlerMapping ,每个HandlerMapping可以有自己的拦截器。当一个请求按Order值从小到大,顺序执行HandlerMapping接口的实现类时,哪一个先有返回,那就可以结束了,后面的HandlerMapping就不走了,本道工序就完成了。就转到下一道工序了。拦截器会在什么时候执行呢? 一个请求交给一个HandlerMapping时,这个HandlerMapping先找有没有处理器来处理这个请求,如何找到了,就执行拦截器,执行完拦截后,交给目标处理器。如果没有找到处理器

35、,那么这个拦截器就不会被执行。 在spring MVC的配置文件中配置有三种方法: 方案一,(近似)总拦截器,拦截所有url Java代码 1. 2. 3. 为什么叫“近似”,前面说了,Spring没有总的拦截器。 会为每一个HandlerMapping,注入一个拦截器。总有一个HandlerMapping是可以找到处理器的,最多也只找到一个处理器,所以这个拦截器总会被执行的。起到了总拦截器的作用。 如果是REST风格的URL,静态资源也会被拦截。方案二, (近似) 总拦截器, 拦截匹配的URL。 Xml代码 1. 2. 3. 4. 5. 6. 就是比 方案一多了一个URL匹配。 如果是RES

36、T风格的URL,静态资源也会被拦截。方案三,HandlerMappint上的拦截器。 如果是REST风格的URL,静态资源就不会被拦截。因为我们精准的注入了拦截器。Xml代码 1. 2. 3. 4. 5. 6. 7. 如果使用了,它会自动注册DefaultAnnotationHandlerMapping 与AnnotationMethodHandlerAdapter 这两个bean,所以就没有机会再给它注入interceptors属性,就无法指定拦截器。 当然我们可以通过人工配置上面的两个Bean,不使用 ,就可以 给interceptors属性 注入拦截器了。 其实我也不建议使用 ,而建议手

37、动写详细的配置文件,来替代 ,这就控制力就强了。 如何替换 ?他到底做了什么工作,请看,最后面的 十九节 到底做了什么工作。 转载请注明出处:原文地址: 十一、如何实现全局的异常处理? 在spring MVC的配置文件中: Xml代码 1. 2. 3. 4. /error/error5. 6. 7. 5008. 9. 10. org.springframework.web.servlet.handler.SimpleMappingExceptionResolver11. 12. 这里主要的类是SimpleMappingExceptionResolver类,和他的父类AbstractHandle

38、rExceptionResolver类。 具体可以配置哪些属性,我是通过查看源码知道的。 你也可以实现HandlerExceptionResolver接口,写一个自己的异常处理程序。spring的扩展性是很好的。 通过SimpleMappingExceptionResolver我们可以将不同的异常映射到不同的jsp页面(通过exceptionMappings属性的配置)。 同时我们也可以为所有的异常指定一个默认的异常提示页面(通过defaultErrorView属性的配置),如果所抛出的异常在exceptionMappings中没有对应的映射,则Spring将用此默认配置显示异常信息。 注意这

39、里配置的异常显示界面均仅包括主文件名,至于文件路径和后缀已经在viewResolver中指定。如/error/error表示/error/error.jsp 显示错误的jsp页面: Html代码 1. 3. 4. 5. 6. 7. 8. 错误页面9. 10. 11. 出错了12. 16. 17. 其中一句:request.getAttribute(exception),key是exception,也是在SimpleMappingExceptionResolver类默认指定的,是可能通过配置文件修改这个值的,大家可以去看源码。 十二、如何把全局异常记录到日志中? 在前的配置中,其中有一个属性wa

40、rnLogCategory,值是 “SimpleMappingExceptionResolver类的全限定名”。我是在SimpleMappingExceptionResolver 类父类AbstractHandlerExceptionResolver类中找到这个属性的。查看源码后得知:如果warnLogCategory不为 空,spring就会使用apache的mons.logging.Log日志工具,记录这个异常,级别是warn。 值:“org.springframework.web.servlet.handler.SimpleMappingExceptionResolver”,是“Simp

41、leMappingExceptionResolver类的全限定名”。这个值不是随便写的。 因为我在log4j的配置文件中还要加入 log4j.logger.org.springframework.web.servlet.handler.SimpleMappingExceptionResolver=WARN, 保证这个级别是warn的日志一定会被记录,即使log4j的根日志级别是ERROR。 转载请注明出处:原文地址: 十三、如何给spring3 MVC中的Action做JUnit单元测试? 使用了spring3 MVC后,给action做单元测试变得很方便,我以前从来不给action写单元测试的,现在可以根据情况写一些了。 不用给每个Action都写单元测试吧,自己把握吧。 JUnitActionBase类是所有JUnit的测试类的父类 Java代码 1. packagetest;2. importjavax.servlet.http.HttpServletRequest;3. importjavax.servlet.http.HttpServletResponse;4. importorg.junit.BeforeClass;5. importorg.springframe

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!