MVC使用SignalR 提高B2C商城用户体验1

2024-06-20 23:38

本文主要是介绍MVC使用SignalR 提高B2C商城用户体验1,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

vs2010 使用SignalR 提高B2C商城用户体验

1、需求简介,做为新时代的b2c商城,没有即时通讯,怎么提供用户粘稠度,怎么增加销量,用户购物的第一习惯就是咨询,即时通讯,应运而生。这里使用SignalR来实现即时通讯,再好不过了,不过项目依然简历在2010的基础上,所以不能使用新版本的SignalR了,这里介绍一下1.0.0版本的。

2、整个框架大概是这样搭建的,欢迎拍砖:

  

3、启动VS2010,新建一个项目,这里我建立的是asp.net mvc4

 

然后通过nuget引入SignalR所需要的组件  

     Install-Package Microsoft.AspNet.SignalR -Version 1.0.1

关于nuget怎么使用就不过多介绍了,回车后,所需要的组件基本已经引入项目中了,下面进入开发。

(1)先介绍推送服务器开发:

  在项目下,新加一个文件夹SignalR,

  然后建立我们的集线器,

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
using  System;
using  System.Collections.Generic;
using  System.Linq;
using  System.Threading.Tasks;
using  System.Web;
using  Microsoft.AspNet.SignalR;
using  Microsoft.AspNet.SignalR.Hubs;
using  Owin;
namespace  SignalRTest.SignalR
{
     [HubName( "pushHub" )]
     public  class  PushHub : Hub
     {
         public  void  Send( string  message)
         {
             Clients.All.addMessage(message);
         }
         public  void  Bind( string  userKey)
         {
             
         }
         public  override  Task OnConnected()
         {
             var  id = Context.ConnectionId;
             var  c = Clients.Caller;
             return  base .OnConnected();
         }
     }
}

  Send方法,主要用来向客户端广播消息,Bind我本意是做登录校验,然后绑定客户端,OnConnected当客户端发起连接后会出发,里面的成员可以用一个字典进行管理。

  然后进入Global.asax,配置一下路由,我这里的配置是适用于跨域的,后面会介绍到。

  

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
using  System;
using  System.Collections.Generic;
using  System.Linq;
using  System.Web;
using  System.Web.Http;
using  System.Web.Mvc;
using  System.Web.Routing;
using  Microsoft.AspNet.SignalR;
using  Owin;
namespace  SignalRTest
{
     // Note: For instructions on enabling IIS6 or IIS7 classic mode,
     // visit http://go.microsoft.com/?LinkId=9394801
     public  class  MvcApplication : System.Web.HttpApplication
     {
         protected  void  Application_Start()
         {
             var  config = new  HubConfiguration();
             config.EnableCrossDomain = true ;
             RouteTable.Routes.MapHubs(config);
             AreaRegistration.RegisterAllAreas();
             WebApiConfig.Register(GlobalConfiguration.Configuration);
             FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
             RouteConfig.RegisterRoutes(RouteTable.Routes);
             
         }
        
     }
}

  

(2)web页面开发:

先创建母版页,请注意js的顺序,json2.js主要是用于支持ie7及以下版本的。

复制代码
复制代码
复制代码
 1 @{2     Layout = null;3 }4 <!DOCTYPE html>5 <html>6 <head>7     <meta name="viewport" content="width=device-width" />8     <title>singalr</title>9     <script src="@Url.Content("~/Scripts/jquery-1.6.4.js")" type="text/javascript"></script>
10     <script src="@Url.Content("~/Scripts/json2.js")" type="text/javascript"></script>
11     <script src="@Url.Content("~/Scripts/jquery.signalR-1.0.1.js")" type="text/javascript"></script>
12     <script src="@Url.Content("~/signalr/hubs")" type="text/javascript"></script>
13 </head>
14 <body>
15     <div>
16         @RenderBody()
17     </div>
18 </body>
19 </html>
复制代码
复制代码
复制代码

然后创建主页,我是在homecontroller里面创建的index,这里就不过多介绍了:

复制代码
复制代码
复制代码
 1 @{2     Layout = "~/views/shared/_layout.cshtml";3 }4 <script type="text/javascript">5 6     $(function () {7 8 9         // Proxy created on the fly
10         var chat = $.connection.pushHub;
11         // Declare a function on the chat hub so the server can invoke it
12         chat.client.addMessage = function ( message) {
13             writeEvent('<b>ny</b> 对大家说: ' + message, 'event-message');
14         };
15 
16         $("#broadcast").click(function () {
17             // Call the chat method on the server
18             chat.server.send( $('#msg').val())
19                             .done(function () {
20                                 console.log('Sent message success!');
21                                 
22                             })
23                             .fail(function (e) {
24                                 console.warn(e);
25                             });
26         });
27 
28         // Start the connection
29         $.connection.hub.start().done(function() {
30             //绑定
31             chat.server.bind("wo");
32         });
33 
34         //A function to write events to the page
35         function writeEvent(eventLog, logClass) {
36             var now = new Date();
37             var nowStr = now.getHours() + ':' + now.getMinutes() + ':' + now.getSeconds();
38             $('#messages').prepend('<li class="' + logClass + '"><b>' + nowStr + '</b> ' + eventLog + '.</li>');
39         }
40     });
41 </script>
42 <h2>
43     Hub Chat</h2>
44 <div>
45     <input type="text" id="Placeholder" value="ny" hidden="true" />
46     <input type="text" id="msg" />
47     <input type="button" id="broadcast" value="广播" />
48     <br />
49     <br />
50     <h3>
51         消息记录: (你是:<span id="MyClientName">ny</span>):
52     </h3>
53     <ul id="messages">
54     </ul>
55 </div>
复制代码
复制代码
复制代码

此时,启动我们的项目

已经可以进行广播了,开启多个客户端看一下效果

是不是感觉很不错。此时,只是当前系统的,并不能做到与其他系统互通有无,那我们加个web方法,提供给其他服务器进行推送调用:

复制代码
复制代码
复制代码
 1 using System;2 using System.Collections.Generic;3 using System.Linq;4 using System.Web;5 using System.Web.Mvc;6 using Microsoft.AspNet.SignalR;7 using Microsoft.AspNet.SignalR.Hubs;8 using SignalRTest.SignalR;9 
10 namespace SignalRTest.Controllers
11 {
12     public class HomeController : Controller
13     {
14         //
15         // GET: /Home/
16         /// <summary>
17         /// 用户界面
18         /// </summary>
19         /// <returns></returns>
20         public ActionResult Index()
21         {
22             return View();
23         }
24 
25         /// <summary>
26         /// web接口,推送消息
27         /// </summary>
28         /// <param name="msg"></param>
29         /// <returns></returns>
30         public string Send(string msg)
31         {
32             var context = GlobalHost.ConnectionManager.GetHubContext<PushHub>();
33             context.Clients.All.addMessage(msg);
34             return "ok";
35         }
36 
37     }
38 }
复制代码
复制代码
复制代码

这时我们来调用一下看看:

这样,我们就可以给客服人员做一个页面,让他们来给指定用户,或者全站用户广播消息了,是不是感觉很棒。

这篇关于MVC使用SignalR 提高B2C商城用户体验1的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1079585

相关文章

如何使用 Python 读取 Excel 数据

《如何使用Python读取Excel数据》:本文主要介绍使用Python读取Excel数据的详细教程,通过pandas和openpyxl,你可以轻松读取Excel文件,并进行各种数据处理操... 目录使用 python 读取 Excel 数据的详细教程1. 安装必要的依赖2. 读取 Excel 文件3. 读

解决Maven项目idea找不到本地仓库jar包问题以及使用mvn install:install-file

《解决Maven项目idea找不到本地仓库jar包问题以及使用mvninstall:install-file》:本文主要介绍解决Maven项目idea找不到本地仓库jar包问题以及使用mvnin... 目录Maven项目idea找不到本地仓库jar包以及使用mvn install:install-file基

Python使用getopt处理命令行参数示例解析(最佳实践)

《Python使用getopt处理命令行参数示例解析(最佳实践)》getopt模块是Python标准库中一个简单但强大的命令行参数处理工具,它特别适合那些需要快速实现基本命令行参数解析的场景,或者需要... 目录为什么需要处理命令行参数?getopt模块基础实际应用示例与其他参数处理方式的比较常见问http

C 语言中enum枚举的定义和使用小结

《C语言中enum枚举的定义和使用小结》在C语言里,enum(枚举)是一种用户自定义的数据类型,它能够让你创建一组具名的整数常量,下面我会从定义、使用、特性等方面详细介绍enum,感兴趣的朋友一起看... 目录1、引言2、基本定义3、定义枚举变量4、自定义枚举常量的值5、枚举与switch语句结合使用6、枚

使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)

《使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)》PPT是一种高效的信息展示工具,广泛应用于教育、商务和设计等多个领域,PPT文档中常常包含丰富的图片内容,这些图片不仅提升了... 目录一、引言二、环境与工具三、python 提取PPT背景图片3.1 提取幻灯片背景图片3.2 提取

Mysql用户授权(GRANT)语法及示例解读

《Mysql用户授权(GRANT)语法及示例解读》:本文主要介绍Mysql用户授权(GRANT)语法及示例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql用户授权(GRANT)语法授予用户权限语法GRANT语句中的<权限类型>的使用WITH GRANT

使用Python实现图像LBP特征提取的操作方法

《使用Python实现图像LBP特征提取的操作方法》LBP特征叫做局部二值模式,常用于纹理特征提取,并在纹理分类中具有较强的区分能力,本文给大家介绍了如何使用Python实现图像LBP特征提取的操作方... 目录一、LBP特征介绍二、LBP特征描述三、一些改进版本的LBP1.圆形LBP算子2.旋转不变的LB

Maven的使用和配置国内源的保姆级教程

《Maven的使用和配置国内源的保姆级教程》Maven是⼀个项目管理工具,基于POM(ProjectObjectModel,项目对象模型)的概念,Maven可以通过一小段描述信息来管理项目的构建,报告... 目录1. 什么是Maven?2.创建⼀个Maven项目3.Maven 核心功能4.使用Maven H

Python中__init__方法使用的深度解析

《Python中__init__方法使用的深度解析》在Python的面向对象编程(OOP)体系中,__init__方法如同建造房屋时的奠基仪式——它定义了对象诞生时的初始状态,下面我们就来深入了解下_... 目录一、__init__的基因图谱二、初始化过程的魔法时刻继承链中的初始化顺序self参数的奥秘默认

SpringBoot使用GZIP压缩反回数据问题

《SpringBoot使用GZIP压缩反回数据问题》:本文主要介绍SpringBoot使用GZIP压缩反回数据问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录SpringBoot使用GZIP压缩反回数据1、初识gzip2、gzip是什么,可以干什么?3、Spr