IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 网络协议 -> 跨域问题:Access to XMLHttpRequest at ‘http: |localhost:3001/re‘ from origin ‘http: |127.0.0.1:8848‘ -> 正文阅读

[网络协议]跨域问题:Access to XMLHttpRequest at ‘http: |localhost:3001/re‘ from origin ‘http: |127.0.0.1:8848‘

1、问题描述:

在本地用express构建服务器端,前端访问数据。
报错:Access to XMLHttpRequest at ‘http://localhost:3001/responseData’ from origin ‘http://127.0.0.1:8848’

(一)app.js

// 引入express
const express = require('express');
// 引入path
const path = require('path');
// 实例化express
const app = express();

// 访问静态资源文件夹
app.use(express.static(path.join(__dirname, 'public')));

// 创建路由,数据请求方式要跟客户端统一
app.get('/first', (req,res)=>{
	res.send('hello ajax');	//res: response
});

app.get('/responseData', (req, res)=>{
	//res.setHeader("Access-Control-Allow-Origin","*");	//跨域
	res.send({"name":"张三"});	//JSON:键值对
});

app.listen(3001); 
console.log('3001启动成功');

(二)启动app.js
在app.js目录下,启动命令行窗口
在这里插入图片描述
(三)客户端访问

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
	</head>
	<body>
		<script type="text/javascript">
			// 创建ajax对象
			// XMLHttpRequest:JS中内置的构造函数
			var xhr = new XMLHttpRequest();
			// 请求方式,get post
			// 请求地址,url
			xhr.open('get', 'http://localhost:3001/responseData');
			// http://poetry.apiopen.top/getTime
			// 发送请求
			xhr.send();
			
			// 获取服务器端返回的数据:responseText,需要不定长时间等待
			xhr.onload = function () {
				// console.log(xhr.responseText);
				// console.log(typeof xhr.responseText);
				var resText = JSON.parse(xhr.responseText);
				console.log(resText);
				// console.log(typeof resText);
				// 字符串拼接
				var str = '<h1>'+resText.name+'</h1>';
				document.body.innerHTML = str;
			}
		</script>
	</body>
</html>

2、解决方法:

解决跨域:app.js文件中,在数据响应部分,加上:

res.setHeader("Access-Control-Allow-Origin","*");

在这里插入图片描述

3、注意

一般前端文件的打开,在启动的服务器端,端口号后面
在这里插入图片描述

  网络协议 最新文章
使用Easyswoole 搭建简单的Websoket服务
常见的数据通信方式有哪些?
Openssl 1024bit RSA算法---公私钥获取和处
HTTPS协议的密钥交换流程
《小白WEB安全入门》03. 漏洞篇
HttpRunner4.x 安装与使用
2021-07-04
手写RPC学习笔记
K8S高可用版本部署
mySQL计算IP地址范围
上一篇文章      下一篇文章      查看所有文章
加:2022-03-21 21:30:49  更:2022-03-21 21:32:40 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/2 3:49:53-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码