专注于 JetBrains IDEA 全家桶,永久激活,教程
持续更新 PyCharm,IDEA,WebStorm,PhpStorm,DataGrip,RubyMine,CLion,AppCode 永久激活教程

在eclipse中进行Struts2项目的配置

  Struts2是一个比较出色的基于MVC设计模式的框架,是由Struts1和WebWork发展而来的,性能也比较稳定,现在是Apache软件基金会的一个项目,下面就来配置Struts2进行初始化的开发

  Struts2对环境要求不高,JDK版本1.5以上,ServletAPI在2.5以上,Tomcat版本在6.0以上即可,当然更推荐使用最新版本

  首先去Apache官网下载Struts2的类库,http://www.apache.org最下方的Struts项目超链接http://struts.apache.org,进入Struts首页如下:

  53_1.png

  点击Download按钮进入下载界面,

  53_2.png

  目前Struts最新版本是2.3.24.1,分为apps项目案例,lib核心驱动,docs文档和src框架源码,根据需要进行下载,我这里下载的struts-2.3.24.1-all.zip这其中包括所有的包,下载到本地解压出来即可,这个页面中还有之前版本的下载链接,也包括struts1的下载链接

  如果想下载所有的历史包,链接是:http://people.apache.org/builds/struts/

  然后打开eclipse for javaEE,新建动态网站项目

  53_3.png

  输入项目名确认即可,然后就建立了一个普通的web项目,和之前的没有区别,另外注意要创建web.xml配置文件

  53_4.png

  然后,打开我们刚才下载的Struts2中lib目录,这下面有非常多的Struts类库,并不是完全需要,一般情况下我们只导入常用的即可,其他的到需要的时候再导入,需要的jar包如下图:

  53_5.png

  复制到lib目录后,eclipse项目会自动导入web的类库

  然后,配置web.xml,在节点之间添加下面代码,也就是Struts2的框架的过滤器

     <filter>
         <filter-name>struts2</filter-name>
         <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
     </filter>

     <filter-mapping>
         <filter-name>struts2</filter-name>
         <url-pattern>/*</url-pattern>
     </filter-mapping>

  配置过滤器是Struts2能跑起来最基本的前提,工作原理就是当tomcat容器启动时,首先加载web.xml,所以会加载其中定义的过滤器,因此StrutsPrepareAndExecuteFilter过滤器会过滤项目下所有的请求,然后后来利用过滤器捕获action请求,从而调用相应的方法进行处理,这就是Struts2的大致工作情况,StrutsPrepareAndExecuteFilter类出现可以让开发人员自定义过滤器,从而在请求到达处理之间对用户请求进行处理

  配置好web.xml后需要建立Struts2的核心配置文件,位置就是项目下的src目录中,建立struts.xml文件,他负责配置所有的请求对应各种类或者方法,所以是核心配置文件,基本的结构如下:

 <?xml version="1.0" encoding="UTF-8" ?>
 <!DOCTYPE struts PUBLIC
     "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
     "http://struts.apache.org/dtds/struts-2.3.dtd">
 <struts>

 </struts>

  头部是声明,我们所有的配置都写在标签的内部,那么写一个最简单的配置:

     <package name="default" namespace="/" extends="struts-default">
         <action name="hellostruts2" class="net.zengzhiying.action.HelloStruts2Action">
             <result>/result.jsp</result>
         </action>

         <action name="login" method="login" class="net.zengzhiying.action.HelloStruts2Action">
             <result>/login.jsp</result>
         </action>
     </package>

  在这里,一个action就负责处理一个请求,packge我们使用的默认包,当有多个packge时,name一定要区分开,namespace就是访问的空间,我们的项目名是HelloStruts2,如果命名空间是/test那么应该访问,http://localhost:8080/HelloStruts2/test/自定义的action

  第一个action对应的访问路径就是http://localhost:8080/HelloStruts2/hellostruts2.action当然默认也可以不加action

  第二个action对应的就是http://localhost:8080/HelloStruts2/login.action

  然后去建立一个Action类,就是HelloStruts2Action,类名命名必须是以Action结尾的驼峰命名,并且继承于ActionSupport类,具体代码如下:

 package net.zengzhiying.action;

 import com.opensymphony.xwork2.ActionSupport;

 public class HelloStruts2Action extends ActionSupport {

     private static final long serialVersionUID = 1L;

     @Override
     public String execute() throws Exception {
         System.out.println("执行Action");

         return SUCCESS;
     }

     //新增自定义方法
     public String login() {
         return SUCCESS;
     }

 }

  如果前面配置文件没指定method属性,默认访问的方法就是execute方法,我们另外还自定义了一个login方法,SUCCESS常量返回了默认的指定的视图,下面建立对应的jsp文件

  result.jsp

 <%@ page language="java" contentType="text/html; charset=UTF-8"
     pageEncoding="UTF-8"%>
 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
 <html>
 <head>
 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
 <title>成功视图</title>
 </head>
 <body>
     Hello Struts2
 </body>
 </html>

  另外login.jsp的建立也是一样,就不列出了,现在一个基本的Struts2应用就建好了,现在启动服务器,访问即可看到结果:

  53_6.png

  然后我么看控制台也进行了打印输出

  53_7.png

  同时访问login也是相同的效果

  53_8.png

  以上就是基本的配置了,另外在配置文件struts.xml中还可以配置感叹号、通配符等多种灵活的访问方式,还可以配置访问后缀等参数,同时Struts2框架强大的功能更远不止这些,还需要不断地学习研究

  

文章永久链接:https://tech.souyunku.com/47676

未经允许不得转载:搜云库技术团队 » 在eclipse中进行Struts2项目的配置

JetBrains 全家桶,激活、破解、教程

提供 JetBrains 全家桶激活码、注册码、破解补丁下载及详细激活教程,支持 IntelliJ IDEA、PyCharm、WebStorm 等工具的永久激活。无论是破解教程,还是最新激活码,均可免费获得,帮助开发者解决常见激活问题,确保轻松破解并快速使用 JetBrains 软件。获取免费的破解补丁和激活码,快速解决激活难题,全面覆盖 2024/2025 版本!

联系我们联系我们