目前学了struts的原理
就是将mvc应用到网页上,也就是将业务逻辑,数据,界面分离的组织方式
运行过程:
client网页输入地址
|
v
tomcat调用dofilter()查找web.xml中的filter
然后去找struts.xml中的namespace
|
v
找到对应action
|
v
返回result中的结果
我对namespace的理解:namespace就是拦截下来action的路径
我对action的理解:action就是调用了一个java函数返回一个值如果result判断对就
执行result标签中的内容,比如“/Path.jsp”就会直接返回Path.jsp中的内容
我对Path的理解:只根据当前页面的地址再链接
比如在http://localhost:8080/Struts2_040_Path/path/Action.action
中点击了一个链接内容为<a href="index.jsp">成功了!</a>
会链接到http://localhost:8080/Struts2_040_Path/path/index.jsp
#五#动态方法调用
在进入链接的时候,能够动态选择调用java类中的函数
这里对应第五个例子中的indexaction1.java
通过地址输入在action后加“!函数”比如“user!add”就会自动访问add函数
#六#使用通配符
通过在struts设置通配符简化action的拦截
#七#通过action传值
在相应的action函数中添加函数还有参数
地址传过去参数然后自动匹配函数中的
#八#通过类传值
在相应的action函数中添加函数还有参数,把参数换成另一个类,(如果地址传入的
数值与类参数不符,就是用odt,就是一个数据的中转站,然后匹配数据再传给
action函数)
#九#模型驱动传值
mvc中m为model 就是后台的一些类
v为view 就是jsp显示界面
c为contraler 为action,action控制以上两者交流,并解开以上两者耦合
#十#中文问题
总结struts编程“小”问题
(1)struts.xml中的这句话,是调试自动化,就是调试过程中修改不用重新运行
<constant name="struts.devMode" value="true" />
(2)web.xml文件中的filter有一栏属性,叫做filter-class为控制struts2的源文
件位置
(3)在jsp中
<%String path = request.getContextPath();
StringbasePath=request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<head>
<base href="<%=basePath%>">
<head/>
为获取文件根位置,这个影响到在本页想要访问其他页面的方法比如以上我对path的理解,想要正确访问就要加上上边两句话
中文乱码:在将参数代入action传入后,传出时出现乱码
说明:为struts1.6的bug,将在1.7修正
解决方法:1。修改filter进行拦截2。使用老版的<filter-class>
数据校验:在#八#中传递的参数需要校验
在action函数中使用函数接收信息,然后在内部判断如果出错通过返回不同的值跳转到出错提示界面。而且可以填充fielderror然后在具体页面提取出来进行使用
this.addFieldError("name", "name is error");
this.addFieldError("name", "name is too long");
+
<s:property value="errors.name[0]"/>
通过actioncontect可以后台的一些action的运行环境。