socket.io跨域踩坑

一、koa结合socket.io

后端代码:

// 引入依赖
const koa = require("koa");
// 初始化koa
const app = new koa();
// 开启 http
var server = require("http").createServer(app.callback());
// 初始化 socket
const io = require("socket.io")(server, { cors: true });
// 监听
io.on("connection", (socket) => {console.log("有人链接");//接收数据socket.on('send', function (data) {console.log(data);// 发送数据socket.emit('resend', {msg: `你好${data.msg}`,code: 200});});
});
server.listen(3000);

前端代码:

<template><div class="hello"><input type="text" v-model="msg"><button @click="sendMsg">发送</button></div>
</template><script>
import io from 'socket.io-client'
export default {name: 'HelloWorld',data () {return {msg: 'Welcome to Your Vue.js App'}},mounted () {const socket = io('ws://localhost:3000')this.socket = socketwindow.socket = socketsocket.on('connect', function () {console.log('连接建立成功了!')})socket.on('disconnect', function () {console.log('断开连接了')})socket.on('resend', function (data) {console.log(data)})},methods: {sendMsg () {// 发送信息给服务端this.socket.emit('send', {msg: this.msg})}}
}
</script>
<style scoped></style>

在这里插入图片描述
在这里插入图片描述

二、express 结合 socket.io

var app = require('express')();
var http = require('http').Server(app);
var io = require('socket.io')(http, { cors: true });app.get('/', function(req, res){res.send('<h1>你好web秀</h1>');
});io.on('connection',function(socket) {console.log("有人链接");//接收数据socket.on('send', function (data) {console.log(data);// 发送数据socket.emit('resend', {msg: `你好${data.msg}`,code: 200});});
});http.listen(3000, function(){console.log('listening on *:3000');
});

前端代码:

<template><div class="hello"><input type="text" v-model="msg"><button @click="sendMsg">发送</button></div>
</template><script>
import io from 'socket.io-client'
export default {name: 'HelloWorld',data () {return {msg: 'Welcome to Your Vue.js App'}},mounted () {const socket = io('ws://localhost:3000')this.socket = socketwindow.socket = socketsocket.on('connect', function () {console.log('连接建立成功了!')})socket.on('disconnect', function () {console.log('断开连接了')})socket.on('resend', function (data) {console.log(data)})},methods: {sendMsg () {// 发送信息给服务端this.socket.emit('send', {msg: this.msg})}}
}
</script>
<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped></style>

在这里插入图片描述
在这里插入图片描述
注意:
如果出现跨域报错,可以参考以下解决方案:
在这里插入图片描述

  1. 重装socket.io-client
npm i socket.io-client --save
  1. 在vue中使用
    在这里插入图片描述

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/470254.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ios 权限提示语_iOS工作室都在用按键v1.6.1(体验版)

按键精灵iOS v1.6.1(体验版)已发布到cydia新增工作室专场还支持VIP自助换绑欢迎下载使用~源地址&#xff1a;http://apt.mobileanjian.comVIP换绑方法如下&#xff1a;1、在按键精灵APP上进入“我的”分页&#xff0c;点击VIP信息&#xff0c;看到“解绑”按钮。点击后&#xf…

Redux学习(一)——Redux的使用过程

一、为什么需要redux JavaScript开发的应用程序&#xff0c;已经变得越来越复杂了&#xff1a; JavaScript需要管理的状态越来越多&#xff0c;越来越复杂&#xff1b;这些状态包括服务器返回的数据、缓存数据、用户操作产生的数据等等&#xff0c;也包括一些UI的状态&#x…

OpenCV实现图像颜色特征提取

https://github.com/ictlyh/ImageFeature 链接&#xff1a;http://pan.baidu.com/s/1mhUoPxI 密码&#xff1a;3cnn转载于:https://www.cnblogs.com/eustoma/p/5792717.html

贪吃蛇python小白_面向 python 小白的贪吃蛇游戏

代码和教程详见微信公众号&#xff1a;Python高效编程效果图图片代码和教程详见微信公众号&#xff1a;Python高效编程文字部分&#xff1a;引言作为python 小白&#xff0c;总是觉得自己要做好百分之二百的准备&#xff0c;才能开始写程序。以至于常常整天在那看各种语法教程&…

Redux学习(二)——封装connect函数

一、自定义connect函数 connect.js: import {PureComponent} from "react"; import store from "../store"; export function connect(mapStateToProps, mapDispatchToProps) {return function enhanceHOC(WrappedComponent) {return class extends PureC…

python ssh实现_SSH协议的Python实现paramiko

paramiko安装SSH是一个协议&#xff0c;paramiko 是一个Python 的库&#xff0c;该库支持sshv2协议&#xff0c;实现了对远程服务器执行操作安装命令&#xff1a;pip3 install paramikoSSHClient类与SFTPClient类paramiko包含两个核心组建&#xff0c;分别是SSHClient和SFTPCli…

C++学习10 static静态成员变量和静态成员函数

一般情况下&#xff0c;如果有N个同类的对象&#xff0c;那么每一个对象都分别有自己的成员变量&#xff0c;不同对象的成员变量各自有值&#xff0c;互不相干。但是有时我们希望有某一个或几个成员变量为所有对象共有&#xff0c;这样可以实现数据共享。 可以使用全局变量来达…

Redux学习(三)——redux-saga的使用、编写中间件函数、Reducer文件拆分

一、redux-devtools 我们之前讲过&#xff0c;redux可以方便的让我们对状态进行跟踪和调试&#xff0c;那么如何做到呢&#xff1f; redux官网为我们提供了redux-devtools的工具&#xff1b;利用这个工具&#xff0c;我们可以知道每次状态是如何被修改的&#xff0c;修改前后…

python 存储图片 alpha_保存时Matplotlib图形面颜色alpha(背景色、透明度)

前一个问题是使用savefig()保存屏幕上显示的相同的面颜色(背景色)&#xff0c;即&#xff1a;fig plt.figure()fig.patch.set_facecolor(blue)fig.savefig(foo.png, facecolorfig.get_facecolor())(使用savefig()需要重新指定背景色。)fig.patch.set_alpha(0.5)我找不到一种方…

【JavaScript代码实现四】获取和设置 cookie

1 // 创建cookie2 function setCookie(name, value, expires, path, domain, secure) {3 var cookieText encodeURIComponent(name) encodeURIComponent(value);4 if (expires instanceof Date) {5 cookieText ; expires expires; 6 }7 if…

react-router的使用(一)——URL的hash、HTML5的history、Router的基本使用

一、阶段一&#xff1a;后端路由阶段 早期的网站开发整个HTML页面是由服务器来渲染的. 服务器直接生产渲染好对应的HTML页面, 返回给客户端进行展示. 但是, 一个网站, 这么多页面服务器如何处理呢? 一个页面有自己对应的网址, 也就是URL.URL会发送到服务器, 服务器会通过正…

Linux中source是什么指令?

命令用法&#xff1a; source FileName作用&#xff1a;在当前bash环境下读取并执行FileName中的命令。 注&#xff1a;该命令通常用命令“.”来替代。 如&#xff1a;source /etc/profile 与 . /etc/profile 是等效的。 注意&#xff1a;source命令与shell scripts的区别是&a…

react-router的使用(二)——NavLink的使用、Switch的作用、Redirect

一、NavLink的使用 需求&#xff1a;路径选中时&#xff0c;对应的a元素变为红色 这个时候&#xff0c;我们要使用NavLink组件来替代Link组件&#xff1a; activeStyle&#xff1a;活跃时&#xff08;匹配时&#xff09;的样式&#xff1b;activeClassName&#xff1a;活跃时…

群晖ffmpeg_群晖Video station支持DTS和EAC3

群晖video station这个套件现在经过群晖的打磨&#xff0c;现在还是不错的&#xff0c;支持硬件解码和蓝光等多媒体播放&#xff0c;比起PLEX和EMBY动辄好几百的会员费&#xff0c;这个免费的用起来还真香&#xff0c;但是因为种种小问题需要解决了&#xff0c;才能好用&#x…

Redis 3.0.2集群搭建以及相关问题汇总

Redis3 正式支持了 cluster&#xff0c;是为了解决构建redis集群时的诸多不便&#xff08;1&#xff09;像操作单个redis一样操作key&#xff0c;不用操心key在哪个节点上&#xff08;2&#xff09;在线动态添加、删除redis节点&#xff0c;不用停止服务&#xff08;3&#xff…

react-router的使用(三)——路由的嵌套

一、路由的嵌套 在开发中&#xff0c;路由之间是存在嵌套关系的。 这里我们假设about页面中有三个页面内容&#xff1a; 企业历史、企业文化和联系我们&#xff1b;点击不同的链接可以跳转到不同的地方&#xff0c;显示不同的内容&#xff1b; 二、手动路由跳转 目前我们实现…

如何阅读一本书 pdf_《如何阅读一本书》:一本书,四个层次,看阅读小白如何逆袭?...

“读书不是为了雄辩和驳斥&#xff0c;也不是为了轻信和盲从&#xff0c;而是为了思考和权衡。”这是培根的一句名言&#xff0c;我们都曾经被这样的读书警句激励的斗志昂扬&#xff0c;于是立下目标一年或是一个月要读多少本书&#xff0c;结果发现一切是徒劳。你是否曾经斗志…

React Hooks的使用(一)——useState、useEffect解析

一、为什么需要Hook? Hook 是 React 16.8 的新增特性&#xff0c;它可以让我们在不编写class的情况下使用state以及其他的React特性&#xff08;比如生命周期&#xff09;。 我们先来思考一下class组件相对于函数式组件有什么优势&#xff1f;比较常见的是下面的优势&#xf…

python长沙_长沙python

本文转自量子位(ID:QbitAI) 边策 鱼羊 发自 凹非寺 量子位 报道 | 公众号 QbitAI 只用99行代码&#xff0c;你也可以像《冰雪奇缘》里的艾莎公主一样拥有冰雪魔法。虽然你不能在现实世界中肆意变出魔法&#xff0c;但却能在计算机的虚拟世界挥洒特效。或许你不知道&#xff0c;…

sed

sed -n 10p text.txt 输出第10行转载于:https://www.cnblogs.com/ssyuxue/p/5804857.html