signalR制作微信墙 开源
微信墙
上一篇文章中已经用PHP搭建了一个微信墙获取信息的服务器,我这里使用微软的signalr搭建一个客户端,signalr是一个为开发者开发实时应用的 一个库文件,支持windows server 2008 r2+,win7,win8 windows azure,可以使用iis8托管,iis7必须支持 extensionless URLs 。下图是浏览器支持情况
其实据我所知,你可以再微软的任何技术中使用signalr比如wpf,winform等等中都可以,只不过要引入相应的dll文件,而且可以在高强度的环境下使用signalr,比如股市网站实时绘制波形图。更多信息请直接去官网查看,传送门 。项目源码 传送门
准备工作
首先创建一个asp.net mvc 5 的项目
在项目中引入必要的文件,我这里使用了mongo做数据库所以要引入mongo的驱动,直接使用nuget搜索即可,如下图
这里我们使用signalr做实时推送,直接安装Microsoft Asp.Net AsignalR即可,他会引入项目中所需要的必要依赖项
项目中使用模拟登陆获取人物图片,我用了自己写好的Utility库,里面有常用的cookie封装,cache封装,http客户端等等几十个操作,nuget搜索yeanzhi即可(p.s.这一步理论上应该在服务器中直接获取图片信息的,因为服务器用的PHP,图片没办法和这个项目共享(除非使用第三方图床),所以图片在这里下载,其实可以服务器都用.NET做,短时间直接一个ConsoleApplication就行,长时间的话写一个服务用定时器调用就好了,不过这两天在做PHP的实时推送,到时候还要用PHP写一个后台怪麻烦的,后期会放出来PHP的微信墙客户端)
这些都完成了,我们的准备工作也就差不多了
编码工作
我在项目中创建了微信常用的模拟操作,如下图,一会和微信打交道的操作都有他们完成,源码在github上面
我们首先要更改Home下的index,更换email和password即可登录微信,登陆成功会跳转到GetInfo,这里之所以会单独初始化一下是为了防止以后每次去微信拿数据都要登录一遍来获取token和cookie,如果单位时间内登录次数过多微信会有一个二维码的校验,这个就十分麻烦了,所以我们登录一次,将cookie和token放到缓存中,以后从缓存中拿数据
public ActionResult Index()
{
if (WeiXinLogin.ExecLogin("email", "password"))
{
return RedirectToAction("GetInfo");
}
return View();
}
下面的方法是从mongo中拿到我们PHPserver存放进去的数据,同时检测有没有下载这个人的头像,如果没有下载,就去下载,其中判断函数和下载函数直接去源码中查看即可,我都放到了HomeController 里面,没有进行进一步封装
public ActionResult GetInfo()
{
MongoUtil mongo = new MongoUtil();
var colloction = mongo.getCollection("message");
var res = colloction.FindAll().ToList();
foreach (var item in res)
{
if (!IsExitImage(item.fakeid))
{
DownImage(item.fakeid);
}
}
return View(res);
}
一切顺利的话我们访问/Home/Index 微信模拟登陆登陆成功,页面就会重定向到/Home/GetInfo 这里,我是用了bootstrap简单的写了一个页面,时间戳没有处理直接输出了如下图
接下来该准备推送的事情了,我们再一次明确一下需求,上一个图中我们点击上墙,这条消息应该就会被推送到微信墙那个页面,下面我们做推送的事情,首先肯定是要初始化signalr的一些操作的,我们创建一个Hubs的文件夹,在文件夹中创建一个WeChatHub的类继承Hub,如下
public class WeChatHub : Hub
{
public void Send(string name, string message)
{
Clients.All.addData(name, message);
}
}
然后我们在根目录下创建一个Startup文件用来在程序运行之处初始化SignalR,代码如下
[assembly: OwinStartup(typeof(WeChatWallClient.NET.Startup))]
namespace WeChatWallClient.NET
{
public class Startup
{
public void Configuration(IAppBuilder app)
{
app.MapSignalR();
}
}
}
接下来我们需要一个action创建一个代理去调用hub,将信息推送出去,代码如下
public ActionResult Sq(string id)
{
var hubContext = GlobalHost.ConnectionManager.GetHubContext<WeChatHub>();
if (hubContext != null)
{
ObjectId objid = new ObjectId(id);
MongoUtil mongo = new MongoUtil();
var colloction = mongo.getCollection("message");
var msg = colloction.AsQueryable<Msg>().FirstOrDefault(a => a.Id == objid);
if (msg!=null)
{
hubContext.Clients.All.addData(msg);
}
}
return RedirectToAction("GetInfo");
}
接下来我们创建一个Client页面用来展现微信墙的一些操作,效果如下
接着引入jquery.signalR.js ,注册signalr路由,创建一个代理与后端addData进行通讯,代码如下
<script src="~/Scripts/jquery.signalR-2.2.0.min.js"></script>
<script src="~/signalr/hubs"></script>
<script type="text/javascript">
$(function () {
var chat = $.connection.weChatHub;
chat.client.addData = function (data) {
$("#UL").append('<li>\
<div class="single">\
<div class="pic">\
<img src="/corvers/' + data.fakeid + '.jpg">\
</div>\
<div class="message">\
<div class="s-name">\
<span>' + data.nick_name + '</span> :\
</div>\
<div class="s-word">' + data.content + '\
</div>\
</div>\
</div>\
</li>');
Slide();
$("#total-num").text(++total);
};
});
</script>
现在所有的工作都做好了,我们点击一下上墙,看看效果还不错,如下图
后记&总结
其实整个流程很清楚了,我是从我给我们OurEDA实验室做的微信公众平台中抽取出来的这部分代码,也去除了一些无关的功能,demo中没有什么高级的oop手法,除了伸手党,真想学的看起来应该会很轻松,这个功能当时做也就花了不到两个小时前端后端服务器就都出来了。本来是想给出PHP下的,但是这两天放假回家想来实时通信这块需要后台PHP再写一个socket,和signalr一比较好像有点得不偿失,还不如ajax长轮询,但是这样的话就与平台无关了,想想还有没有什么别的方法,如果想出来了再写一个PHP版本的,欢迎大家一起讨论
另外求助园友一个事情,我回家以后github,composer访问不稳定,连mongo官网都上不去了,nydusvpn,GreenVPN都试过了,不好用,我怀疑是电信禁用了vpn,大家有什么建议没,我家的网是电信10M光纤。。。谢谢了
signalR制作微信墙 开源的更多相关文章
- PHP微信墙制作,开源
PHP微信墙制作 微信墙 PHP 注意:由于微信官网不定时会更新,其中模拟登陆以及爬取数据的方式可能会失效,最近这12个月里,就有两次更新导致此功能需要重写. 服务端源码->github地址传送 ...
- HTML5服务器端推送事件 解决PHP微信墙推送问题
问题描述 以前的文章中<PHP微信墙制作,开源>已经用PHP搭建了一个微信墙获取信息的服务器,然后我就在想推送技术应该怎么解决,上一篇已经用了.NET 的signalr做了一个微信墙,PH ...
- 教你用Python制作微信好友背景墙
目录: 0 引言 1 环境 2 代码实现 3 后记 0 引言 前段时间,微信朋友圈开始出现了一种晒照片新形式,微信好友墙,即在一张大图片中展示出自己的所有微信好友的头像. 效果如下图,出于隐私考虑,这 ...
- PHP微信墙制作
微信墙 PHP 注意:由于微信官网不定时会更新,其中模拟登陆以及爬取数据的方式可能会失效,最近这12个月里,就有两次更新导致此功能需要重写. 服务端源码->github地址传送门 思路 其实实现 ...
- .Net Webapi SignalR与微信小程序的交互
.Net Webapi SignalR与微信小程序的交互 一.SignalR与Webapi 1.SignalR的安装: Signalr与跨域仅需要安装两个开源库 Microsoft.Owin.Cors ...
- Pygame制作微信打飞机游戏PC版
使用Pygame制作微信打飞机游戏PC版 转至:http://www.cnblogs.com/dukeleo/p/3339780.html 前一阵子看了一篇文章:青少年如何使用Python开始游戏 ...
- 如何制作微信动态表情包 GIF制作工具哪个好
表情包已经成为我们生活聊天中必不可少的一部分,但是如何制作微信动态表情包呢?自己制作的表情包更加独有个性,今天小编带大家看一波原创表情包的制作方法吧! 使用工具:电脑 操作方法: 1.首先在手机上也是 ...
- [教程]微信官方开源UI库-WeUI使用方法【申明:来源于网络】
[教程]微信官方开源UI库-WeUI使用方法 [ 教程]微信官方开源UI库-WeUI使用方法 地址:http://www.weui.org.cn/?/article/1 微信公众号开发-WeUI使用说 ...
- 如何利用python制作微信好友头像照片墙?
这个不难,主要用到itchat和pillow这2个库,其中itchat用于获取微信好友头像照片,pillow用于拼接头像生成一个照片墙,下面我简单介绍一下实现过程,代码量不多,也很好理解,实验环境wi ...
随机推荐
- Sql 数据引擎中删除用户名、密码信息
SQl版本:Microsoft SQL Server 2008 R2 系统:Windows Server 2008 R2 Enterprise 删除文件为:SqlStudio.bin 删除星系路径:C ...
- C# 接口应用及意义
写在前面:新手入行,读者勉强看看吧,写的不对的欢迎讨论,板砖轻拍! 一.定义 接口描述的是可属于任何类或结构的一组相关功能,所以实现接口的类或结构必须实现接口定义中指定的接口成员. 通常用Interf ...
- Office 开发版本号与版本对应关系
Office 开发版本号与版本对应关系: office97 : 8.0 office2000 : 9.0 officeXP(2002) : 10.0 office2003 : 11.0 office2 ...
- KMP算法简明扼要的理解
KMP算法也算是相当经典,但是对于初学者来说确实有点绕,大学时候弄明白过后来几年不看又忘记了,然后再弄明白过了两年又忘记了,好在之前理解到了关键点,看了一遍马上又能理解上来.关于这个算法的详解网上文章 ...
- (Java和C++)二进制date数据写进android保存为yuv格式
Java实现函数: String strpath = "/storage/emulated/0/DCIM/" + i + "output.yuv"; bool ...
- 使用阿里Docker镜像加速器加速
在阿里开发者平台注册开发者账号 https://dev.aliyun.com/search.html 注册之后可以访问Docker镜像服务 https://cr.console.aliyun.com/ ...
- ZTSD_008_1表没有某订单数据,无法回写交期
ZTSD_008_1表没有某订单数据,无法回写交期, 取系SAP组检查执行此RFC:ZFM_FP_025_1 为什么没有将数据导进来 select * from SAPSR3.ZTSD_008_1@S ...
- Keynote of Python III
[Keynote of Python III] 1.许多大型网站是用Python开发的,例如YouTube.Instagram,还有国内的豆瓣.很多大公司,包括Google.Yahoo等,甚至NASA ...
- VS2010英文版修改删除、注释快捷键
VS2010英文版修改删除.注释快捷键 打开快捷键修改面板,然后修改
- Python全栈之路6--正则表达式
正则本身就是一门语言: 正则表达式使用单个字符串来描述.匹配一系列符合某个句法规则的字符串,在文本处理方面功能非常强大,也经常用作爬虫,来爬取特定内容,Python本身不支持正则,但是通过导入re模块 ...