博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
一步一步学习SignalR进行实时通信_3_通过CORS解决跨域
阅读量:5771 次
发布时间:2019-06-18

本文共 3040 字,大约阅读时间需要 10 分钟。

目录

一步一步学习SignalR进行实时通信_3_通过CORS解决跨域

标签(空格分隔): SignalR


前言

这周工作比较忙,一直没有时间学习SignalR,大致希望一周能写一篇关于SignalR的文章。用Persistent Connections方式实现了个简单的在线聊天功能,这次我们继续深入学习。

关于start()的补充

在上一篇文章里前台的html页面我们通过几句javascript创建了一个,代码如下,也可以上次的源码。

    persistent connections            

Echo service

这里需要做些说明:通过代码var connection = $.connection("/echo");

我们创建了一个连接,通过connection.start().done()来开启连接并在连接完成时处理我们需要处理的事件。
如果你将以下代码

connection.start().done(function () {    connection.send('Hi');});

分成2部分写,如:

connection.start();connection.send('Hi');

那么你必须注意:

虽然你在connection.send()之前调用了connection.start()开启了连接,但是connection.start()是一个__异步__方法,意味着有可能你在调用connection.send()时connection并未开启,那么项目将会报错。
正确方法如之前代码所示,再加上一段开启失败的代码:

var connection = $.connection("/echo");connection.start(function() {    // 连接开启成功才会进入这里    connection.send("Hi");}).fail(function() {    //连接开启失败则进入这里    alert("服务开启失败");});

跨域解决方案

上篇文章里有同学问到跨域的问题,那么在接下来的时间我将会带着大家一起学习。

在SignalR解决跨域,有两种方式:第一种是JSONP,第二种是CORS。

JSONP

如果你的服务必须要支持老版本的浏览器,那么JSONP是唯一选择,否则处于安全的考虑这并不被推荐,具体什么安全因素我并不知晓(有同学知道的话可以说明下),基于快速学习的情况下,我们无需纠缠于此。服务器默认会禁用此功能,我们可以通过初始化时提供一个ConnectionConfiguration对象并设置EnableJSONP属性为true来激活此功能。

public class Startup{    public void Configuration(IAppBuilder app)    {        var config = new ConnectionConfiguration()        {            EnableJSONP = true        };        app.MapSignalR
("/echo", config); }}

我想这几句代码应该很好理解,我们在前面提到过MapSignalR<TConnection>()有许多重载方法,这是另一个重载方法通过提供一个ConnectionConfiguration对象进行相关配置。

CORS

CORS是一个独立的框架,它可以很方便的解决跨域问题,通过Nuget安装

安装命令:Install-Package microsoft.owin.cors
CORS是通过Owin实现的,所以我们需要在项目启动时对他进行一些配置,和做SignalR映射一样实在Startup中进行配置。

public class Startup{    public void Configuration(IAppBuilder app)    {        //app.MapSignalR
("/echo"); app.Map("/echo", map => { map.UseCors(CorsOptions.AllowAll); map.RunSignalR
(); } ); }}

代码应该也不难,这次我们通过app.Map()进行映射,第一个参数是映射的地址,第二个参数是一个lambda表达式,通过UseCors(CorsOptions.AllowAll)允许允许跨域。

CORS跨域演示

JSONP我不做演示了有兴趣的可以自己尝试下,接下来我这里做一个通过CORS来进行跨域聊天。首先我讲上次的项目复制一份,省得再重新打代码,并将__复制__出来的项目名称由__SignalR_1__改为__SignalR_2_CORS__。

项目目录如下图所示:
89190936.jpg
省得麻烦,我把SignalR_1部署在IIS上面,这就充当了 一个远程的SignalR服务。
66010784.jpg
部署成功后,如图所示:
97434567.jpg
此时我们讲SignalR_2_CORS项目稍作修改

  1. 将Startup中的映射删去,此时SignalR_2_CORS已不做SignalR服务器了,只做客户端来连接SignalR_1提供的服务
    81356378.jpg
  2. 将echo中的var connection = $.connection("/echo");改为

    var connection = $.connection("http://127.0.0.1:8083/echo");
    61833773.jpg
    然后运行SignalR_2_CORS中的echo页面,结果如图所示:
    61274844.jpg
    出现了一个错误,这个错误提示是我们自己写的
    87507291.jpg
    因为我们的__SignalR_1__并没有允许跨域连接,那么在__SignalR_2_CORS__中当然无法连接,接下来我们在项目一中允许跨域连接。
    31745098.jpg
    重新编译项目一后再刷新下__SignalR_1__的_echo.html_页面,注意我们这个页面地址
    99734103.jpg
    然后刷新下__SignalR_2_CORS__的页面,注意这个地址
    36763168.jpg
    连接成功,没有报错了,发送个消息试试看(●ˇ∀ˇ●)
    95697586.jpg
    86349915.jpg

    结束语

    这里通过CORS实现了SignalR的跨域问题,跨域如此简单赶快试试吧 。

    注意:在通过Nuget安装CORS包时,我这边提示了Unable to find package 'Microsoft.AspNet.Cors'我已经FQ了,所以这个应该不是需要FQ才能下载,但是在Nuget页面中搜索确实有这个包,具体什么原因引起的我也不清楚,如果你有碰到这个问题请解压并添加引用即可,由于Microsoft.AspNet.Cors依赖于Microsoft.AspNet.Cors,所以里面的2个包都要添加引用

99724361.jpg

本文发布至

参考文献

转载于:https://www.cnblogs.com/Jack-Blog/p/4735199.html

你可能感兴趣的文章
基于mybatis的BaseDao及BaseService深度结合
查看>>
从程序员进阶到架构师,6大核心技能要领详解
查看>>
CDH安装方法
查看>>
spring mvc+Ajax跨域请求-CORS方式
查看>>
Windows 8.1 下硬盘方式安装 Ubuntu 14.04
查看>>
SpringMVC+Shiro权限管理
查看>>
Python中的模块导入
查看>>
Springboot + mongoDB : So easy
查看>>
mybitis 使用记录
查看>>
关于构造函数 和 析构函数 能否抛出异常的讨论
查看>>
haproxy负载均衡和配合keepalived的快速部署
查看>>
WIN10+RTX2070 tensorflow-gpu环境搭建
查看>>
小黑小波比.功能测试登录用户
查看>>
Java enum用法详解
查看>>
去云端的多条途径
查看>>
Docker容器从一知半解到入门
查看>>
关于“方法参数”
查看>>
Redis命令总结
查看>>
unable to write 'random state'错误解决
查看>>
win7 wamp 下安装pear phpunit
查看>>