首页 > 编程 > Java > 正文

SpringMVC前端和后端数据交互总结

2019-11-26 12:51:39
字体:
来源:转载
供稿:网友

本文主要介绍了SpringMVC前端和后端数据交互的资料,特地发出来记录一下。有需要的朋友可以了解一下。

控制器

作为控制器,大体的作用是作为V端的数据接收并且交给M层去处理,然后负责管理V的跳转。SpringMVC的作用不外乎就是如此,主要分为:接收表单或者请求的值,定义过滤器,跳转页面;其实就是servlet的替代品。

传值方式

springmvc最方便的一点就是可以通过注释方式来定义它的url。

@Controllerpublic class formMVC {  @RequestMapping("/hello")  public void login(){      }

如上面这种方式,在项目名下跟着hello就能访问这个方法了,相较struts2的xml配置加大了开发效率,并且是以方法为级别的开发。

接收表单数据只需要在方法的参数加入响应的字段,对应表单input的name属性,因为是通过反射技术实现的所以字段要完全相同。  

  @RequestMapping("/login")  public String login(String username,String password){    System.out.println(username+" "+password);    return "form.jsp";  }

如上面这种方式,表单提交之后就会获得值。跳转方式就是使用返回的字符串,springmvc的DispatcherServlet会跳转到字符串的页面。你也可以配置它的前缀后缀。在它的配置文件中配置下面属性,就是在这个return的字符串的前面和后面加入你配置的前缀后缀。

  <!-- configure the InternalResourceViewResolver -->  <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"       id="internalResourceViewResolver">    <!-- 前缀 -->    <property name="prefix" value="" />    <!-- 后缀 -->    <property name="suffix" value="" />  </bean>

另外,springmvc可以使用bean来接收参数,因为是反射技术,所以属性字段依然要保持完全一样。

public class user {  private String username;  private String password;  public String getUsername() {    return username;  }  public void setUsername(String username) {    this.username = username;  }  public String getPassword() {    return password;  }  public void setPassword(String password) {    this.password = password;  }  }
@RequestMapping(value="/Model",method=RequestMethod.POST)  public String loginModel(user u){    System.out.println(u.getUsername()+" "+u.getPassword());    return "form.jsp";  }

最后,前端发过来的数据是经过json包装的,依然可以在后端使用bean来接收。

<%@ 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"><script type="text/javascript" src="jquery.min.js"></script> <title>登录表单</title></head><script type="text/javascript">   $(document).ready(function(){     $("#button_submit").click(function(){       //序列化表单元素,返回json数据       var params = $("#userForm").serializeArray();       console.log(params);      //也可以把表单之外的元素按照name value的格式存进来       //params.push({name:"hello",value:"man"});       $.ajax({        type:"post",        url:"Model",        data:params      });    });   }); </script> <body>  <form id="userForm">    <input name="username" type="text"/>    <br/>    <input name="password" type="password"/>    <br/>  </form>    <button id="button_submit">提交</button>    <button type="reset" >重置</button></body></html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持武林网。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表