119-(AJAX)post

<!DOCTYPE html>
<html>
<head>
	<meta charset="utf-8">
	<meta name="viewport" content="width=device-width, initial-scale=1">
	<title>post</title>
	<style type="text/css">
		.info {
			color: red;
		}
	</style>
</head>
<body>
	<h2>登录</h2>

	<span>用户名:</span> <input class="username" type="text" name=""> <br>
	<span>密 码:</span> <input class="pwd" type="password" name=""> <br>

	<button>登录</button>  <br>

	<button class="user-list">用户列表</button>  <br>

	<span class="info"></span>

	<script type="text/javascript">
		// 1.先获取页面元素
		var btn = document.querySelector('button');
		var userListEleObj = document.querySelector('.user-list');
		var username = document.querySelector('.username');
		var pwd = document.querySelector('.pwd');
		var span = document.querySelector('.info');
		var globalToken = ''; // 将token存到当前页的全局变量中;
		btn.onclick = function() {
			// 1. 判断用户输入的是否合法
			if(!username.value || !pwd.value) {
				span.innerText = '用户名或密码不能为空';
				return;
			}
			console.log('是否执行');
			// 2 创建异步对象
			var xhr = new XMLHttpRequest();
			// 3.建立连接 post
			// http://124.223.98.197:10086/prod-api/login
			// xhr.open('post', 'http://wish.byesame.com/login');
			xhr.open('post', 'http://124.223.98.197:10086/prod-api/login');
			// application/x-www-form-urlencoded
			xhr.setRequestHeader('Content-type', 'application/json');
			var obj = {
				username: username.value,
				password: pwd.value
			};
			xhr.send(JSON.stringify(obj));
			xhr.onreadystatechange = function() {
				if (xhr.readyState === 4) {
					var res = JSON.parse(xhr.responseText);
					console.log(res);
					if (res.code === 200) {
						var token = 'Bearer ' +  res.token;
						globalToken = token;  // 将token存到当前页的全局变量中;
						localStorage.setItem('token', token);
						var xhrUserInfo = new XMLHttpRequest();
						xhrUserInfo.open('get', 'http://124.223.98.197:10086/prod-api/getInfo');

						xhrUserInfo.setRequestHeader('Content-type', 'application/json');
						xhrUserInfo.setRequestHeader('Authorization', token);

						xhrUserInfo.send();
						xhrUserInfo.onreadystatechange = function() {
							if (xhrUserInfo.readyState === 4) {
								var userInfo = JSON.parse(xhrUserInfo.responseText);
								if (userInfo.code === 200) {
									console.log(userInfo);
								}
							}
						}

					} else {
						alert(res.msg);
					}
				}
			}
		}
		userListEleObj.onclick = function() {
			var xhrUserList = new XMLHttpRequest();
			xhrUserList.open('GET', 'http://124.223.98.197:10086/prod-api/system/user/list?pageNum=1&pageSize=10');

			xhrUserList.setRequestHeader('Content-type', 'application/json');
			// xhrUserList.setRequestHeader('Authorization', 'Bearer ' + globalToken);
			xhrUserList.setRequestHeader('Authorization', 'Bearer ' + localStorage.getItem('token'));

			xhrUserList.send();
			xhrUserList.onreadystatechange = function() {
				if (xhrUserList.readyState === 4) {
					var userList = JSON.parse(xhrUserList.responseText);
					if (userList.code === 200) {
						console.log(userList);
					}
				}
			}
		}


		// 送给于思辰
		/*
		get 一般用于获取信息, 使用url传递参数, 对所发送信息的数量大小是有限制的, 一般在2000个字符, 个别浏览器可能是8000个字符;
		而post一般用于修改服务器资源, 对客户端发送的数据没有限制, 
			-- 更新服务器的文件或者数据库内容一般使用post
			--向服务器发送大量数据(post没有数据量限制)
			-- 发送包含未知字符的用户输入, post比get更稳定


		2022年5月28日 周六
		下午: 设置token 简单缓存 字符串变量(模板字符串) 接口文档   同源策略  跨域
		作业: 文件
		*/
	</script>
</body>
</html>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

七色的天空

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值