Struts2-上传文件、自定义拦截器

一、Struts2上传文件

一、单个文件上传:
1、加入jarcommons-fileupload-1.2.1.jarcommons-io-1.3.2.jar
2
、设置form表单如下:
<form enctype="multipart/form-data" action="${pageContext.request.contextPath}/***.action" method="post">
 <imput type="file" name="image">
</form>
3
、在Action类中添加以下属性:
private File image;//得到上传的文件
private String imageContentType;//得到文件的类型
private String imageFileName;//得到文件的名称
...
public String upload() throws Exception{
 String realpath = ServletActionContext.getServletContext().getRealPath("/images");
 if(image!=null){
  File savefile = new File(new File(realpath),imageFileName);
  if(!savefile.getParentFile().exists()) savefile.getParentFile().mkdirs();
  FileUtils.copyFile(image,savefile);
  ActionContext.getContext().put("message","
上传成功");
 }
 return "success";
}


String realpath = ServletActionContext.getServletContext().getRealPath("/images");
File file = new File(realpath);
if(!file.exists()) file.mkdirs();
FileUtils.copyFile(image,new File(file,imageFileName));

二、当有多个文件上传时:
    文件1:<input type="file" name="image"><br/>
   
文件2:<input type="file" name="image"><br/>
   
文件3:<input type="file" name="image"><br/>
Action类中:
    private File[] image;
    private String[] imageFileName;
   ...
   public String upload() throws Exception{
 String realpath = ServletActionContext.getServletContext().getRealPath("/images");
 if(image!=null){
  File savedir = new File(realpath);
  if(!savedir.exists()) savedir.mkdirs();
  for(int i = 0 ; i<image.length ; i++){    
   File savefile = new File(savedir, imageFileName[i]);
   FileUtils.copyFile(image[i], savefile);
  }
  ActionContext.getContext().put("message", "
上传成功");
 }
 return "success";
  }

 

二、Struts2自定义拦截器

自定义拦截器:
<package name="itcast" namespace="/test" extends="struts-default">
 <interceptors>
  <interceptor name="permission" class="cn.itcast.aop.PermissionInterceptor"/>
  <interceptor-stack name="permissionStack">
   <interceptor-ref name="defaultStack"/>
   <interceptor-ref name="permission"/>
   //<interceptor-ref name="permission"><param name="excludeMethods">welcome,login</param></interceptor>
  </interceptor-stack>
 </interceptors>
 //<default-interceptor-ref name="permission"/>
 <action name="helloworld_" class="cn.itcast.action.HelloWorldAction" method="{1}">
  <result name="success">hello.jsp</result>
  <interceptor-ref name="permissionStack"/>
 </action>
</package>

因为struts2中如文件上传,数据验证,封装请求参数到action等功能都是由系统默认的defaultStack中的拦截器实现的,所以我 们定义的拦截器需要引用系统默认的defaultStack,这样应用才可以使用struts2框架提供的众多功能。
如果希望包下的所有action都使用自定义的拦截器,可以通过<default-interceptor-ref name="permissionStack"/>把拦截器定 义为默认拦截器。注意,每个包只能指定一个默认拦截器。另外,一旦我们为该包中的某个action显式指定了某个拦截器,则默认 拦截器不会起作用。

举例:
判断用户是否登录,登录后才可以执行action的方法,否则不可执行
public class PermissionInterceptor implements Interceptor {
 public void destroy() {
 }
 public void init() {
 }
 public String intercept(ActionInvocation invocation) throws Exception {
  Object user = ActionContext.getContext().getSession().get("user");
  if(user!=null) return invocation.invoke(); //
如果user不为null,代表用户已经登录,允许执行action中的方法
  ActionContext.getContext().put("message", "你没有权限执行该操作");
  return "success";
 }
}

注:invocation.invoke()被执行了被拦截的方法才会执行,invocation.invoke()执行后返回当前方法所返回的字符串。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值