struts2面试整理

  1. struts2的工作原理
  • 客户端发送请求
  • 经过一系列的过滤器
  • FilterDispatcher通过ActionMapper来决定这个REquest需要调用的Action
  • FilterDispather交给ActionProxy
  • 通过ConfigurationManager询问struts.xml找到对应的Action
  • ActionProxy创建一个ActionInvocation实例
  • 调用Action Action执行完毕ActionInvocation负责根据struts.xml中的配置找到对应的返回结果

2. Struts拦截器,常用的拦截器

  • Struts2的拦截器是其核心部分,它提供了一种机制,可以定义一个特殊的模块,对请求进行封装和处理,这个模块在Action执行前后都可以进行
  • modelDriven(模型驱动) servletConfig(获取ServletApo) params(动态参数注入) validation(输入验证 声明式验证)

3. struts2的优点

  • 实现了mvc模式 层次结构清晰,
  • 丰富的标签库,提高了开发效率
  • 提供了丰富的拦截器实现
  • 方便异常处理
  • 通过配置文件可以掌握系统各个部分之间的关系

4. struts2核心控制器

  • FilterDispatcher
  • 它负责拦截所有的用户请求,当 用户请求到达时,该Filter会过滤用户请求。如果用户请求以action结尾,该请求将被转入Struts 2框架处理。

5. struts2配置文件覆盖顺序

  • struts.xml -> struts.properties -> web.xml(配置过滤器时,指定参数。程序员可以编写)

6. struts2修改常量的方式

  • struts.xml:<constant name="struts.action.extension" value="do"/>
  • struts.properties : struts.action.extension=do

7. Action

  • Action为多例的,所以在Spring中Scope要设置参数
  • 通配符 动态调用

8. Action实现的三种方式

  • 单纯的POJO
  • 实现Action接口 (提供了格式化的返回参数)
  • 继承ActionSupport(实现了Action接口并且其中还做了一些国际化和验证的功能)

9. 访问ServletAPI

  • ServletActionContext
  • 实现接口 ServletRequestAware,ServletResponseAware ,ServletContextAware 拦截器负责注入(ServletConfig)

10. 结果视图

  • chain(转发到动作,要是不在同一个包内需要设置 name) dispatcher(默认) redierct (请求重定向) stream(文件上传和下载)

11. 默认的struts-default有什么作用

  • struts-default包是由struts内置的,它定义了struts2内部的众多拦截器和Result类型,而Struts2很多核心的功能都是通过这些内置的拦截器实现,当包继承了struts-default包才能使用struts2为我们提供的这些功能。
  • 通常每个包都应该继承struts-default包。

12. struts2如何对指定的方法进行验证

  • 验证功能是由validation拦截器来负责处理的。回显错误信息是由workflow拦截器来负责处理的。
  • 验证失败以后错误信息回显需要设置<result name="input">/regist.jsp</result> 结果视图
  • 对类中所有方法进行验证,复写validate()方法,当出错的时候addFieldError("name", "请输入用户名");
  • 对指定方法:将validate()方法改写成为public void validateDemo1 后面是指定方法的名字(验证Demo1方法)

13. 值栈

  • ValueStack的生命周期为Action的生命周期,保存在request域中,
  • 每个action都有与之对应的值栈,action对象默认保存在栈顶
  • 使用OGNL访问值栈中的内容不需要添加# 而访问其他域中的需要添加#

14. ActionContext、ServletContext、pageContext的区别?

  • ActionContext是当前Action的上下文环境,通过ActionContext可以获取到request、session、ServletContext等与Action有关的对象的引用
  • ServletContext是域对象,一个web应用中只有一个ServletContext,生命周期伴随整个web应用;
  • pageContext是JSP中的最重要的一个内置对象,可以通过pageContext获取其他域对象的应用,同时它是一个域对象,作用范围只针对当前页面

15. 拦截器

  • 每个拦截器都是实现了Interceptor接口的java类
  • Init() 在这个拦截器初始化的时候被调用
  • intercept() 当拦截器起作用的时候调用
  • destroy() 在拦截器被销毁的时候调用
  • struts2默认有18个拦截器

16. 自定义拦截器

  • 编写一个类继承MethodFilterInterceptor
  • struts2.xml中声明拦截器
  • struts2.xml中声配置拦截器 , 当指定自定义拦截器时默认拦截器会失效,所以还要显示的在指定一次.

17. 文件上传

  • file域 form表单enctype=multipart/form-data 提交方式为post
  • action接受文件对象为表单中的name, 文件类型为name+ContentType 文件名字为:jsp页面file组件的名称+FileName
  • 可以用数组来接收多个文件的上传

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏ionic3+

【Appetite】ionic3实录(五)基本服务实现

前面章节基本把应用的总体配置完成了,开始进入具体页面的开发,而这些离不开与数据的交互、与用户的反馈操作等。正所谓“兵马未动,粮草先行”,现在封装下基本的服务。

854
来自专栏程序员互动联盟

【专业技术】Android安全嘛?

安卓有一套自己的安全权限机制,大部分来自linux的权限机制,某些地方也做了延伸,比如linux中的用户概念,在安卓上来说就相当于app。对于一些刚学习安卓的同...

4059
来自专栏安恒网络空间安全讲武堂

技术分享 | 深入分析APPCMS&lt;=2.0.101 sql注入漏洞

目录 0x00 前言 0x01 漏洞分析--代码审计 0x02 漏洞利用 1.sql注入出后台账号、密码、安全码 2.二次漏洞利用:sql注入+csrf...

2968
来自专栏散尽浮华

Python-Socket

socket通常也称作套接字,用于描述IP地址和端口,是一个通信链的句柄,应用程序通常通过“套接字”向网络发出请求或者应答网络请求 socket既是一种特殊文件...

2267
来自专栏屈定‘s Blog

Maven仓库清理脚本

工作中本地maven仓库随着项目增多会变得越来越大,看着心烦,于是想着清理. 没有发现很好的清理策略,只能从文件以及文件夹修改时间上入手,修改时间小于指定时间的...

1093
来自专栏用户2442861的专栏

C语言开发Linux下web服务器(支持GET/POST,SSL,目录显示等)

http://blog.csdn.net/yueguanghaidao/article/details/8450938

1482
来自专栏扎心了老铁

Redis实现分布式锁

之前写过一篇博客,里面吭哧吭哧半天,使用Redis实现了一个分布式锁。 今天闲来没事看源码,突然发现redis set命令的用法可以直接指定nx和ex,文档中没...

3066
来自专栏后端之路

js捕获404错误

最近使用fundebug,发现fundebug升级到了0.1.0,支持了 Fundebug的JavaScript监控插件更新至0.1.0,可以监控3种不同类型的...

4867
来自专栏有趣的Python

11- vue django restful framework 打造生鲜超市 -用户登录和手机注册(下)

Vue+Django REST framework实战 搭建一个前后端分离的生鲜超市网站 Django rtf 完成 手机注册和用户登录(下) user...

5388
来自专栏拂晓风起

Spring 获取web根目录 (Spring线程获取web目录/路径/根目录,普通类获取web目录)

923

扫码关注云+社区