简单web网页与SSM后台交互
简单web网页与SSM后台交互
情况说明
如今,已经搭建好SSM后台开发环境,并且可以经由postman工具测试成功。现在尝试写出web前端网页,通过实现简单的提交、注册、查询功能来加深对前后端数据传输格式、接口设置等理解。
编程思路
大体的思路得正确,为实现以上需求,首先需要确定的是,主要编写简单网页的方式是通过js实现点击按钮向后台发送get或post请求。
实现结果

由于笔者前端js语言应用经验较少,首先在网上找到简单网页的代码模板,如下:
test.html
<!DOCTYPE html>
<html>
<head>
<title></title>
<meta charset="utf-8" />
<script type="text/javascript" src="https://ajax.aspnetcdn.com/ajax/jQuery/jquery-1.8.0.js"></script>
<script type="text/javascript" src="submit.js"></script>
</head>
<body>
<form name="myform" method="post">
<label for="user">用户名</label>
<input type="text" id="user" name="user" value="d">
<br />
<label for="password">密码</label>
<input type="password" id="password" name="password" value="d">
<br />
<label for="user">原名</label>
<input type="realName" id="realName" name="realName" value="lallll">
<br />
<input type="button" id="submit" name="submit" value="登录" onclick="Submit()">
<input type="button" id="signUp" name="signUp" value="注册" onclick="SignUp()">
<br />
<label for="user">用户id</label>
<input type="text" id="userId" name="userId" value="6">
<br />
<input type="button" id="query" name="query" value="查询" onclick="Query()">
</form>
</body>
整个代码结构还是比较清晰的,就是最基本的html结构,需要注意的是在head部分引入了两个src。针对以上代码做一点说明:
- 其中一个是在线引用jQuery。jQuery是一个快速、简洁的JavaScript框架。它封装JavaScript常用的功能代码,提供一种简便的JavaScript设计模式,优化HTML文档操作、事件处理、动画设计和Ajax交互。总而言之,jQuery可以帮助你更加方便的实现js发送get或post请求
- 另外一个是引入submit.js。submit.js是另一个文件,主要负责具体实现get或post请求。
- 在input/button标签或者需要发送数据的地方,增加一个onclick的属性,这些方法在submit.js中实现。
submit.js
function Submit() {
console.log($('#user').val(),$('#password').val());
var jsonData={
"userId":4,
"userName":$('#user').val(),
"passWord":$('#password').val(),
"realName":"d"
}
$.ajax({
type: "POST",
dataType: "json",
url: "http://localhost:8889/user/enterUser",
contentType: 'application/json',
data: JSON.stringify(jsonData),
success: function () {
alert('Bingo!')
},
error: function () {
alert("Bad!");
submitted = false;
}
});
}
function Query() {
console.log($('#userId').val());
$.ajax({
type: "GET",
url: "http://localhost:8889/user/getUser/"+$('#userId').val(),
success: function (data) {
alert(data.userId+" "+data.userName +" "+data.passWord+" "+data.realName)
alert("Bingo!")
},
error: function () {
alert("Bad");
}
});
}
//注册功能测试时,需要改一下用户名(相同用户名不能再注册)
function SignUp() {
console.log($('#userId').val());
var jsonData={
"userName":$('#user').val(),
"passWord":$('#password').val(),
"realName":$('#realName').val()
}
$.ajax({
type: "POST",
url: "http://localhost:8889/user/addUser",
dataType: "json",
contentType: 'application/json',
data: JSON.stringify(jsonData),
success: function () {
alert("Bingo!")
},
error: function () {
alert("Bad");
}
});
}
对以上代码做几点说明:
- 以上三个方法的实现有很多相似之处,大体框架是一样的。
- 编程小技巧:console.log($('#userId').val())可以把需要观察的值写在日志里,在浏览器端F12就可以在控制台看到
- 针对具体运行结果是走success还是error,主要看发送get或post请求后,后台返回的状态码(是OK还是NOT_FOUND)。另外success中function括号中可能包含的data只是接受返回的数据,名字无所谓的。比如Submit.js对应的后台登录代码:
//返回类型是ResponseEntity(可以添加HttpStatus状态码)
@RequestMapping(value="enterUser", method={RequestMethod.POST, RequestMethod.GET})
public ResponseEntity<User> EnterUser(@RequestBody User user){
System.out.println(user);
User check_userName = userService.check(user);
if (check_userName == null)
return new ResponseEntity<>(HttpStatus.NOT_FOUND);
return new ResponseEntity<>(userService.EnterUser(user), HttpStatus.OK);
}
bug说明(本次练习遇到两次靠自己没能解决的bug,好在得到师兄的帮助解决了)
- 首先的问题是码完test.html和submit.js后,双击test.html运行,结果在chrome上显示如图:

在Firefox上显示如图:
可以得到结论,火狐浏览器在开发者角度上很不错,尤其在针对国内开发者。两个浏览器都显示是跨域请求出现了问题,在网上找了一遍,很多解决办法,但是好像都挺复杂的。尝试了其中一种,安装chrome插件 Allow-Control-Allow-Origin: *,同样也给Firefox安上插件,然并卵。
最终解决办法是把test.html和submit.js放到后台框架SSM的resource资源文件中(如此便在一个域中),如此在浏览器端输入localhost:8889/test.html即可访问成功
- 第二个bug是在码完Query方法时出现,无法正常返回user信息。找了半天,不知道问题在哪。
最终解决办法是发现是后台出现了问题,后台并没有返回user对象,而是简单返回了一个字符串。所以前后端对接乃至接口设置都至关重要。<后台背锅呀!>
简单web网页与SSM后台交互的更多相关文章
- Ztree的简单使用和后台交互的写法(二)
针对Ztree的简单使用和后台交互的写法(一)中的树进行改进 1.增加节点的权限 由页面的当前用户,决定树的根节点 然后动态获取树的详细节点: 初始化函数为: function init(){ //初 ...
- ajax简单后台交互
ajax简单后台交互 1,扯淡 单身的生活,大部分时间享受自由,小部分时间忍受寂寞. 生活有时候,其实蛮苦涩,让人难以下咽.那些用岁月积累起来的苦闷,无处宣泄,在自己的脑海里蔓延成一片片荆棘,让你每每 ...
- java简单web爬虫(网页图片)
java简单web爬虫(网页图片)效果,执行main()方法后图片就下载道C盘的res文件夹中.没有的话创建一个文件夹代码里的常量根据自己的需求修改,代码附到下面. package com.sinit ...
- web storage 简单的网页留言版
html <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <ti ...
- 如何用CropBox实现头像裁剪并与java后台交互
如何用CropBox实现头像裁剪并与java后台交互 参考网站:https://developer.mozilla.org/zh-CN/docs/Web/API/Blob 参考: http://blo ...
- web网页练习
一. HTML部分 1. XHTML和HTML有什么区别 HTML是一种基本的WEB网页设计语言,XHTML是一个基于XML的置标语言最主要的不同: XHTML 元素必须被正确地嵌套. XHTML 元 ...
- 简单介绍几种Java后台开发常用框架组合
01 前言 Java框架一直以来都是面试必备的知识点,而掌握Java框架,不管在成熟的大公司,快速发展的公司,还是创业阶段的公司,都能对当前正在开发中的系统有整体的认知,从而更好的熟悉和学习技术,这篇 ...
- C#开发BIMFACE系列49 Web网页中加载模型与图纸的技术方案
BIMFACE二次开发系列目录 [已更新最新开发文章,点击查看详细] 在BIMFACE二次系列博客中详细介绍了服务器端API的调用方式,如下列表 C#开发BIMFACE系列1 BIMFAC ...
- 静态网页怎样实现动态交互?-JavaScript
在Html基础上,javascript能够开发交互式web网页.javascript的出现使得网页和用户之间实现了一种实时性的.动态的.交互性的关系,javascript短小精悍,又是在客户机上执行的 ...
随机推荐
- 为什么你有10年经验,但成不了专家?(重复性刻意训练+反馈修正,练习的精髓是要持续地做自己做不好的,太精彩了)真正的高手都有很强的自学能力,老师和教练的最重要作用是提供即时的反馈(莫非我从小到大学习不好的原因在这里?没有单独刻意训练?) good
也许简单看书就是没有刻意训练.更没有反馈,所以没有效果 我倒是想起自己,研究VCL源码的时候,都是自己给自己提问,然后苦思冥想.自己解决问题,然后Windows编程水平果然上了一个台阶.对什么叫做“框 ...
- 亿方云(用电话或者qq沟通是远远不够的,容易忘还不能反复催,最好的方式就是指定一个平台,团队内的人定期查看最新记录)
作者:城年链接:http://www.zhihu.com/question/20579359/answer/106319200来源:知乎著作权归作者所有,转载请联系作者获得授权. 更新,文字发完后,好 ...
- [android自动化构建]之centos安装gradle
这是android自动化构建系列之环境配置 这里只记录部分gradle相关的配置 下载并解压 下载地址参考这里:https://services.gradle.org/distributions/,未 ...
- Codility---MaxProductOfThree
Task description A non-empty zero-indexed array A consisting of N integers is given. Theproduct of t ...
- 创业游戏模拟器 Startup 游戏试玩
买的正版游戏,还在beta阶段.因为对这种经营类的游戏挺感兴趣,结合自己也是做这个行当的.算是一次性通关了吧.我来评价一下这个游戏.足足玩了有5个多小时.从1级玩到15级.解锁了所有的内容.员工从1个 ...
- 深入理解Java G1垃圾收集器
本文首先简单介绍了垃圾收集的常见方式,然后再分析了G1收集器的收集原理,相比其他垃圾收集器的优势,最后给出了一些调优实践. 一,什么是垃圾回收 首先,在了解G1之前,我们需要清楚的知道,垃圾回收是什么 ...
- justgage.js的使用
网址:http://justgage.com/ [1]需引入的文件: <!-- 引入 justGage相关js --><script src="js/raphael-2.1 ...
- Adobe cs6 全系列软件绿色破解版-一键安装
下载地址: 链接:https://pan.baidu.com/s/1THssmSS-SnyNc2DW7Wr8cA 提取码:y3tq 软件介绍 作为全球领先的多媒体设计软件供应商,Adobe Syste ...
- java中list和Arrylist的区别
List:是一个有序的集合,可以包含重复的元素.提供了按索引访问的方式.它继承 Collection. List有两个重要的实现类:ArrayList 和 LinkedList ArrayList:我 ...
- python 基本数据类型之字符串功能
字符串常用功能: # name.upper() #全部大写变小写 # name.lower() #全部小写变大写 # name.split() #分割 # name.find() #找到指定子序列的索 ...