前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >java之struts2的配置讲解(2) java之struts框架入门教程

java之struts2的配置讲解(2) java之struts框架入门教程

作者头像
Vincent-yuan
发布2019-09-10 18:17:29
3900
发布2019-09-10 18:17:29
举报
文章被收录于专栏:Vincent-yuanVincent-yuan

java之struts框架入门教程

基础上,进行下列操作

1.结构对比

原来的项目结构图

现在的结构图

即从结构上可以看出,在HelloStruts项目中增加了config 文件夹(Source Folder) 及user.xml 文件

2.修改配置文件,使struts.xml 中包含 user.xml 配置文件

struts.xml

代码语言:javascript
复制
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
    "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
    "http://struts.apache.org/dtds/struts-2.3.dtd">
<struts>
    
    <!-- 常量配置 -->
    <!-- 解决乱码 -->
    <constant name="struts.i18n.encoding" value="utf-8"/>
    <!-- action扩展名配置 -->
    <constant name="struts.action.extension" value="do,action,,zhangsan"/>
    <!-- 配置开发模式 -->
    <constant name="struts.devMode" value="true"/>
    
    <!-- 加载另外的配置文件  在团队协作中使用 -->
    <include file="cn/qm/struts/user.xml"></include>


    
</struts>

user.xml

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

    <!-- package表示包   name是自定义的 一般和模块名称相关  name在整个项目中唯一

    extends 表示继承   必须直接或者间接继承struts-default 因为在struts-default中 定义了struts2的相关功能。

    namespace 表示命名空间 和分模块开发相关   直接决定请求的url匹配工作 ,一个请求的url被action匹配
    需要加上namespace 如:namespace="/user",该namespace下有一个add的action,那么要请求
    该action的url为/user/add.action
    namespace也是为分工协作使用
    -->
    <package name="default" extends="struts-default" namespace="/sys">
    
        <!-- 
            action的配置 一个action表示一个请求

            name表示请求的url名称去掉后缀,在同一个 包下唯一

            class 表示处理请求的类的完全限定名=包名+类名,

            如果不写 默认由com.opensymphony.xwork2.ActionSupport

            method 指明处理请求的方法名称,默认是execute方法

            处理方法 必须是 public String xxxx(){};无参方法
         -->
        <action name="hello" class="cn.qm.action.HelloAction" method="hello">
            <!-- result表示结果集处理  name和action中处理方法的返回值匹配  默认为success
                struts的Action接口 提供了5个返回值类型
                  Action.SUCCESS 表示处理方法执行成功
                  Action.NONE  表示处理方法执行成功 但是不需要视图显示
                  Action.ERROR 表示处理方法执行失败
                  Action.INPUT 表示处理方法需要更多的输入信息 才能执行成功
                  Action.LOGIN 表示处理方法不能执行,需要用户登录 
                type表示结果集的跳转类型 默认是转发
                  dispatcher 转发
                  redirect 重定向
                  redirectAction 跳转到另外一个Action
                stream 流
                
                值 /表示根路径
             -->
            <result name="success" type="dispatcher">/index.jsp</result>
        </action>
    </package>
    
    
</struts>

3.修改 HelloAction 类,增加 hello 方法

代码语言:javascript
复制
public class HelloAction {

    ////struts2的处理方法 都是 public String的  默认执行execute,并且处理方法没有参数
    public String execute(){
        System.out.println("请求被接收了...");
        return "success";
    }
    
    public String hello(){
        System.out.println("hello");
        return Action.SUCCESS;
    }
}

因为在配置文件中,指定了hello方法,所以请求会进入hello方法

4.运行程序,并且在浏览器输入网址验证

网址:http://localhost:8080/Hello/sys/hello.action

浏览器显示

myeclipse中的console显示

说明请求成功被接收了。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-05-15 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • java之struts框架入门教程
相关产品与服务
Prowork 团队协同
ProWork 团队协同(以下简称 ProWork )是便捷高效的协同平台,为团队中的不同角色提供支持。团队成员可以通过日历、清单来规划每⽇的工作,同时管理者也可以通过统计报表随时掌握团队状况。ProWork 摒弃了僵化的流程,通过灵活轻量的任务管理体系,满足不同团队的实际情况,目前 ProWork 所有功能均可免费使用。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档