Java中controller层接Map_spring-mvc中controller,前端传过来的参数,用数组,列表,Map来接受参数的方式...
时间: 2024-03-21 16:39:40 浏览: 180
在Java的Spring MVC框架中,Controller层接收前端传递的参数可以使用以下方式:
1. 使用Map来接收参数:
```java
@RequestMapping("/test")
public String test(Map<String, Object> map) {
String username = (String)map.get("username");
// ...
return "test";
}
```
2. 使用@RequestParam注解来接收参数:
```java
@RequestMapping("/test")
public String test(@RequestParam("username") String username) {
// ...
return "test";
}
```
3. 使用数组来接收参数:
```java
@RequestMapping("/test")
public String test(String[] usernames) {
// ...
return "test";
}
```
4. 使用List或者Set来接收参数:
```java
@RequestMapping("/test")
public String test(List<String> usernames) {
// ...
return "test";
}
```
注意:以上示例中的参数名和前端传递的参数名必须一致,否则无法正确接收参数。
相关问题
以idea为工具sqlyog为数据库运用spring-context,spring-tx,spring-jdbc,spring-webmvc,mybatis,pagehelper,mybatis-spring,java.servlet-api,mysql-connector-java,druid,fastjson,jackson-core,jackson-databind,jackson-annotations,tomcat7-maven-plugin依赖所写出的项目
### 项目实现概述
在使用 IDEA 和 SQLyog 开发基于上述依赖的项目时,需按照模块化设计原则合理分配功能组件并完成集成。以下是具体说明:
#### Maven 依赖配置
在 `pom.xml` 文件中引入所需的依赖项,确保各模块能够正常工作。
```xml
<dependencies>
<!-- Spring 相关 -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>5.3.10</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-tx</artifactId>
<version>5.3.10</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>5.3.10</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.3.10</version>
</dependency>
<!-- MyBatis 及其扩展 -->
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.2.0</version>
</dependency>
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
<version>5.3.0</version>
</dependency>
<!-- 数据库相关 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.26</version>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.2.8</version>
</dependency>
<!-- JSON 处理 -->
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-core</artifactId>
<version>2.13.0</version>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.13.0</version>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-annotations</artifactId>
<version>2.13.0</version>
</dependency>
<!-- Servlet API -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>4.0.1</version>
<scope>provided</scope>
</dependency>
<!-- Tomcat 插件 -->
<dependency>
<groupId>org.apache.tomcat.embed</groupId>
<artifactId>tomcat-embed-jasper</artifactId>
<version>9.0.52</version>
<scope>provided</scope>
</dependency>
</dependencies>
```
以上代码展示了如何通过 Maven 引入所需依赖[^1]。
---
#### 项目结构规划
根据引用描述,推荐如下目录结构:
- **controller**: 存储控制器层逻辑,负责接收请求和返回响应。
- **service**: 提供业务逻辑接口定义及其实现类(如 `-impl`)。
- **dao**: 使用 MyBatis 进行数据库交互的操作映射。
- **entity**: 定义与数据库表对应的实体类。
- **config**: 配置全局参数、数据源、事务管理等内容。
- **exception**: 自定义异常处理机制。
- **util**: 封装通用工具方法。
---
#### 数据源配置 (`application.properties`)
设置数据库连接池及相关参数,便于统一管理和动态调整。
```properties
# Druid 数据源配置
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8&serverTimezone=UTC
spring.datasource.username=root
spring.datasource.password=password
# MyBatis 配置
mybatis.mapper-locations=classpath:mapper/*.xml
mybatis.configuration.map-underscore-to-camel-case=true
# 分页插件配置
pagehelper.helperDialect=mysql
pagehelper.reasonable=true
pagehelper.supportMethodsArguments=true
```
此部分实现了对 MySQL 的访问支持,并启用了分页功能[^1]。
---
#### Web 应用初始化 (`web.xml`)
如果未启用 Java Config,则可通过 XML 方式声明核心组件。
```xml
<!-- 加载 Spring 上下文监听器 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/applicationContext.xml</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<!-- 字符编码过滤器 -->
<filter>
<filter-name>encodingFilter</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>encodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<!-- DispatcherServlet 映射 -->
<servlet>
<servlet-name>dispatcher</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>dispatcher</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
```
上述片段完成了基础环境搭建,包括上下文加载、编码转换以及前端控制器绑定[^3]。
---
#### 测试运行流程
利用 SQLyog 创建测试数据库及表格;随后启动 IDEA 中的应用程序入口函数验证整体连通性。
```java
@SpringBootApplication
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
```
最后部署到嵌套版 Tomcat 或独立服务器上观察效果。
---
问题
org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'webMvcRequestHandlerProvider' defined in URL [jar:file:/Users/mac/Documents/workspace/repositoryNew/io/springfox/springfox-spring-webmvc/2.10.5/springfox-spring-webmvc-2.10.5.jar!/springfox/documentation/spring/web/plugins/WebMvcRequestHandlerProvider.class]: Unsatisfied dependency expressed through constructor parameter 2; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'requestMappingHandlerMapping' defined in class path resource [org/springframework/boot/autoconfigure/web/servlet/WebMvcAutoConfiguration$EnableWebMvcConfiguration.class]: Invocation of init method failed; nested exception is java.lang.IllegalStateException: Ambiguous mapping. Cannot map 'projectClientImpl' method org.wlgs.feign.ProjectClientImpl#getRoleCodeList() to {GET /cbsNewAllprocesses/getRoleCodeList}: There is already 'cbsNewAllprocessesController' bean method org.wlgs.controller.CbsNewAllprocessesController#getRoleCodeList() mapped.
根据你提供的信息,看起来是由于Spring Boot应用程序中的Bean依赖关系问题导致的错误。具体来说,`webMvcRequestHandlerProvider` bean在构造函数参数2处存在不满足依赖的问题,导致应用程序无法启动。
检查`webMvcRequestHandlerProvider` bean的构造函数参数2的依赖项,并确保它们都已经正确地注入或配置。特别是要检查`requestMappingHandlerMapping` bean的配置是否正确,因为它在该错误中提到了。
另外,还要检查应用程序中是否存在重复的映射,如错误信息中的`getRoleCodeList`方法,确保所有映射都是唯一的。
希望这可以帮助你解决问题。
阅读全文
相关推荐













