SpringMVC请求参数的绑定

1. 基本类型参数

包括基本类型和String类型。要求我们的参数名称必须和控制器中方法的形参名称保持一致(严格区分大小写)。

页面代码:

<a href="account/findAccount?accountId=10&accountName=zhangsan">查询账户</a>

控制器代码:

@Controller("account")
public class AccountController {

	@RequestMapping("/findAccount")
	public String findAccount(Integer accountId, String accountName) {
		System.out.println(accountId+","+accountName);
		return "success";
	}
}

2. POJO类型参数

包括实体类,以及关联的实体类。要求表单中参数名称和POJO类的属性名称保持一致,并且控制器方法的参数类型是POJO类型。

POJO类代码:

public class Account implements Serializable {
	private Integer id;
	private String name;
	private Float money;
	private Address address;
	
	//省略 getters和 setters
}

public class Address implements Serializable {
	private String provinceName;
	private String cityName;
	//省略 getters and setters
}

页面代码:

<form action="account/saveAccount" method="post">
	账户名称: <input type="text" name="name" ><br/>
	账户金额: <input type="text" name="money" ><br/>
	账户省份: <input type="text" name="address.provinceName" ><br/>
	账户城市: <input type="text" name="address.cityName" ><br/>
	<input type="submit" value="保存">
</form>

控制器代码:

@Controller("account")
public class AccountController {

	@RequestMapping("/saveAccount")
	public String saveAccount(Account account) {
		System.out.println("保存了账户:" + account);
		return "success";
	}
}

3. 数组和集合类型参数

包括数组和List结构与Map结构的集合。要求

  • 第一种:要求集合类型的请求参数必须在POJO中,在表单中请求参数名称要和POJO中集合属性名称相同。给List集合中的元素赋值,使用下标。给Map集合中的元素赋值,使用键值对。
  • 第二种:接收的请求参数是json格式数据。需要借助@RequestBody注解实现。

POJO类代码:

public class User implements Serializable {
	private String username;
	private String password;
	private Integer age;
	private Integer[] ids
	private List<Account> accountsList;
	private Map<String,Account> accountMap;
	
	//省略 getters和 setters
}

页面代码:

<form action="account/updateAccount" method="post">
	用户名称: <input type="text" name="username" ><br/>
	用户密码: <input type="password" name="password" ><br/>
	用户年龄: <input type="text" name="age" ><br/>
	用户ids: <input type="text" name="ids" ><br/>
	用户ids: <input type="text" name="ids" ><br/>
	账户 1 名称: <input type="text" name="accountsList[0].name" ><br/>
	账户 1 金额: <input type="text" name="accountsList[0].money" ><br/>
	账户 2 名称: <input type="text" name="accountsList[1].name" ><br/>
	账户 2 金额: <input type="text" name="accountsList[1].money" ><br/>
	账户 3 名称: <input type="text" name="accountMap['one'].name" ><br/>
	账户 3 金额: <input type="text" name="accountMap['one'].money" ><br/>
	账户 4 名称: <input type="text" name="accountMap['two'].name" ><br/>
	账户 4 金额: <input type="text" name="accountMap['two'].money" ><br/>
	<input type="submit" value="保存">
</form>

控制器代码:

@Controller("account")
public class AccountController {

	@RequestMapping("/updateAccount")
	public String updateAccount(User user) {
		System.out.println("更新了账户:" + user);
		return "success";
	}
}

4. 自定义类型转换器

开发过程中我们可能还会遇到需要我们自己定义类型转换器的情况,例如前端传入了一个String类型的字符串,而接口中希望以日期类型接收该参数,如下所示:

页面代码:

<a href="account/deleteAccount?date=2018-01-01">用于把String类型转成日期类型</a>

控制器代码:

@Controller("account")
public class AccountController {

	@RequestMapping("/deleteAccount")
	public String deleteAccount(Date date) {
		System.out.println("传入的日期为:" + date);
		return "success";
	}
}

这种情况下,由于SpringMVC不能把String类型转成日期类型而报错,我们可以使用SpringMVC自定义类型转换器来进行参数的转换。

定义一个类,实现Converter接口,该接口有两个泛型,第一个表示接受的类型,第二个表示目标类型。具体如下所示:

//用于把 String类型转成日期类型
public class StringToDateConverter implements Converter<String, Date> {
	
	@Override
	public Date convert(String source) {
		DateFormat format = null;
		try {
			if(StringUtils.isEmpty(source)) {
				throw new NullPointerException("请输入要转换的日期");
			}
			format = new SimpleDateFormat("yyyy-MM-dd");
			Date date = format.parse(source);
			return date;
		} catch (Exception e) {
			throw new RuntimeException("输入日期有误");
		}
	}
}

在spring配置文件中配置类型转换器,spring配置类型转换器的机制是:将自定义的转换器注册到类型转换服务中去。

<!-- 配置类型转换器工厂 -->
<bean id="converterService" class="org.springframework.context.support.ConversionServiceFactoryBean">
	<!-- 给工厂注入一个新的类型转换器 -->
	<property name="converters">
		<array>
			<!-- 配置自定义类型转换器 -->
			<bean class="com.joker.web.converter.StringToDateConverter"></bean>
		</array>
	</property>
</bean>

<!-- 引用自定义类型转换器 -->
<mvc:annotation-driven conversion-service="converterService"></mvc:annotation-driven>

5. 使用Servlet API对象作为方法参数

SpringMVC还支持使用原始Servlet API对象作为控制器方法的参数,使用方式很简单,直接在方法参数列表中添加相应的Servlet API对象即可,如下所示:

@Controller("account")
public class AccountController {

	@RequestMapping("/testServletAPI")
	public String testServletAPI(HttpServletRequest request, HttpServletResponse response, HttpSession session) {
		System.out.println(request);
		System.out.println(response);
		System.out.println(session);
		return "success";
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQLAlchemy 是一个 SQL 工具包和对象关系映射(ORM)库,用于 Python 编程语言。它提供了一个高级的 SQL 工具和对象关系映射工具,允许开发者以 Python 类和对象的形式操作数据库,而无需编写大量的 SQL 语句。SQLAlchemy 建立在 DBAPI 之上,支持多种数据库后端,如 SQLite, MySQL, PostgreSQL 等。 SQLAlchemy 的核心功能: 对象关系映射(ORM): SQLAlchemy 允许开发者使用 Python 类来表示数据库表,使用类的实例表示表的行。 开发者可以定义类之间的关系(如一对多、多对多),SQLAlchemy 会自动处理这些关系在数据库的映射。 通过 ORM,开发者可以像操作 Python 对象一样操作数据库,这大大简化了数据库操作的复杂性。 表达式语言: SQLAlchemy 提供了一个丰富的 SQL 表达式语言,允许开发者以 Python 表达式的方式编写复杂的 SQL 查询。 表达式语言提供了对 SQL 语句的灵活控制,同时保持了代码的可读性和可维护性。 数据库引擎和连接池: SQLAlchemy 支持多种数据库后端,并且为每种后端提供了对应的数据库引擎。 它还提供了连接池管理功能,以优化数据库连接的创建、使用和释放。 会话管理: SQLAlchemy 使用会话(Session)来管理对象的持久化状态。 会话提供了一个工作单元(unit of work)和身份映射(identity map)的概念,使得对象的状态管理和查询更加高效。 事件系统: SQLAlchemy 提供了一个事件系统,允许开发者在 ORM 的各个生命周期阶段插入自定义的钩子函数。 这使得开发者可以在对象加载、修改、删除等操作时执行额外的逻辑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值