首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 软件管理 > 软件架构设计 >

马战士struts2.1.6视频教程笔记(01 - 22)

2012-10-30 
马士兵struts2.1.6视频教程笔记(01 -- 22)1、02_尚学堂马士兵_Struts2_Struts2_HelloWorld_2.avi指定Tomcat

马士兵struts2.1.6视频教程笔记(01 -- 22)

1、02_尚学堂马士兵_Struts2_Struts2_HelloWorld_2.avi  指定Tomcat的目录,指定JDK搭建开发环境(拷贝jar包,复制struts.xml文件 此文件不要放在WEB-INF下面,应该放到src下面  ),在web.xml文件中:<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> 其中<url-pattern>/*</url-pattern> 不要写/*.do 或者 /*.action约定俗成用/*2、04_尚学堂马士兵_Struts2_Struts2_HelloWorld_3.avi(1)<!-- <constant >:常量的配置 --><!--name="struts.devMode" value="true":当前是开发模式,改动配置文件会自动装载 默认是false--><!--命名空间 ---> action -->相应的处理类或页面 --><constant name="struts.devMode" value="true" /> <package name="default" namespace="/" extends="struts-default">                <action name="hell"  key="*.dtd"3、09_尚学堂马士兵_Struts2_Struts2_HelloWorld_7_2.avi   struts2的执行流程:   当用户在浏览器中敲入要访问的地址的时候,浏览器会将这个请求发送给tomcat然后tomcat判断应该交给那个WebApplication来处理,然后会读取它下面的web.xml配置发现有配置:<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>因为<url-pattern> 为/* 它会过滤所有的请求然后就交给filter类org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter处理执行调用doFilter()方法,然后再方法中会读取struts-xml文件,根据用户请求的地址找到相应的package、 action、 result、然后将相应的页面返回给浏览器4、10_尚学堂马士兵_Struts2_Struts2_Namespace_命名空间.avi(1)namespace决定了action的访问路径,默认为"",可以接收所有路径的actionnamespace可以写为/,或者/xxx,或者/xxx/yyy,对应的action访问路径为/index.action,/xxx/index.action,或者/xxx/yyy/index.actionnamespace最好也用模块来进行命名5、11_尚学堂马士兵_Struts2_Struts2_Action.avi(1)struts1 与struts2的一个重要区别:在struts1中进行多次访问的时候用到的是同一个Action对象。而struts2则是每一次访问都会创建一个Action对象,所以struts2不会有线程安全问题的发生(2)<result>标签如果没有指定name属性默认返回值为success (3)<action>标签中的class值如果没有配置相应的类,它会调用struts默认的一个处理类的execute()方法.(4)实现struts的处理类的时候不要自己随便写类然后定义execute()方法,也不要实现Action类而要从ActionSupport类继承,可以直接使用它为我们定义好的方法.6、12_尚学堂马士兵_Struts2_Struts2_Path_路径问题.avi(1)struts2中的路径问题是根据action的路径而不是jsp路径来确定,所以尽量不要使用相对路径。虽然可以用redirect方式解决,但redirect方式并非必要。解决办法非常简单,统一使用绝对路径。(在jsp中用request.getContextRoot方式来拿到webapp的路径)或者使用myeclipse经常用的,指定basePath(2)request.getContextPath()得到项目的名字,一般用来解决路径问题 如果项目为根目录,则得到一个"",即空的字条串。     request.getscheme()返回的协议名称.默认是http     request.getServerName()就是获取你的网站的域名,如果是在本地的话就是localhost     request.getServerPort()获取服务的端口号   7、13_尚学堂马士兵_Struts2_Struts2_ActionMethod_DMI_动态方法调用.avi   Action执行的时候并不一定要执行execute方法<br />可以在配置文件中配置Action的时候用method=来指定执行哪个方法也可以在url地址中动态指定(动态方法调用DMI)(推荐)<br /><a href="<%=context %>/user/userAdd">添加用户</a><br /><a href="<%=context %>/user/user!add">添加用户</a><br />前者会产生太多的action,所以不推荐使用配置文件:<package name="user" extends="struts-default" namespace="/user">        <action name="userAdd" method="add">            <result>/user_add_success.jsp</result>        </action>                <action name="user" extends="struts-default" namespace="/actions">    <action name="Student_add"></action>    <action name="Student_*" method="{1}"> <result>/Student_{1}_success.jsp</result>    </action>    <!-- 更简便的配置法 -->    <action name="*_*" method="{2}"> <result>/{1}_{2}_success.jsp</result>    </action></package>说明:(1){1}代表name="Student*"后面第一个'*',同理{2}代表第二个'*'(2).如果action之间有重复配置,struts2会匹配最精确的action。如果通配符配置之间有重复,则看前后配置顺序9、 15_尚学堂马士兵_Struts2_Struts2_用Action的属性接收参数.avi      在继承ActionSupport的类中定义要接受的参数,参数的名称与Action所传的名称无关在struts2内部调用的是属性的set方法,所以setxxx()的名字一定要与Action后面所传的值是一样的。10、16_尚学堂马士兵_Struts2_Struts2_用DomainModel接收参数.avi    如果要接受的参数的个数很多,我们可以不用定义属性而是直接定义一个对象例如:     private User user (set get 方法)在调用Action传值的时候使用user!add?user.name=x&user.age=x的方式进行值得传递。(最常用的方式)11、17_尚学堂马士兵_Struts2_Struts2_用ModelDriven接收参数.avi    继承ActionSupport类的处理类必须同时实现ModelDriven<Object>(实现getModel())在传值的时候使用user/user!add?name=bbb进入处理类的时候会调用getModel()方法返回User对象并且把传过来的值set到里面,注意:此时private User user = new User() 不能只定义,要同时实现这样getModel()才能拿到user对象。12、18_尚学堂马士兵_Struts2_Struts2_2.1.6版本的中文问题.avi    在配置文件中加入:     <constant name="struts.i18n.encoding" value="GBK"/> 按照文档说明加入此句可解决中文乱码但是不行这是2.1.6的一个bug,会在下一个版本中修复 如何解决呢:在web.xml中: <filter-name>struts2</filter-name>        <!--<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>-->        <filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class>把过滤器的版本改成老版本的即可解决该问题!13、19_尚学堂马士兵_Struts2_简单数据验证_1.avi    使用addFieldError方法和s:fieldError标签简单处理数据校验     public String add() {if(name == null || !name.equals("admin")) {this.addFieldError("name", "name is error");this.addFieldError("name", "name is too long");return ERROR;} return SUCCESS;}在页面中显示错误信息:<!-- 以固定的css样式取出错误信息,不方便我们进行相应的处理--><s:fielderror fieldName="name" theme="simple"/><!-- 从存储错误信息的Map中拿数据 --><s:property value="errors.name[1]"/><!-- 显示详细的栈信息--><s:debug></s:debug>14、21_尚学堂马士兵_Struts2_访问Web元素_1.avi注意:web.xml中关于struts的配置一定要采用2.1的,2.0的会取不到这是一个bug(1)通过ActionContext对象取得Map类型的request, session, application HttpServletRequest, HttpSerletSession ServletContetext:  public class LoginAction1 extends ActionSupport {private Map request;private Map session;private Map application;         //访问此方法,取得相应的对象但是是Map类型public LoginAction1() {  request = (Map)ActionContext.getContext().get("request");  session = ActionContext.getContext().getSession();  application = ActionContext.getContext().getApplication();}//在Map类型的对象中存入相应的值public String execute() {request.put("r1", "r1");session.put("s1", "s1");application.put("a1", "a1");return SUCCESS; }}//在页面中通过标签取得存入的数据 二种方法(通过标签, 通过原始方式):<s:property value="#request.r1"/> | <%=request.getAttribute("r1") %> <br /><s:property value="#session.s1"/> | <%=session.getAttribute("s1") %> <br /><s:property value="#application.a1"/> | <%=application.getAttribute("a1") %> <br /><s:property value="#attr.a1"/><br /><s:property value="#attr.s1"/><br /><s:property value="#attr.r1"/><br /><s:debug></s:debug><br />我们存入Map中的数据居然可以在request,等对象中得到,那么在struts内部他是将Map中的数据全部复制到了request,session等对象中的 #attr ,可以取得所有的属性,但是不推荐使用,为了防止同名的情况,造成无法区别。(2)通过实现RequestAware,SessionAware, ApplicationAware 接口获取(最常用 和重要的一种)private Map<String, Object> request;private Map<String, Object> session;private Map<String, Object> application;//DI dependency injection//IoC inverse of controlpublic String execute() {request.put("r1", "r1");session.put("s1", "s1");application.put("a1", "a1");return SUCCESS; }@Overridepublic void setRequest(Map<String, Object> request) {this.request = request;}@Overridepublic void setSession(Map<String, Object> session) {this.session = session;}@Overridepublic void setApplication(Map<String, Object> application) {this.application = application;}(3)通过ServletActionContext()取得真实的相应的对象private HttpServletRequest request;private HttpSession session;private ServletContext application;public LoginAction3() {request = ServletActionContext.getRequest();session = request.getSession();application = session.getServletContext();}public String execute() {request.setAttribute("r1", "r1");session.setAttribute("s1", "s1");application.setAttribute("a1", "a1");return SUCCESS; }(4)通过实现ServletRequestAware接口获得相应的对象  private HttpServletRequest request;private HttpSession session;private ServletContext application;public String execute() {request.setAttribute("r1", "r1");session.setAttribute("s1", "s1");application.setAttribute("a1", "a1");return SUCCESS; }@Overridepublic void setServletRequest(HttpServletRequest request) {this.request = request;this.session = request.getSession();this.application = session.getServletContext();}  

热点排行