1.1.自从Struts2.13、以后之前的FilterDispatcher标注为过时
2.<filter-class>
3. org.apache.struts.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter
4.</filter-class>
5.
6.2.action中默认的method为execute()
7. 默认class为ActionSupport
8. 默认name 为success;
9.
10.3.转发类型 传中文参数URLEncoder.encode("","UTF-8");
11.forward
12.
13.redirect 浏览器跳转
14.<result type="redirect">/index.jsp</param>
15.
16.redirectAction(跳转到另一action)
17.<result type="redirectAction">
18.<param name="actionName">xxx</param>
19.<param name="namespace">/xxx/xxx</param>
20.</result>
21.
22.plainText(返回jsp页面的源代码) 中文问题
23.<result type="plainText">
24.<param name="location">index.jsp</param>
25.<param name="charSet">UTF-8</param>
26.</result>
27.
28.4.共用
29.<global-results>
30. <result name="success">index.jsp</result>
31.</global-results>
32.
33.5.给action中的参数赋值
34.<action ---->
35. <param name="param_name">xxx</param>
36. <result>index.jsp</result>
37.</action>
38.
39.6.常量标签
40.<指定截取的后缀
41.<constant name="struts.action.extension" value="do,action"/>
42.
43.指定默认编码集 作用于HttpServletRequest的setCharacterEncoding的方法
44.<constant name="struts.i18n.encoding" value="UTF-8"/>
45.
46.设置浏览器是否缓存静态页面 默认值为true
47.<constant name="struts.serve.static.browserCache" value="true"/>
48.
49.当struts的配置文件被修改后,系统是否自动重新加载文件 默认值为false
50.<constant name="struts.configuration.xml.reload" value="true"/>
51.
52.打印详细错误信息 开发阶段可以打开
53.<constant name="struts.devMode" value="true"/>
54.
55.与spring集成时,指定由spring负责的action对象创建
56.<constant name="struts.objectFactory" value="spring"/>
57.
58.上传文件大小限制 默认大小为10701096
59.<constant name="struts.multipartmaxSize" value="10701096"/>
60.
61.struts2加载常量的搜索顺序
62.struts-default.xml->struts-plugin.xml->struts.xml->struts.properties->web.xml
63.如果在多个配置中定义了同一常量则后一文件中的常量将覆盖前面的常量
64.
65.主题
66.<constant name="struts.ui.theme" value="simple"/>
67.7.指定调用方法 默认是执行execute
68.动态方法调用:
69.<constant name="struts.enable.DynamicMethodInvocation" value="true"/>
70.在访问路径后加!methodname 如/example/list!add.action
71.
72.也可以用通配符来确认
73.<action name="list_*_*" class="com.ss.action.{1}Action" method="{1}">
74. <result name="success">/{2}.jsp</result>
75.</action>
76.
77.8.2.1.6版本 接受中文请求参数出现乱版
78.新建一个过滤器filter放到struts2的filter之前,然后在doFilter()方法中添加代码
79.public void doFilter(){
80. HttpServletRequest req=(HttpServletRequest)request;
81. req.setCharacterEncoding("UTF-8");
82. filterchain.doFilter(request,response);
83.}
84.
85.9.定义类型转换器
86.一、局部
87.定义一个类并继承DefaultTypeConverter从写
88.convertValue(Map<String,Object> context,Object value,Class toType){
89. SimpleDateFormat date=new SimpleDateFormat("yyyymmdd");
90.try{
91. if(toType==Date.class){
92. String[] params=(String[])value;
93. return dateFormat.parse(params[0]);
94. }else if(toType==String.class){
95. Date date=(Date)value;
96. return dateFormat.format(date);
97. }
98. }catch(ParseException e){
99. return null;
100. }
101.}
102.注册:在Action类包下放置<ActionClassName>-conversion.properties文件
103. 属性名=包名.定义的类
104.二、全局
105.在src下(WEB-INF/class/)下 xwork-conversion.properties
106.java.util.Date=包名.类名
107.
108.10.向request、session、application中添加属性
109.ActionContext act=ActionContext.getCOntext();
110.act.getApplication.put("app","应用范围");
111.act.getSession.put("ses","session应用范围");
112.act.put("req","request范围")
113.
114.获取原生的请求对象
115.HttpServletRequest request=ServletActionContext.getRequest();
116.ServletContext servlet=ServletActionContext.getServletContext();
117.servletContext.getRealPath(“”);得到具体文件的绝对路径
118.request.getSession().setArrtibute("session","会话范围");
119.servletContext.setAttribut("app","应用范围");
120.request.setAttribute("req","request范围");
121.页面访问
122.${applicationScope.app}
123.${sessionScope.ses}
124.${requestScope.req}
125.
126.11.struts2上传文件
127.第一步:放jar包 commond-fileupload-1.21.art和commons-io-1.3.2.jar
128.第二步:把form表单的enctype设置为:multipart/form-data 如
129.<form enctype="multipart/form-data"
130.
131.action="${pageContext.request.contextPath/list.action}" method="">
132. <input type="file" name="uploadImage">
133. <input type="submit" value="upload"/>
134.</form>
135.第三步:在action中添加以下属性 命名规则 与file的name相同
136.private File uploadImage;//得到上传文件
137.private String uploadImageContentType;//得到上传文件的类型
138.private String uploadImageFileName;//得到上传文件的名称
139.
140.String realPath=ServletActionContext.getServletContext().getRealPath
141.
142.("/images");
143.File saveFile=new File(new File(realPath),uploadImageFileName);
144.if(!savefile.getParentFile().exists())
145. saveFile.getParentFile().mkdirs();
146.FileUtils.copyFile(uploadImage,saveFile);
147.
148.12.多文件上传
149.
150.将属性类型定义成数组活list类型
151.private File[] uploadImage;
152.private String[] uploadImageContentType;
153.private String[] uploadImageFileName;
154.
155.String realPath=ServletActionContext.getServletContext().getRealPath
156.
157.("/images");
158.if(uploadImage!=null){
159.File savedir=new File(new File(realPath));
160.if(!savedir.exists())
161. savedir.mkdirs();
162.for(int index=0;index<uploadImage.length,index++){
163. File saveFile=new File(savedir,uploadImageFileName[index]);
164. if(!saveFile.getParentFile().exists())
165. saveFile.getParentFile().mkdirs();
166. FileUtils.copyFile(uploadImage[index],saveFile);
167.}
168.
169.}
170.13.自定义拦截器
171.一:类实现Interceptor接口
172.在intercept方法中进行操作,invocation.invoke();继续执行该方法
173.二:注册拦截器
174.在sturts配置中定义:
175.<interceptors>
176. <interceptor name="自定义拦截器名" class="类"/>
177. <interceptor-stack name="栈名">
178. <interceptor-ref name="defaultStack"/>引用原来的拦截器
179. <interceptor-ref name="自定义拦截器名"/>
180. </interceptor-stack>
181.</interceptors>
182.<action name="xxx" class="xxxx">
183. <interceptor-ref name="栈名">
184.</action>
185.
186.定义一个包下的所有action都使用此拦截器
187.<default-interceptor-ref name="栈名"/>
188.
189.14.struts2的校验
190.第一:手工代码校验
191.一:所有方法校验
192. 1、类继承ActionSupport 再从写validate方法
193. 2、在validate中写入自己的验证需要
194. 3、此方法this.addFieldError("username","用户名不能为空!");用于放置错误信息
195.
196.,正则表达式的验证:
197.Pattern.compile(regex).matcher(this.mobile).matches();regex以^开始以$结尾
198.
199.fieldError包含错误信息则返回input <s:fielderror/>显示错误信息
200.二:指定方法校验
201. 1、继承ActionSupport,再写方法validateXxx() 其他同上一样
202.
203.第二:xml配置进行校验
204.一、所有方法
205.1.继承ActionSupport类,校验文件与action同包 命名ActionClassName-validation.xml
206.
207.;
208.文件内容:
209.<?xml version="1.0" encoding="UTF-8"?>
210.<!DOCTYPE validators PUBLIC"-//OpenSymphony Group//XWork Validator 1.03//EN"
211.
212."http://www.opensymphony.com/xwork/xwork-validator-1.0.3.dtd">
213.<validators>
214. <field name="username">
215. <field-validator type="requiredstring">
216. <param name="trim">true</param>
217. <message>用户名不能为空!</message>
218. </field-validator>
219. <field-validator type="tringlength">
220. <param name="minLength">4</param>
221. <param name="minLength">10</param>
222. <message><![CDATA[用户名应在4到10之间]]</message>
223. </field-validator>
224. </field>
225. <field name="mobile">
226. <field-validator type="requiredstring">
227. <message>手机号不能为空!</message>
228. </field-validator>
229. <field-validator type="regex">
230. <param name="expression"><![CDATA[^1[358]\d{9}$]]/>
231. <message>手机号格式不正确</message>
232. </field-validator>
233. </field>
234. <field name="age">
235. <field-validator type="int">
236. <param name="min">1</param>
237. <param name="max">150</param>
238. <message>年龄范围不对!</message>
239. </field-validator>
240. </field>
241.</validators>
242.
243.校验器的路径:com.opensymphony.xwork2.validators下的default.xml中
244.二、指定方法
245.文件命名:类名-配置中actiono的name-validation.xml
246.
247.15.国际化
248.全局范围、包范围、action范围
249.命名格式:
250.baseName_language_country.properties
251.baseName_language.properties
252.baseName.properties
253.baseName是资源文件基本名可以自定义,language和country必须支持java的语言和国家
254.中国baseName_zh_CN.properties
255.台湾baseName_zh_TW.properties
256.美国baseName_en_US.properties
257.
258.在properties中MyEclipse支持自动将中文转换为Unicode编码
259.利用jdk提供的native2ascii命令格式转:
260.native2ascii 源文件.properties 目标文件.properties
261.
262.通过在浏览器中改变语言就可以再语言间转换
263.一、全局:<constant name="struts.custom.i18n.resources" value="资源文件基本
264.*在jsp页面是用<s:text name=""/>标签来输出国际化信息 name为资源文件中的key
265.*在action中可以继承ActionSupport 是用getTest()方法得到国际化信息名"/> 第一个参
266.
267.数为资源文件中key
268.*在表单标签中,通过key属性指定资源文件中的key 如:<s:textfeild name="" key=""/>
269.
270.有占位符的表示:
271.welcome={0},欢迎光临!{1}
272.*在jsp页面:
273.<s:text name="welcome">
274. <param><s:property value="realname"/></s:param>
275. <param>学习</param>
276.</s:text>
277.*在action类中:
278.getTest(String key,String[] args)或者是getText(String aTextName,List args)方法
279.
280.二、包范围
281.在包下放置package_language_country.properties资源文件 package为固定写法
282.该包及子包下的action毒可以访问该资源 系统会先找包资源文件 找不到则找系统资源
283.
284.中的key
285.
286.三:action范围
287.在action所在路径放置ActionClassName_language_country.properties的资源文件
288.
289.无需任何配置直接从资源文件中获取配置:利用标签
290.<s:i18n name="资源文件名"> 全局
291. <s:text name="welcome">
292. <param>小张</param>
293. </s:text>
294.</s:i18n>
295.<s:i18n name="路径.package">从包中
296. <s:text name="welcome">
297. <param>小张</param>
298. </s:text>
299.</s:i18n>
300.<s:i18n name="路径.ActionName">action
301. <s:text name="welcome">
302. <param>小张</param>
303. </s:text>
304.</s:i18n>
305.
306.16.OGNL表达式语言
307.类静态方法调用格式:
308.@类名(包括路径)@方法名
309.
310.OGNL Context(ActionContext)访问上下文中的对象:session、request、application、
311.
312.attr、parameters、OgnlValueStack
313.访问对象格式:#session、#request
314.访问对象属性格式:#session.userName或者#session['userName']
315.其中OgnlValueStack root变量无需#,他访问对象属性时从栈顶开始找
316.需配合struts2才能使用,也可以用EL表达式(只能访问值栈中的属性)直接访问对象的属性
317.
318.17.常用标签使用
319.*构造list对象:
320.<s:set var="list" value="{'1','2','3'}"/>
321.
322.*迭代list:此标签迭代时将当前对象放到栈顶
323.<s:iterator value="#list">
324. <s:property/>
325.</s:iterator>
326.
327.*构造map对象:
328.<s:set var="maps" value="#{'key1':90,'key2':20}"/>
329.*迭代map:
330.<s:iterator value="#maps" status="obj">
331. <s:property value="key"/>=<s:property value="value"/>
332.</s:iterator>
333.obj包含方法:
334.int getCount();返回当前迭代了几个元素
335.int getIndex();返回当前迭代元素的索引
336.boolean isEven();返回当前使用元素索引是否为偶数
337.boolean isOdd();返回当前元素的索引是否为奇数
338.boolean isFirst();
339.boolean isLast();
340.
341.*判断元素是否在集合中:
342.<s:if test="foo" in/not in {"foo","tar"}>
343.在
344.</s:if>
345.<s:else>
346.不在
347.</s:else>
348.
349.*投影 在大集合中过滤数据放到小集合 例:Book对象
350.?表示获取符合逻辑的元素
351.^获取符合逻辑的第一个元素
352.$获取符合逻辑的最后一个元素
353..{}表示从大集合中筛选到小集合
354.<s:iterator value="books.{?#this.price>35}">
355. <s:property value="title"/>==<s:property value="price"/>
356.</s:iterator>
357.
358.*URL标签
359.<s:url action="" namespace="">
360. <param name="" value=""/>
361.</s:url>
362.
363.<s:set name="myurl" value="www.baidu.com"/>
364.<s:url id="url" action="hello">
365. <s:param name="request_locale">en</s:param>
366.</s:url><s:a href="%{url}">English</s:a>
367.如果href="#myurl" 他会把他当做字符处理 要这样:
368.<s:a href="%{#myurl}"/>
369.
370.*复选框 集合list和集合map
371.集合list
372.<s:checkboxlist name="list" list="{'java','c#','c++'}" value="{'java','c#'}"/>
373.value属性用于指定被选择的复选框
374.
375.集合map
376.<s:checkboxlist name="map" list="#{1:'java',2:'c#'}" listKey="key"
377.
378.listValue="value" value="{1,2,3}"/>
379.
380.*单选框
381.集合JavaBean
382.<s:radio name="beans" list="#request.persons" listKey="personid"
383.
384.listValue="name"/>
385.集合list
386.<s:radio name="list" list="{'java','c#'}" value="java"/>
387.集合map
388.<s:radio name="map" list="#{1:'java',2:'c#'}" listKey="key" listValue="value"
389.
390.value="1"/>
391.
392.*下拉列表框
393.<s:select name="list" list="{'java','c#'}" value="java"/>
394.<s:select name="beans" list="#request.persons" listKey="personid"
395.
396.listValue="name"/>
397.<s:select name="map" list="#{1:'java',2:'c#'}" listKey="key" listValue="value"
398.
399.value="1"/>
400.
401.18:防止表单重复提交
402.<s:form actio="" namespace="" method="post"?
403. <s:textfield name="name"/>
404. <s:soken/>
405. <input type="submit" value="提交"/>
406.</s:form>
407.引入拦截器
408.<interceptor-ref name="defaultStack"/>
409.<interceptor-ref name="token"/>
410.<result name="invalid.token">index.jsp</result>///发现表单重估提交时返回视图
详细参照:http://yangzhibin-java.iteye.com/blog/440811
http://blog.csdn.net/yaosan109901/archive/2009/08/25/4481375.aspx
分享到:
相关推荐
基于STM8单片机的编程实例,可供参考学习使用,希望对你有所帮助
Matlab遗传优化算法等算法 求解 生鲜配送问题 路径优化 时间窗 新鲜度 损成本 等约束 程序+算法+参考文献
计算机组成原理课程设计任务书 2021-3-1修订版1
单向辐射ugr模型 包含单向辐射电场模,上下表面辐射损耗,能带,q因字。
光伏锂电池储能功率协调控制系统仿真 [1]左侧光伏Boost控制部分:采用扰动观察法来进行MPPT最大功率跟踪,其中可以改变光照和温度模拟环境工况阶跃: [2]锂电池双向Buck_Boost:采用双闭环控制策略,给定负载电压外环,电流内环,通过稳定负载电压从而控制电流进行充放电 [3]负载电压能够稳定在设定值48V,锂离子电池对功率进行功率协调补偿 仿真运行工况模式: (1)当外界光照变弱,光伏输出功率不能满足负载所需功率,储能会放电进行补偿功率 (2)当外界光照变强,光伏输出功率超过负载所需功率,多余的功率储能会充电进行储存
激光熔覆数值模拟 COMSOL仿真 双椭球热源 采用双椭球热源模型,考虑材料热物性参数、相变、马兰戈尼效应、布辛涅斯克近似等,动网格模拟熔覆层,计算瞬态温度场和流场。
multisim学习Multisim2001电路设计及仿真入门与应用附带光盘含大量实例提取方式是百度网盘分享地址
HFI高频注入仿真 直接转矩控制,滑模观测器MATLAB仿真模型
拿来就用的张定友标定法实验报告,特别详细和完整 一、实验目的 3 二、实验器材 3 三、 张正友标定法原理 3 四、实验步骤 4 4.1 整体流程 4 4.2图像采集 4 4.3特征点提取 5 4.4相机标定 5 4.5畸变校正 6 五、 实验结果 6 5.1 内参矩阵K 6 5.2 畸变系数D 7 5.3 外参矩阵 和 7 5.4 标定误差的计算 8 六、实验结论 9 6.1标定结果的准确性与图像数量密切相关 9 6.2标定图像的分布与角度多样性对标定结果的影响 9 6.3重投影误差的评估 9 6.4畸变系数的准确性 9 6.5OpenCV 工具的使用简便性: 9 七、参考文献 10 八、附件 11
内容概要:本篇文章基于 Flask 框架讲解了一个具体的 API 接口实现方法,该接口用于触发特定ID关联的应用程序运行流程(利用Docker容器执行指定的应用Python脚本)。具体地,在接收 POST 请求之后,根据提供的应用ID来检索对应应用程序的相关路径、镜像名称与主脚本的位置等信息,并且尝试将应用程序目录及其相关联的数据目录挂载进一个临时创建出来的docker环境内以运行主要入口脚本,整个执行过程限定在一小时内完成。一旦成功则把结果以 JSON 包的形式发送回客户端,若是出现错误情况,如找不到对应的 App 或者在执行时发生异常或是超出了时限都将给予相应的JSON报错回复。 适用人群:有一定网络编程以及 Flask 框架使用基础的人群,特别是有志于深入研究 Python 网络服务器构建,掌握如何集成外部组件或容器化应用程序来提升业务处理能力的学生或者是工程师。 使用场景及目标:为用户提供一种简易但实用的方式让 Flask Web 应用可以异步地调用位于远端或本地机器上的 Docker 容器内的脚本来开展某些任务,如进行长时间的数据处理作业或是调用第三方工具等。
HFI高频方波注入方案stm32f405 无感FOC控制 直接闭环启动 永磁同步电机无感控制,0速带载启动,堵转保持扭矩 低速HFI, 高速SMO,全速域运行。 基于stm32f405。 高频注入零速启动三步走: 1 .先是高频注入,角度估算收敛。 2.脉冲NS磁极辨识。 3 .角度,速度双闭坏零速启动运行。 包括完整的cubemx配置文件,mdk工程,原理图和开发笔记,初始角度检测仿真,代码全C语言,宏定义选项均有中文注释,方便我植到自己的项目中。 内涵升级版hfi程序和新的foc程序框架,新版hfi程序速度波动更小。
数据来源:基于上市公司公告、年报等相关数据整理计算 数据范围:沪深京上市公司A股,包括主板、中小企业板、创业板、科创板、北京证交所服务板块等 数据详情: https://blog.csdn.net/yushibing717/article/details/144893810 包含六大类数据: 1、上市公司研究报告发布机构关联表20010101-20240929: ReportID [研究报告编码] - 自动生成的一组序列 Title [标题] - 研究报告的标题 DeclareDate [发布日期] - 研报对外发布日期 InstitutionName [发布机构名称] - 如果一个研报对应多个发布机构,分多条录入 2、上市公司研究报告分类关联表20010101-20240929: 3、上市公司研究报告基本信息20010101-20240929 4、上市公司研究报告人员关联表20010101-20240929 5、上市公司研究报告行业关联表20060703-20240929 上市公司研究报告证券关联表20010101-20240929.......
基于STM8单片机的编程实例,可供参考学习使用,希望对你有所帮助
基于STM8单片机的编程实例,可供参考学习使用,希望对你有所帮助
GEC6818 人脸检测
基于STM8单片机的编程实例,可供参考学习使用,希望对你有所帮助
内容概要:本文档是一份详尽的轨道交通信号与控制专业的综合实验指导手册,涵盖了五个主要实验项目,旨在帮助学生深入理解和实践轨道交通领域的关键技术。具体内容包括ZPW-Z000轨道电路信号的FSK调制与解调、机车信号噪声干扰、应答器报文编制与CRC校验。每个实验详细介绍了目的、原理、任务及实验步骤,同时提供了实验报告要求。通过这些实验,学生们能够全面了解和掌握轨道交通信号系统的工作机制和核心技术。 适用人群:高等院校电气与控制工程学院的本科生、研究生,以及从事轨道交通信号与控制系统研究的技术人员。 使用场景及目标:适用于课堂教学、实验课程和研究项目,帮助学生和研究人员掌握轨道电路信号的FSK调制与解调技术,理解噪声对机车信号的影响及应对措施,熟悉应答器报文的设计与CRC校验机制。目标是提高学生的动手能力、实验技能和理论素养,培养他们解决实际问题的能力。 其他说明:该实验手册不仅为学生提供了详细的实验指南,还为教师和实验技术人员提供了一套科学的教学和实验工具,有助于提升教学质量。同时,这些实验也为未来的研究和发展打下了坚实的基础。
基于 OpenCV 和 Angular Velocity 读数的高精度算法,该算法可以从五个不同的视频中重现汽车的方向盘角度。
简易高考志愿填报辅助工具(含源码与说明).zip [资源说明] 1、该项目是团队成员近期最新开发,代码完整,资料齐全,含设计文档等 2、上传的项目源码经过严格测试,功能完善且能正常运行,请放心下载使用! 3、本项目适合计算机相关专业(人工智能、通信工程、自动化、电子信息、物联网等)的高校学生、教师、科研工作者、行业从业者下载使用,可借鉴学习,也可直接作为毕业设计、课程设计、作业、项目初期立项演示等,也适合小白学习进阶,遇到问题不懂就问,欢迎交流。 4、如果基础还行,可以在此代码基础上进行修改,以实现其他功能,也可直接用于毕设、课设、作业等。 5、不懂配置和运行,可远程教学 6、欢迎下载,沟通交流,互相学习,共同进步!