近年来,前后端分离成为web领域的热点话题,javascript作为前端三大核心技术之一,与后端的spring mvc、mybatis组成了一种完整的企业级开发架构,即ssm。
在这种架构下,前端通过http请求与后端进行交互,而javascript相应的技术就是Ajax。Ajax全称为Asynchronous JavaScript and XML,即异步的Javascript和XML。它支持在不重新载入整个页面的情况下与服务器交换数据并更新部分页面内容,从而提升了用户的使用体验。本文将介绍JavaScript方式提交请求SSM的实现方法。
一、前端代码
我们先来看一下前端javascript的实现代码。
在javascript中,需要先创建XMLHttpRequest对象,通过该对象发起异步请求。
立即学习“Java免费学习笔记(深入)”;
var xmlhttp;
if (window.XMLHttpRequest) {
// code for IE7+, Firefox, Chrome, Opera, Safari
xmlhttp=new XMLHttpRequest();
} else {
// code for IE6, IE5
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}通过xmlhttp对象的open方法设置请求方式、请求地址、是否异步等参数,再通过send方法发送请求。在请求的回调函数中,可以通过修改DOM元素、改变样式等方式来处理响应数据。
xmlhttp.open("GET","ajax_info.txt",true);
xmlhttp.send();
xmlhttp.onreadystatechange=function()
{
if (xmlhttp.readyState==4 && xmlhttp.status==200)
{
document.getElementById("myDiv").innerHTML=xmlhttp.responseText;
}
}二、后端代码
采用HttpClient向服务器端action请求数据,当然调用服务器端方法获取数据并不止这一种。WebService也可以为我们提供所需数据,那么什么是webService呢?,它是一种基于SAOP协议的远程调用标准,通过webservice可以将不同操作系统平台,不同语言,不同技术整合到一起。 实现Android与服务器端数据交互,我们在PC机器java客户端中,需要一些库,比如XFire,Axis2,CXF等等来支持访问WebService,但是这些库并不适合我们资源有限的android手机客户端,
0
前端处理完请求后,需要后端进行响应。在SSM架构中,后端代码使用Spring MVC框架实现,其中@ResponseBody注解可以标记一个Controller方法的返回值为json数据。
@RequestMapping(value="/getUserName",method=RequestMethod.POST)
@ResponseBody
public String getUserName(@RequestParam("userId")String userId) {
// 处理业务逻辑,获取用户名称
String userName = userService.findNameById(userId);
// 返回json格式的数据
return "{\"userName\":\"" + userName + "\"}";
}三、整合步骤
var userId = "123";
$.ajax({
type : 'POST',
url : '/ssm-demo/getUserName',
data: {"userId" : userId},
dataType : 'json',
success : function(data) {
console.log(data.userName);
}
});在后端代码中,需要引入Jackson相关库来实现json数据的的转换。
<!-- jQuery库 -->
<dependency>
<groupId>org.webjars</groupId>
<artifactId>jquery</artifactId>
<version>3.3.1</version>
</dependency>
<!-- Jackson库 -->
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.9.8</version>
</dependency>在Spring的JavaConfig文件中,需要进行如下配置:
@Configuration
@ComponentScan(basePackages="com.demo.controller")
public class AppConfig {
// ...
}在web.xml中配置DispatcherServlet,将Servlet映射到指定url。需要配置的参数有:
<servlet>
<servlet-name>demo-dispatcher</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:com/demo/config/AppConfig.java</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>demo-dispatcher</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>通过对以上步骤的整合,即可在SSM架构中实现通过Javascript方式提交请求。这种方式的优点在于,可以提升用户的使用体验,在不重新载入整个页面的情况下通过前后端异步交互,实现局部刷新,从而快速响应用户的操作。
以上就是聊聊JavaScript方式提交请求SSM的实现方法的详细内容,更多请关注php中文网其它相关文章!
java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号