初识struts

我们在maven入门的基础上,再来学习一下struts,
利用struts完成book的增删查改以及图片上传

完成maven流程,创建项目,环境搭建。我们需要在配置一下pom.xml

<dependency>
			<groupId>org.apache.struts</groupId>
			<artifactId>struts2-core</artifactId>
			<version>2.5.13</version>
		</dependency>

使用框架,需要把它的配置文件导进去,如下图
在这里插入图片描述

框架里面写了很多方法
在这里插入图片描述
这里为了开发方便,分成了三个
今天的第一个重点,动态方法调用
因此我们的struts-base.xml中,必须配置
(2.5版本以后)

<package name="base" extends="struts-default" abstract="true">
		<global-allowed-methods>regex:.*</global-allowed-methods>
	</package>

同时这五项配置也必须添加

<constant name="struts.i18n.encoding" value="UTF-8" />
	<constant name="struts.devMode" value="true" />
	<constant name="struts.configuration.xml.reload" value="true" />
	<constant name="struts.i18n.reload" value="true" />
	<constant name="struts.enable.DynamicMethodInvocation" value="true" />

否则失效
至于配置详细解释,我们可以在struts.xml的Action配置详解中参见
当然为了防止配置文件冲突,引入了packge包的概念,可以通过将Action进行分类,进行配置。
在这里插入图片描述
由图可知,它也引入了extends,目的是为了继承我们的packge,继承com.xx,在配置文件写的代码,必然属于xx包下。
使用框架,导了jar包,导了配置文件,还要配置核心类,

<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
         version="3.1">
  <display-name>Archetype Created Web Application</display-name>
  <filter>
  	<filter-name>Struts</filter-name>
  	<filter-class>org.apache.struts2.dispatcher.filter.StrutsPrepareAndExecuteFilter</filter-class>
  </filter>
  <filter-mapping>
  	<filter-name>Struts</filter-name>
  	<url-pattern>*.action</url-pattern>
  </filter-mapping>
</web-app>

好了,struts环境搭建完毕
2.动态方法 调用
struts与mvc类似,但它比mvc强大之处在哪里呢
就是这个不继承也能动态方法调用
我们用代码展示一下:
写一个自控制器,里面方法

package com.ly.web;

import com.opensymphony.xwork2.ActionSupport;

public class HelloAction /*extends ActionSupport*/ {
public String add() {
	System.out.println("调用add方法。。。。");
	return "rs";
}
public String del() {
	System.out.println("调用del方法。。。。");
	return "rs";
}
}

配置:

<action name="/demo_*" class="com.ly.web.HelloAction" method="{1}">
		<result name="rs">/rs.jsp</result>
		</action>

然后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>Insert title here</title>
</head>
<body>
<h3>动态方法调用</h3>
<a href="${pageContext.request.contextPath }/sy/demo_add.action">新增</a>
<a href="${pageContext.request.contextPath }/sy/demo_del.action">删除</a>
</body>
</html>
<%@ 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>Insert title here</title>
</head>
<body>
结果页
</body>
</html>

测试:
在这里插入图片描述
当我们点击新增方法时,调用add方法
在这里插入图片描述
返回结果页
在这里插入图片描述
点击删除方法
调用删除方法
在这里插入图片描述
返回结果页
在这里插入图片描述
当然这种动态调用方法,虽然效率高,但有一个缺点就是安全性比较低,我们可以直接通过地址栏看到方法名
在这里插入图片描述
来讲我们的第二个重点,
jsp传递参数到后台,后台如何接受
a.implements modelDrivern
b.set/get
c.类实例.属性名
演示一下:
首先写一个实体类:

package com.ly.entity;

public class Cal {
private String num1;
private String num2;
public String getNum1() {
	return num1;
}
public void setNum1(String num1) {
	this.num1 = num1;
}
public String getNum2() {
	return num2;
}
public void setNum2(String num2) {
	this.num2 = num2;
}
@Override
public String toString() {
	return "Cal [num1=" + num1 + ", num2=" + num2 + "]";
}

}

子控制器:

package com.ly.web;

import com.ly.entity.Cal;
import com.opensymphony.xwork2.ActionSupport;
import com.opensymphony.xwork2.ModelDriven;

public class HelloAction implements ModelDriven<Cal> {
	private Cal cal1 = new Cal();
	private Cal cal2;
	private String sex;
	
public Cal getCal2() {
		return cal2;
	}
	public void setCal2(Cal cal2) {
		this.cal2 = cal2;
	}
	public String getSex() {
		return sex;
	}
	public void setSex(String sex) {
		this.sex = sex;
	}
public String add() {
	System.out.println("调用add方法。。。。");
	return "rs";
}
public String del() {
	System.out.println("调用del方法。。。。");
	return "rs";
}
/**
 * implements modelDrivern接受参数值
 * @return
 */
public String accept1() {
	System.out.println("cal1:"+cal1);
	return "rs";
}
/**
 * 类实例.属性名 接受参数值
 * @return
 */
public String accept2() {
	System.out.println("cal2:"+cal2);
	return "rs";
}
/**
 * set/get 接受参数值
 * @return
 */
public String accept3() {
	System.out.println(sex);
	return "rs";
}
@Override
public Cal getModel() {
	return cal1;
}
}

jsp页面:

<h3>后台接受jsp传递参数的三种方式</h3>
<a href="${pageContext.request.contextPath }/sy/demo_accept1.action?num1=20&&num2=5">accept1</a>
<a href="${pageContext.request.contextPath }/sy/demo_accept2.action?cal2.num1=20&&cal2.num2=5">accept2</a>
<a href="${pageContext.request.contextPath }/sy/demo_accept3.action?sex=nv">accept3</a>

测试:
在这里插入图片描述
在这里插入图片描述
我们可以得知:
jsp传递参数到后台
有三种方法:
implements modelDrivern
set/get
类实例.属性名
都可以接收
3.后台传递到jsp的方式
有两种:
1.set/get定义的属性是可以接收到的
比如之前jsp传递参数到后台,第一种不可以接收,而第二种,第三中中有set/get方法可以接受
如下图:
在这里插入图片描述
第一种不可以:
在这里插入图片描述
第二种:
在这里插入图片描述
第三种;
在这里插入图片描述
2.req.的形式
代码:

public class HelloAction implements ModelDriven<Cal>,ServletRequestAware {
	private HttpServletRequest req;
public void setServletRequest(HttpServletRequest req) {
	this.req = req;
}
public String accept1() {
	System.out.println("cal1:"+cal1);
	req.setAttribute("cal1", cal1);
	return "rs";
}

测试:
由图可知:我们的第一种方法通过req可以接受jsp传递参数了
在这里插入图片描述
当然我们也可以获取response接口
同样的方法

与J2EE容器交互
1 非注入
2 耦合
ServletActionContext

2 解耦(建立使用解耦模式)
          ActionContext

注入
1 耦合
2解耦
这里面的注入解耦我们一般不用,因为一般很难获取到它的参数,比较麻烦。
上面的一种是注入的耦合。
非注入的耦合
直接在方法内用:

public String accept1() {
	System.out.println("cal1:"+cal1);
//	req.setAttribute("cal1", cal1);
	HttpServletRequest request = ServletActionContext.getRequest();
	request.setAttribute("cal1", cal1);
	return "rs";
}

非注入解耦形式:

public String accept1() {
	System.out.println("cal1:"+cal1);
//	req.setAttribute("cal1", cal1);
	//非注入耦合
	HttpServletRequest request = ServletActionContext.getRequest();
	request.setAttribute("cal1", cal1);
	![在这里插入图片描述](https://img-blog.csdnimg.cn/201906262049007.png)
	//非注入解耦形式
//	ActionContext context = ActionContext.getContext();
//	context.get("xxxx");
	return "rs";
	
}
 当然,我们在开发中,一般使用的是注入耦合方法。
《C++编程实例100篇》是一本深入实践、极具价值的编程教程,它针对C++编程语言提供了丰富的实例,旨在帮助读者更好地理解和掌握C++的各项特性与编程技巧。这本书的经典之处在于它将理论与实践相结合,通过100个精心设计的编程实例,覆盖了C++的各个核心领域,包括基础语法、面向对象编程、模板、异常处理、STL(标准模板库)等。 我们来探讨C++的基础语法。C++是C语言的增强版,它保留了C语言的高效性和灵活性,并引入了类、对象和继承等面向对象编程概念。基础语法包括变量声明、数据类型、运算符、控制结构(如if语句、for循环、while循环)、函数的定义和调用等。在实例中,你可能会遇到如何编写简单的程序,如计算两个数的和,或者实现一个简单的猜数字游戏。 C++的面向对象编程是其一大特色。通过类和对象,你可以构建复杂的软件系统。类是对象的蓝图,它定义了对象的属性和行为。实例化一个类,就是创建一个具体的对象。继承允许你创建新的类,这些类从现有的类派生,共享其属性和方法,同时可以添加新的功能。多态性是面向对象的另一个关键特性,它使得不同类型的对象可以对同一消息作出不同的响应。这些概念在实例中会以各种形式展现,例如设计一个图形界面的类层次,或实现一个简单的模拟游戏。 接下来是模板,C++的模板功能让代码更加通用,可以处理不同类型的数据。模板分为函数模板和类模板,前者可以创建泛型函数,后者可以创建泛型类。通过模板,你可以编写出高效且灵活的代码,比如实现一个通用的排序算法。 异常处理是C++中用于处理程序运行时错误的机制。当程序出现异常情况时,可以抛出一个异常,然后在适当的点捕获并处理这个异常。这使得代码能够优雅地处理错误,而不是让程序崩溃。实例中可能会有涉及文件操作或网络通信时可能出现的异常处理示例。
一、毕业设计的技术背景和设计依据 计算机硬盘驱动器作为一种存储数据信息的设备,在目前的计算机系统中起着不可替代的作用,读写的快慢对整个计算机系统的性能无疑占有重要地位。硬盘式电子计算机磁记录机构中最为精密的一类微机电系统设备,它对振动的敏感性是由其结构决定的,而其控制尚未很好的解决,针对硬盘展开建模及控制有着重要的实际应用价值。 二、毕业设计的任务 现代硬盘一般有 1 - 5 个盘片,以常见的 3.5 英寸硬盘为例,盘片直径约为 95mm,厚度约为 0.635mm。磁头数量通常与盘片数量相关,每面盘片有一个磁头,比如一个 3 盘片的硬盘就有 6 个磁头。缓存大小可能为 32MB、64MB 或 128MB 等,如某普通硬盘缓存为 64MB,电机功率一般在 2 - 5W,像转速为 7200RPM(转每分钟)的电机功率约 3W。数据写入时,磁头在电机带动下,以平均寻道速度约 10 - 15m/s 定位磁道。以一块顺序写入数据的硬盘为例,当写入连续大文件,如 1GB 的视频文件时,在 SATA3.0 接口下,理论传输带宽为 6Gb/s(约 750MB/s),实际可达 500 - 600MB/s。读取时,磁头感应盘片磁场变化,如读取小文件(1MB 大小),若磁头寻道距离平均为 1000 个磁道,每次寻道时间约 8 - 12ms,读取速度会因寻道而下降到 10 - 20MB/s。 本设计选取硬盘驱动器作为研究对象,假设电机扭矩为 0.3N・m,盘片转动惯量为 0.003kg・m²,轴承摩擦力矩为 0.03N・m。在稳定旋转阶段,转速波动范围设为额定转速的 ±0.5%,即 ±36RPM。首先通过对该系统分析建立了其物理模型,然后针对以音圈电机作为伺服机构的硬盘磁头定位伺服系统的性能要求,对音圈电机的控制设计采用三种控制器方案,即极点配置法、PID控制方法、线性二次型调节器方法,分别比较分
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值