클라이언트 요청 매개변수의 형식은 다음과 같습니다. name=value&name=value... 서버 측은 요청된 매개변수를 가져와야 하며 때로는 데이터를 캡슐화해야 합니다. SpringMVC는 다음을 수신할 수 있습니다. 매개변수 유형 :
Controller의 비즈니스 메소드 매개변수 이름은 요청 매개변수 이름과 일치해야 하며 매개변수 값은 자동으로 매핑 및 일치됩니다.
//http://localhost:8080/project/quick9?username=zhangsan&age=12 @RequestMapping("/quick9") @ResponseBody public void quickMethod9(String username,int age) throws IOException { System.out.println(username); System.out.println(age); }
Controller의 비즈니스 메소드 POJO 매개변수 속성 이름이 요청 매개변수 이름과 일치하며 매개변수 값이 자동으로 매핑되어 일치됩니다.
//http://localhost:8080/itheima_springmvc1/quick9?username=zhangsan&age=12 public class User { private String username; private int age; getter/setter… } @RequestMapping("/quick10") @ResponseBody public void quickMethod10(User user) throws IOException { System.out.println(user); }
Controller의 비즈니스 메소드 배열 이름은 요청 매개변수 이름과 일치하며, 매개변수 값은 자동으로 매핑되어 일치됩니다.
//http://localhost:8080/project/quick11?strs=111&strs=222&strs=333 @RequestMapping("/quick11") @ResponseBody public void quickMethod11(String[] strs) throws IOException { System.out.println(Arrays.asList(strs)); }
컬렉션 매개변수를 얻을 때 컬렉션 매개변수를 POJO로 패키징해야 합니다.
<form action="${pageContext.request.contextPath}/quick12" method="post"> <input type="text" name="userList[0].username"><br> <input type="text" name="userList[0].age"><br> <input type="text" name="userList[1].username"><br> <input type="text" name="userList[1].age"><br> <input type="submit" value="提交"><br> </form>
@RequestMapping("/quick12") @ResponseBody public void quickMethod12(Vo vo) throws IOException { System.out.println(vo.getUserList()); }
ajax를 사용하여 제출할 때 contentType을 json으로 지정한 다음 메소드 매개변수 위치에 @RequestBody를 사용하면 패키징에 POJO를 사용하지 않고 직접 컬렉션 데이터를 받을 수 있습니다.
<script> //模拟数据 var userList = new Array(); userList.push({username: "zhangsan",age: "20"}); userList.push({username: "lisi",age: "20"}); $.ajax({ type: "POST", url: "/itheima_springmvc1/quick13", data: JSON.stringify(userList), contentType : 'application/json;charset=utf-8' }); </script>
@RequestMapping("/quick13") @ResponseBody public void quickMethod13(@RequestBody List<User> userList) throws IOException { System.out.println(userList); }
참고: Google 개발자 도구 패킷 캡처를 통해 jquery 파일이 로드되지 않은 것으로 확인되었습니다. 그 이유는 SpringMVC 프런트엔드 컨트롤러 DispatcherServlet의 url-pattern이 /로 구성되어 있기 때문입니다. 이는 모든 리소스를 의미합니다. 다음 두 가지 방법을 사용하여 정적 리소스 해제를 지정합니다. • spring-mvc에서 해제된 리소스를 지정합니다.
게시 요청 시 데이터가 왜곡됩니다. web.xml을 사용하여 인코딩을 필터링합니다.<mvc:resources mapping="/js/**" location="/js/"/>
<!--资源过滤器--> <filter> <filter-name>CharacterEncodingFilter</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>CharacterEncodingFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
값:
필수: | 지정된 요청 매개변수인지 여부 필수 또는 포함 아님, 기본값은 true입니다. 제출 시 해당 매개변수가 없으면 오류가 보고됩니다 |
defaultValue: | 요청 매개변수가 지정되지 않으면 지정된 기본값이 할당에 사용됩니다 |
4. Restful 스타일 매개변수 얻기 |
GET:
삭제: | 리소스 삭제 |
PUT: | 리소스 업데이트 |
POST: | 새 리소스 |
/user/1인 사용자 가져오기 삭제: |
user인 업데이트 사용자 POST: | |
1 위의 URL 주소에서 /user/1은 요청 매개변수입니다. SpringMVC에서는 매개변수 바인딩에 자리 표시자를 사용할 수 있습니다. 주소 /user/1은 /user/{id}로 쓸 수 있으며 자리 표시자 {id}는 값 1에 해당합니다. 비즈니스 메서드에서는 @PathVariable 주석을 사용하여 자리 표시자 일치를 얻을 수 있습니다. | |
SpringMVC는 매개변수 설정을 위해 클라이언트가 제출한 문자열을 int 유형으로 변환하는 등 일반적으로 사용되는 일부 유형 변환기를 기본적으로 제공합니다. | |
그러나 모든 데이터 유형이 변환기를 제공하는 것은 아닙니다. 그렇지 않은 경우 변환기를 사용자 정의해야 합니다. 예를 들어 날짜 유형 데이터에는 사용자 정의 변환기가 필요합니다. |
① Converter 인터페이스를 구현하기 위한 변환기 클래스 정의
//http://localhost:8080/itheima_springmvc1/quick19/zhangsan @RequestMapping("/quick19/{name}") @ResponseBody public void quickMethod19(@PathVariable(value = "name",required = true) String name){ System.out.println(name); }
public class DateConverter implements Converter<String, Date> { @Override public Date convert(String source) { SimpleDateFormat format=new SimpleDateFormat("yyyy-MM-dd"); Date date = null; try { date = format.parse(source); } catch (ParseException e) { e.printStackTrace(); } return date; } }
<!--配置自定义转换器--> <bean id="conversionService" class="org.springframework.context.support.ConversionServiceFactoryBean"> <property name="converters"> <list> <bean class="converter.DateConverter"/> </list> </property> </bean>
6. 요청 헤더 가져오기
@RequestHeader를 사용하여 웹 단계에서 학습한 request.getHeader(이름)과 동일한 요청 헤더 정보를 가져옵니다. 주석은 다음과 같습니다:
value요청 헤더의 이름required이 요청 헤더를 운반해야 하는지 여부
@RequestMapping("/quick17") @ResponseBody public void quickMethod17(@RequestHeader(value = "User-Agent",required = false) String headerValue){ System.out.println(headerValue); }
@CookieValue
使用@CookieValue可以获得指定Cookie的值 @CookieValue注解的属性如下:
value | 指定cookie的名称 |
required | 是否必须携带此cookie |
@RequestMapping("/quick18") @ResponseBody public void quickMethod18(@CookieValue(value = "JSESSIONID",required = false) String jsessionid){ System.out.println(jsessionid); }
文件上传客户端三要素:
表单项type=“file”
表单的提交方式是post
表单的enctype属性是多部分表单形式,及enctype=“multipart/form-data”
<form action="${pageContext.request.contextPath}/quick20" method="post" enctype="multipart/form-data"> 名称:<input type="text" name="name"><br> 文件:<input type="file" name="file"><br> <input type="submit" value="提交"><br> </form>
文件上传步骤
① 在pom.xml导入fileupload和io坐标
<!--文件下载--> <dependency> <groupId>commons-fileupload</groupId> <artifactId>commons-fileupload</artifactId> <version>1.4</version> </dependency> <dependency> <groupId>commons-io</groupId> <artifactId>commons-io</artifactId> <version>2.6</version> </dependency>
② 配置文件上传解析器
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <property name="defaultEncoding" value="UTF-8"/> <property name="maxUploadSize" value="500000"/> </bean>
③ 编写文件上传代码
@RequestMapping("/quick8") @ResponseBody public void save8(String name, MultipartFile uploadfile) { System.out.println("save8 running..."); System.out.println(name); String filename = uploadfile.getOriginalFilename(); try { uploadfile.transferTo(new File("D:\\upload\\"+filename)); } catch (IOException e) { e.printStackTrace(); } }
위 내용은 SpringMVC에서 요청 데이터를 얻는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!