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

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

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

SignalR


  • 一步一步学习SignalR进行实时通信_3_通过CORS解决跨域
    • 前言
    • 关于start()的补充
    • 跨域解决方案
      • JSONP
      • CORS
        • CORS跨域演示
    • 结束语
    • 参考文献

前言

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

关于start()的补充

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


  1. <!DOCTYPE html>
  2. <html xmlns="http://www.w3.org/1999/xhtml">
  3. <head>
  4. <title>persistent connections</title>
  5. <script src="Scripts/jquery-1.10.2.min.js"></script>
  6. <script src="Scripts/jquery.signalR-2.0.0.min.js"></script>
  7. </head>
  8. <body>
  9. <h1>Echo service</h1>
  10. <div>
  11. <input type="text" id="text" />
  12. <button id="send">Send</button>
  13. </div>
  14. <script>
  15. $(function () {
  16. var connection = $.connection("/echo");
  17. connection.logging = true;
  18. connection.received(function (data) {
  19. $("body").append(data + "<br />");
  20. });
  21. connection.error(function (err) {
  22. alert("存在一个错误. \n" +
  23. "Error: " + err.message);
  24. });
  25. connection.start().done(function () {
  26. $("#send").click(function () {
  27. connection.send($("#text").val());
  28. $("#text").val("").focus();
  29. });
  30. });
  31. });
  32. </script>
  33. </body>
  34. </html>

这里需要做些说明:通过代码var connection = $.connection("/echo");
我们创建了一个连接,通过connection.start().done()来开启连接并在连接完成时处理我们需要处理的事件。
如果你将以下代码


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

分成2部分写,如:


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

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


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

跨域解决方案

上篇文章里有同学问到跨域的问题,那么在接下来的时间我将会带着大家一起学习。
在SignalR解决跨域,有两种方式:第一种是JSONP,第二种是CORS。

JSONP

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


  1. public class Startup
  2. {
  3. public void Configuration(IAppBuilder app)
  4. {
  5. var config = new ConnectionConfiguration()
  6. {
  7. EnableJSONP = true
  8. };
  9. app.MapSignalR<EchoConnection>("/echo", config);
  10. }
  11. }

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

CORS

CORS是一个独立的框架,它可以很方便的解决跨域问题,通过Nuget安装
安装命令:Install-Package microsoft.owin.cors
CORS是通过Owin实现的,所以我们需要在项目启动时对他进行一些配置,和做SignalR映射一样实在Startup中进行配置。


  1. public class Startup
  2. {
  3. public void Configuration(IAppBuilder app)
  4. {
  5. //app.MapSignalR<EchoConnection>("/echo");
  6. app.Map("/echo",
  7. map => {
  8. map.UseCors(CorsOptions.AllowAll);
  9. map.RunSignalR<EchoConnection>();
  10. }
  11. );
  12. }
  13. }

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

CORS跨域演示

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

省得麻烦,我把SignalR_1部署在IIS上面,这就充当了 一个远程的SignalR服务。

部署成功后,如图所示:

此时我们讲SignalR_2_CORS项目稍作修改
1. 将Startup中的映射删去,此时SignalR_2_CORS已不做SignalR服务器了,只做客户端来连接SignalR_1提供的服务

2. 将echo中的var connection = $.connection("/echo");改为
var connection = $.connection("http://127.0.0.1:8083/echo");

然后运行SignalR_2_CORS中的echo页面,结果如图所示:

出现了一个错误,这个错误提示是我们自己写的

因为我们的SignalR_1并没有允许跨域连接,那么在SignalR_2_CORS中当然无法连接,接下来我们在项目一中允许跨域连接。

重新编译项目一后再刷新下SignalR_1echo.html页面,注意我们这个页面地址

然后刷新下SignalR_2_CORS的页面,注意这个地址

连接成功,没有报错了,发送个消息试试看(●ˇ∀ˇ●)

结束语

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

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

源码下载
本文发布至作业部落

参考文献

SignalR Programming in Microsoft ASP.NET pdf 下载

时间: 2024-12-29 00:44:37

一步一步学习SignalR进行实时通信_3_通过CORS解决跨域的相关文章

一步一步学习SignalR进行实时通信_2_Persistent Connections

原文:一步一步学习SignalR进行实时通信_2_Persistent Connections 一步一步学习SignalR进行实时通信\_2_Persistent Connections SignalR 一步一步学习SignalR进行实时通信_2_Persistent Connections 前言 安装 Persistent Connections 映射并配置持久连接 结束语 参考文献 前言 上一篇文章简单的介绍了下SignalR,从此篇文章就开始对SignalR进行剖析.在介绍Persiste

一步一步学习SignalR进行实时通信_5_Hub

原文:一步一步学习SignalR进行实时通信_5_Hub 一步一步学习SignalR进行实时通信\_5_Hub SignalR 一步一步学习SignalR进行实时通信_5_Hub 前言 Hub命名规则 Hub封装好的常用方法 Hub常用方法解释 保持状态 前后台交互 结束语 参考文献 前言 上一讲,我们简单的介绍了下Hub的配置以及实现方法,这一将我希望把更多的细节梳理清楚,不至于让大家在细节上面摸不着头脑,理解深了,那么做项目自然就会相对轻松一些. Hub命名规则 Hub与Persistent

一步一步学习SignalR进行实时通信_9_托管在非Web应用程序

原文:一步一步学习SignalR进行实时通信_9_托管在非Web应用程序 一步一步学习SignalR进行实时通信\_9_托管在非Web应用程序 一步一步学习SignalR进行实时通信_9_托管在非Web应用程序 前言 部署在控制台应用程序 安装自托管包 安装跨域包 winform客户端 设计界面 连接 完整实现效果 windows服务 创建服务 安装服务 启动服务 连接服务 结束语 源码下载 参考文献 前言 本章我们将学习将signalr服务托管在非web应用程序.之前我们一直是通过IIS部署s

一步一步学习SignalR进行实时通信_7_非代理

原文:一步一步学习SignalR进行实时通信_7_非代理 一步一步学习SignalR进行实时通信\_7_非代理 SignalR 一步一步学习SignalR进行实时通信_7_非代理 前言 代理与非代理 建立连接 调用方法 维持状态 从服务器接收 结束语 参考文献 前言 距离上次写博客已经一个多月了,一直想抽空写,却一直没时间写.现在紧接着要开始毕业设计了,工作的同时还要抽时间完成毕业设计,心也是有些累.由于自己是个.NET迷,自己的工作也是.net开发,老师给的毕业设计百分之八九十都是安卓java

一步一步学习SignalR进行实时通信_6_案例

原文:一步一步学习SignalR进行实时通信_6_案例 一步一步学习SignalR进行实时通信\_6_案例1 一步一步学习SignalR进行实时通信_6_案例1 前言 类的定义 各块功能 后台 上线 下线 修改昵称 发送消息给所有人 前台 用户上线消息 昵称改变消息 用户下线消息 更新个人信息 用户上线提醒 发送消息 效果图 结束语 参考文献 前言 由于这段时间在找房子,所以耽误了一段时间.前几讲把一些基础的东西稍微介绍了下,这一讲就简单介绍一个小例子,大致功能是实现在线聊天,并显示在线用户.用

一步一步学习SignalR进行实时通信_4_Hub

原文:一步一步学习SignalR进行实时通信_4_Hub 一步一步学习SignalR进行实时通信\_4_Hub SignalR 一步一步学习SignalR进行实时通信_4_Hub 前言 创建Hub 配置Hub 创建Hubs服务 详细代码 代码解析 效果展示 结束语 参考文献 前言 之前我们介绍了SignalR有2级抽象,前2篇文章我们讲的是较底层PersistentConnection,从这篇文章开始我们学习下较高一层的Hub. 创建Hub 创建Hub的方法和创建PersistentConnec

活到老学到老学习AJAX跨域(三)_AJAX相关

学习AJAX其实有个很重要的应用,就是为了执行另外几个站点的ASP,返回结果. 真正用起来,发现2个问题,一向做DELPHI,接触ASP不多的我,的确问题大堆. 第一个问题: VBS的变量传递给JS...通过学习发现很简单的... 先看下我大体实现方法: <% dim sSrv1Link sSrv1Link = "http://www.XXX.org/test1.asp?U=TESTUSER&M=111&E=222" %> <script type=&

活到老学到老学习AJAX跨域(三)

学习AJAX其实有个很重要的应用,就是为了执行另外几个站点的ASP,返回结果. 真正用起来,发现2个问题,一向做DELPHI,接触ASP不多的我,的确问题大堆. 第一个问题: VBS的变量传递给JS...通过学习发现很简单的... 先看下我大体实现方法: <% dim sSrv1Link sSrv1Link = "http://www.XXX.org/test1.asp?U=TESTUSER&M=111&E=222" %> <script type=&

一步一步学习sqlserver BI--应用开发

接着我们上次那篇<一步一步学习sqlserverBi--多维数据库建立>,现在我们多维数据库已经有了 ,并且里面也已经有了数据,那么赶快进入咱们程序员的主题吧. 今天我要在这个多维数据库上 面开发两个应用: 1.按天统计各个部门的交易量 2.按天统计各个部门和各个游戏的交 易量 首先设计强类型的数据集,如下图. 按部门统计数据集 按部门和游戏交叉统 计数据集 设计MDX语句,在数据层执行MDX,并返回CellSet /**//// <summary> /// 按天统计各个部门的交易