javascript无限请求_SockJS - >重新连接后无限xhr-streaming呼叫

时间: 2024-06-01 22:08:51 浏览: 15
这个问题可能是由于以下原因之一导致的: 1. 服务器端没有正确地关闭连接,导致客户端无法重新连接。你可以尝试在客户端代码中添加一个断开连接的方法,确保在重新连接之前关闭连接。 2. 客户端代码中可能存在错误,导致无限请求。你可以检查代码并确保没有循环调用连接或发送请求的代码。 3. 可能存在网络问题,导致连接断开并重新连接。你可以检查网络连接并尝试在不同的网络环境中测试。 4. 可能存在服务器端的限制,导致客户端无法成功连接。你可以与服务器管理员联系以获取更多信息。 除了上述原因之外,还有其他可能导致这个问题的因素。如果以上建议无法解决问题,你可以提供更多细节信息,以便更好地诊断和解决问题。
相关问题

sockjs-client 跨域

sockjs-client是一个用于在Web浏览器和服务器之间进行实时通信的JavaScript库。在跨域访问的环境下,sockjs-client提供了一种可靠且高效的解决方案。 跨域是指在浏览器中访问不同域上的资源。由于浏览器的同源策略限制,JavaScript在一个域中不能直接访问其他域的资源。然而,通过使用sockjs-client,我们可以在跨域环境下进行实时通信。 sockjs-client使用WebSocket作为主要传输协议,但在不支持WebSocket的浏览器中,它会自动回退到其他传输方式,如XHR流。这意味着无论浏览器是否支持WebSocket,sockjs-client都可以在跨域环境中发送和接收实时数据。 为了允许跨域访问,服务器需要配置CORS(跨域资源共享)。在服务器端,我们需要在响应中包含适当的CORS头,以允许浏览器从其他域访问服务器资源。这通常涉及到在服务器配置中添加一些特定的响应头,如"Access-Control-Allow-Origin"。 在sockjs-client中,我们只需要在JavaScript中创建一个SockJS客户端实例,并指定服务器URL。sockjs-client将为我们处理所有跨域访问和实时通信的细节。 总而言之,sockjs-client是一个能够在跨域环境下让浏览器与服务器进行实时通信的JavaScript库。它利用WebSocket和其他传输机制,提供了一种高效和可靠的解决方案。要在跨域环境下使用sockjs-client,服务器需要配置CORS头以允许跨域访问。通过使用sockjs-client,我们可以轻松地在跨域环境中实现实时通信。

<td contenteditable="true" id="cell_1_1"><input type="text" oninput="filterTable(1)" placeholder="aoiStep" id="input_1_1"></td> <td contenteditable="true" id="cell_1_2"><input type="text" oninput="filterTable(2)" placeholder="defectType" id="input_1_2"></td> <td contenteditable="true" id="cell_1_3"><input type="text" oninput="filterTable(3)" placeholder="layerCode" id="input_1_3"></td> <td contenteditable="true" id="cell_1_4"><input type="text" oninput="filterTable(4)" placeholder="type"id="input_1_4"></td> <td contenteditable="true" id="cell_1_5"><input type="text" oninput="filterTable(5)" placeholder="dpet" id="input_1_5"></td> <td contenteditable="true" id="cell_1_6"><input type="text" oninput="filterTable(6)" placeholder="subcode" id="input_1_6"></td> <td contenteditable="true" id="cell_1_7"><input type="text" placeholder="codeDescription" id="input_1_7"></td> <td contenteditable="true" id="cell_1_8">image1</td> <td contenteditable="true" id="cell_1_9">image2</td> <td contenteditable="true" id="cell_1_10">image3</td> <td contenteditable="true" id="cell_1_11">image4</td> <td contenteditable="true" id="cell_1_12">image5</td> <td contenteditable="true" id="cell_1_13"><input type="text" placeholder="determination_rule"id="input_1_8"></td> function submitData(button) { var row = button.parentNode.parentNode; var aoiStep = row.querySelector("#input_1_1").value; var defectType = row.querySelector("#input_1_2").value; // 获取其他列的数据... // 创建XMLHttpRequest对象 var xhr = new XMLHttpRequest(); xhr.onreadystatechange = function() { if (xhr.readyState === 4 && xhr.status === 200) { // 处理返回的结果 var result = xhr.responseText; console.log(result); } }; // 发送POST请求 xhr.open("POST", "insert.php", true); xhr.setRequestHeader("Content-type", "application/x-www-form-urlencoded"); // 将表格数据作为请求参数发送到后端 var data = "aoiStep=" + encodeURIComponent(aoiStep) + "&defectType=" + encodeURIComponent(defectType) + "&..."; xhr.send(data); } 这是我表格的表头,和链接数据库的代码我已经在数据库创建了表,以及对应的字段,现在要实现在数据库中显示我网页添加的详细文字内容,以及将图片存放到本地文件夹后生成唯一的图片文件名,并且将图片路几个保存在数据库,我需要对上面代码进行怎样的修改

要实现在数据库中显示网页添加的详细文字内容以及保存图片文件名和路径,你需要对代码进行以下修改: 1. 在 `submitData` 函数中,获取其他列的数据并构建请求参数时,添加图片文件的处理。修改代码如下: ```javascript function submitData(button) { var row = button.parentNode.parentNode; var aoiStep = row.querySelector("#input_1_1").value; var defectType = row.querySelector("#input_1_2").value; // 获取其他列的数据... // 创建 FormData 对象,用于存储表格数据和图片文件 var formData = new FormData(); formData.append("aoiStep", aoiStep); formData.append("defectType", defectType); // 添加其他表格数据... // 添加图片文件到 FormData 对象 var image1File = row.querySelector("#input_1_8").files[0]; formData.append("image1", image1File); // 添加其他图片文件... // 创建 XMLHttpRequest 对象 var xhr = new XMLHttpRequest(); xhr.onreadystatechange = function() { if (xhr.readyState === 4 && xhr.status === 200) { // 处理返回的结果 var result = xhr.responseText; console.log(result); } }; // 发送 POST 请求 xhr.open("POST", "insert.php", true); xhr.send(formData); } ``` 在上述代码中,我们使用 `FormData` 对象来存储表格数据和图片文件。首先创建一个 `FormData` 对象,并使用 `formData.append()` 方法添加表格数据(例如 `aoiStep` 和 `defectType`)到对象中。然后,通过查询表单元素的方式获取图片文件,并将其添加到 `FormData` 对象中。 2. 修改 PHP 后端代码 `insert.php`,以保存图片文件并将图片路径存储到数据库中。具体修改方式如下: ```php // 获取表单提交的数据 $aoiStep = $_POST['aoiStep']; $defectType = $_POST['defectType']; // 获取其他表格数据... // 获取图片文件并保存到指定文件夹 $image1Name = uniqid() . '_' . $_FILES['image1']['name']; $image1Path = "path/to/save/" . $image1Name; move_uploaded_file($_FILES['image1']['tmp_name'], $image1Path); // 获取其他图片文件并保存... // 执行数据库插入操作 $sql = "INSERT INTO tms_jianben (aoi_step, defect_type, layer_code, type, dpet, subcode, code_description, image1_path, image2_path, image3_path, image4_path, image5_path, determination_rule) VALUES ('$aoiStep', '$defectType', '$layerCode', '$type', '$dpet', '$subcode', '$codeDescription', '$image1Path', '$image2Path', '$image3Path', '$image4Path', '$image5Path', '$determinationRule')"; // 执行数据库插入操作... ``` 在上述代码中,我们获取表单提交的数据(例如 `aoiStep` 和 `defectType`),然后获取图片文件并将其保存到指定文件夹。我们使用 `uniqid()` 函数生成唯一的图片文件名,并通过 `move_uploaded_file()` 函数将图片文件移动到指定文件夹。 接下来,在数据库插入操作的 SQL 语句中,将图片路径(例如 `$image1Path`)存储到对应的字段中。 请注意,你需要将 `"path/to/save/"` 替换为你想要保存图片的实际文件夹路径。 这样,当你点击提交按钮时,表格数据和图片文件将会被发送到后端 PHP 脚本进行处理,并将图片路径存储到数据库中。 希望这个修改对你有所帮助!如果你还有其他问题,请随时提问。

相关推荐

潮影森美 全硅胶性感甜心胶实体娃娃 159cm 169普通款 - <input type="number" id="gnum" data-id="71790817" class="gnum c_pt" min="1" value="7"/> + ¥15200.00 删除
>帮我做一个js代码,我点击dl标签class为car时候点一次将他class属性设置为car car_on,再次点击时恢复为car,并加上判断如果dl的class为car car_on时,将data-id和input的value值用post传值到t.php页面并回调显示在一个id为c_gprice的em标签里面,把t.php的代码也写出了

最新推荐

recommend-type

javascript实现fetch请求返回的统一拦截

拦截器主要用于在请求发送前或响应接收后执行一些通用操作,例如添加身份验证令牌、处理网络错误等。在axios库中,内置的拦截器API使得这些功能变得简单。但在fetch API中,由于没有内建的拦截器机制,我们需要通过...
recommend-type

1_ARMCortex-A系列处理器(A5、A7、A8、A9、A15)区别对比[参照].pdf

"ARM Cortex-A系列处理器(A5、A7、A8、A9、A15)区别对比" ARM Cortex-A系列处理器是基于ARM v7-A架构的高性能处理器家族,由Cortex-A5、Cortex-A7、Cortex-A8、Cortex-A9和Cortex-A15五个成员组成。...
recommend-type

JavaScript实现文件下载并重命名代码实例

在Web开发中,JavaScript是一种常用的脚本语言,用于处理用户交互、动态内容和与服务器通信等任务。在某些场景下,我们可能需要提供一个功能,让用户能够从网页上下载文件,并且在下载时可以自定义文件的名称。本文...
recommend-type

js get和post请求实现代码解析

这篇文章主要介绍了js get和post实现代码解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 1、get &lt;&#37;...charset=UTF-8" language=... var xhr = getXHR();
recommend-type

文艺高逼格28.pptx

文艺风格ppt模板文艺风格ppt模板 文艺风格ppt模板 文艺风格ppt模板 文艺风格ppt模板 文艺风格ppt模板 文艺风格ppt模板 文艺风格ppt模板 文艺风格ppt模板 文艺风格ppt模板 文艺风格ppt模板 文艺风格ppt模板 文艺风格ppt模板 文艺风格ppt模板 文艺风格ppt模板
recommend-type

计算机基础知识试题与解答

"计算机基础知识试题及答案-(1).doc" 这篇文档包含了计算机基础知识的多项选择题,涵盖了计算机历史、操作系统、计算机分类、电子器件、计算机系统组成、软件类型、计算机语言、运算速度度量单位、数据存储单位、进制转换以及输入/输出设备等多个方面。 1. 世界上第一台电子数字计算机名为ENIAC(电子数字积分计算器),这是计算机发展史上的一个重要里程碑。 2. 操作系统的作用是控制和管理系统资源的使用,它负责管理计算机硬件和软件资源,提供用户界面,使用户能够高效地使用计算机。 3. 个人计算机(PC)属于微型计算机类别,适合个人使用,具有较高的性价比和灵活性。 4. 当前制造计算机普遍采用的电子器件是超大规模集成电路(VLSI),这使得计算机的处理能力和集成度大大提高。 5. 完整的计算机系统由硬件系统和软件系统两部分组成,硬件包括计算机硬件设备,软件则包括系统软件和应用软件。 6. 计算机软件不仅指计算机程序,还包括相关的文档、数据和程序设计语言。 7. 软件系统通常分为系统软件和应用软件,系统软件如操作系统,应用软件则是用户用于特定任务的软件。 8. 机器语言是计算机可以直接执行的语言,不需要编译,因为它直接对应于硬件指令集。 9. 微机的性能主要由CPU决定,CPU的性能指标包括时钟频率、架构、核心数量等。 10. 运算器是计算机中的一个重要组成部分,主要负责进行算术和逻辑运算。 11. MIPS(Millions of Instructions Per Second)是衡量计算机每秒执行指令数的单位,用于描述计算机的运算速度。 12. 计算机存储数据的最小单位是位(比特,bit),是二进制的基本单位。 13. 一个字节由8个二进制位组成,是计算机中表示基本信息的最小单位。 14. 1MB(兆字节)等于1,048,576字节,这是常见的内存和存储容量单位。 15. 八进制数的范围是0-7,因此317是一个可能的八进制数。 16. 与十进制36.875等值的二进制数是100100.111,其中整数部分36转换为二进制为100100,小数部分0.875转换为二进制为0.111。 17. 逻辑运算中,0+1应该等于1,但选项C错误地给出了0+1=0。 18. 磁盘是一种外存储设备,用于长期存储大量数据,既可读也可写。 这些题目旨在帮助学习者巩固和检验计算机基础知识的理解,涵盖的领域广泛,对于初学者或需要复习基础知识的人来说很有价值。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

【进阶】音频处理基础:使用Librosa

![【进阶】音频处理基础:使用Librosa](https://picx.zhimg.com/80/v2-a39e5c9bff1d920097341591ca8a2dfe_1440w.webp?source=1def8aca) # 2.1 Librosa库的安装和导入 Librosa库是一个用于音频处理的Python库。要安装Librosa库,请在命令行中输入以下命令: ``` pip install librosa ``` 安装完成后,可以通过以下方式导入Librosa库: ```python import librosa ``` 导入Librosa库后,就可以使用其提供的各种函数
recommend-type

设置ansible 开机自启

Ansible是一个强大的自动化运维工具,它可以用来配置和管理服务器。如果你想要在服务器启动时自动运行Ansible任务,通常会涉及到配置服务或守护进程。以下是使用Ansible设置开机自启的基本步骤: 1. **在主机上安装必要的软件**: 首先确保目标服务器上已经安装了Ansible和SSH(因为Ansible通常是通过SSH执行操作的)。如果需要,可以通过包管理器如apt、yum或zypper安装它们。 2. **编写Ansible playbook**: 创建一个YAML格式的playbook,其中包含`service`模块来管理服务。例如,你可以创建一个名为`setu
recommend-type

计算机基础知识试题与解析

"计算机基础知识试题及答案(二).doc" 这篇文档包含了计算机基础知识的多项选择题,涵盖了操作系统、硬件、数据表示、存储器、程序、病毒、计算机分类、语言等多个方面的知识。 1. 计算机系统由硬件系统和软件系统两部分组成,选项C正确。硬件包括计算机及其外部设备,而软件包括系统软件和应用软件。 2. 十六进制1000转换为十进制是4096,因此选项A正确。十六进制的1000相当于1*16^3 = 4096。 3. ENTER键是回车换行键,用于确认输入或换行,选项B正确。 4. DRAM(Dynamic Random Access Memory)是动态随机存取存储器,选项B正确,它需要周期性刷新来保持数据。 5. Bit是二进制位的简称,是计算机中数据的最小单位,选项A正确。 6. 汉字国标码GB2312-80规定每个汉字用两个字节表示,选项B正确。 7. 微机系统的开机顺序通常是先打开外部设备(如显示器、打印机等),再开启主机,选项D正确。 8. 使用高级语言编写的程序称为源程序,需要经过编译或解释才能执行,选项A正确。 9. 微机病毒是指人为设计的、具有破坏性的小程序,通常通过网络传播,选项D正确。 10. 运算器、控制器及内存的总称是CPU(Central Processing Unit),选项A正确。 11. U盘作为外存储器,断电后存储的信息不会丢失,选项A正确。 12. 财务管理软件属于应用软件,是为特定应用而开发的,选项D正确。 13. 计算机网络的最大好处是实现资源共享,选项C正确。 14. 个人计算机属于微机,选项D正确。 15. 微机唯一能直接识别和处理的语言是机器语言,它是计算机硬件可以直接执行的指令集,选项D正确。 16. 断电会丢失原存信息的存储器是半导体RAM(Random Access Memory),选项A正确。 17. 硬盘连同驱动器是一种外存储器,用于长期存储大量数据,选项B正确。 18. 在内存中,每个基本单位的唯一序号称为地址,选项B正确。 以上是对文档部分内容的详细解释,这些知识对于理解和操作计算机系统至关重要。