=================請求頭設置===================

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>AJAX POST 請求</title>
<style>
#result {
width: 200px;
height: 100px;
border: solid 1px red;
}
</style>
</head>
<body>
<div id="result"></div>
</body>
<script>
const result = document.getElementById("result");
result.addEventListener("mouseover", function () {
const xhr = new XMLHttpRequest();
xhr.open('POST', 'http://127.0.0.1:8000/servers');
//設置請求頭,設置請求體內容的類型
xhr.setRequestHeader('Content-Type', 'Application/x-www-form-urlencoded');
//設置自定義請求頭
xhr.setRequestHeader('name', 'atxxxxxxxxxxxxxx');
//1、 xhr.send('a=100&b=200&c=300');
xhr.send('a:100&b:200&c:300');
xhr.onreadystatechange = function () {
if (xhr.readyState == 4) {
if (xhr.status >= 200 && xhr.status < 300) {
result.innerText = xhr.response;
}
}
}
})
</script>
</html>
================服務器響應體設置================

//引用 express
const { request, response } = require('express');
const express = require('express');
//創建應用對象
const app = express();
//創建路由規則,
// request 是對請求報文的封裝
// response 是對響應報文的封裝
app.all('/servers', (request, response) => {
//設置響應頭,設置充許跨域
response.setHeader('Access-Control-Allow-Origin', '*');
//設置響應頭,設置充許自定義(自定義時,app.post 一定改為app.all)
response.setHeader('Access-Control-Allow-Headers', '*');
//設置響應體
response.send('hello express 0000000');
})
// 監聽端口啟動服務
app.listen(8000, () => {
console.log('服務已經啟動,8000端口監聽中.......');
})