项目要求是页面监测到后台数据库用户数据(Users)变化,前台做出相应的响应和操作。

一、参考很多资料,大概有几种方式:

参考资料地址:http://www.cnblogs.com/hoojo/p/longPolling_comet_jquery_iframe_ajax.html

客户端不停的向服务器发送请求以获取最新的数据信息。

轮询:客户端定时向服务器发送Ajax请求,服务器接到请求后马上返回响应信息并关闭连接。
优点:后端程序编写比较容易。
缺点:请求中有大半是无用,浪费带宽和服务器资源。
实例:适于小型应用。

长轮询:客户端向服务器发送Ajax请求,服务器接到请求后hold住连接,直到有新消息才返回响应信息并关闭连接,客户端处理完响应信息后再向服务器发送新的请求。
优点:在无消息的情况下不会频繁的请求,耗费资源小。
缺点:服务器hold连接会消耗资源,返回数据顺序无保证,难于管理维护。
实例:WebQQ、Hi网页版、Facebook IM。

长连接:在页面里嵌入一个隐蔵iframe,将这个隐蔵iframe的src属性设为对一个长连接的请求或是采用xhr请求,服务器端就能源源不断地往客户端输入数据。
优点:消息即时到达,不发无用请求;管理起来也相对方便。
缺点:服务器维护一个长连接会增加开销。
实例:Gmail聊天

Flash Socket:在页面中内嵌入一个使用了Socket类的 Flash 程序JavaScript通过调用此Flash程序提供的Socket接口与服务器端的Socket接口进行通信,JavaScript在收到服务器端传送的信息后控制页面的显示。
优点:实现真正的即时通信,而不是伪即时。
缺点:客户端必须安装Flash插件;非HTTP协议,无法自动穿越防火墙。
实例:网络互动游戏。

其博文中最后提到基于html5WebSocket通信方式无奈楼主是新手,没有学习过,只能根据自己的理解来写代码。

二、代码

//login页面                                  var GetWeiXinLogin = function () {
$.ajax({
url: "/Member/GetWeiXinLogin.html",
data: "Sceneid=@(Sceneid)",
type: "get",
success: function (data) {
var dataObj = eval("(" + data + ")");
                           if (dataObj.reg == "success") { alert('登录成功'); }
}
})
}

login页面 代码很简单,就是利用ajax无限访问后台的方法,该方法主要检测数据库数据变化。

  public void GetWeiXinLogin(int Sceneid)
{
string reg = "{\"reg\":\"408\"}";
string Sql = " SELECT * FROM WeiXinQRCodeTemporaryLog WHERE (Sceneid = " + Sceneid + ") "; //查询语句
for (int i = ; i < ; i++) //执行10次 总计20秒
{
var WeiXinQRCodeTemporaryLogBySql = Entity.ExecuteStoreQuery<WeiXinQRCodeTemporaryLog>(Sql); //EF执行语句
int PUid = WeiXinQRCodeTemporaryLogBySql.FirstOrNew().Uid.GetValueOrDefault();
if (PUid != ) //判断数据变化,如果==0 则前台得到相应
{
Users BaseUsers = Entity.Users.FirstOrNew(n => n.Uid == PUid);
reg = "{\"reg\":\"success\",\"UTid\":\"" + BaseUsers.UTid + "\"}"; #region 登陆
用户登录程序过程,省略... #endregion
break;
}
System.Threading.Thread.CurrentThread.Join(); //没2秒执行一次
}
Response.Write(reg);
Response.End();
}

上面代码就是监测数据变化的简单程序,有高手应该看出问题了,代码的确是能实现想要的效果,但是你会发现,网站慢得让你奔溃!

比如我们访问login页面 的同时去访问我们同一个网站页面的Index.html页面,这个时候我们的Index.html页面加载非常得慢,一定会等到我们的异步加载完之后才能加载出我们的Index页面。

这只是个人开发过程中遇到问题的小小记录,勿喷哈,还请高手帮忙看看,初步估计问题就出在数据库访问和页面请求上。

MVC4 + EF + System.Threading.Thread 出现的问题记录的更多相关文章

  1. C#中的线程四(System.Threading.Thread)

    C#中的线程四(System.Threading.Thread) 1.最简单的多线程调用 System.Threading.Thread类构造方法接受一个ThreadStart委托,改委托不带参数,无 ...

  2. 异常System.Threading.Thread.AbortInternal

    异常信息: System.Threading.ThreadAbortException: 正在中止线程. 在 System.Threading.Thread.AbortInternal() 在 Sys ...

  3. .Net 指定时间段内定时执行的Windows服务(System.Threading.Thread)

    创建一个Windows服务项目:解决方案(右击)——> 添加 ——> 新建项目——>项目类型选择Windows——>模板选择Windows服务 ,如图: 编写Windows服务 ...

  4. c# System.Threading.Thread

    using System; using System.Threading; // Simple threading scenario: Start a static method running // ...

  5. System.Threading.Thread的使用及传递参数等总结

    using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threa ...

  6. 【.Net 学习系列】-- .Net 指定时间段内定时执行的Windows服务(System.Threading.Thread)

    创建一个Windows服务项目:解决方案(右击)——> 添加 ——> 新建项目——>项目类型选择Windows——>模板选择Windows服务 ,如图: 编写Windows服务 ...

  7. using System.Threading;

    /// <summary> /// 执行动作:耗时而已 /// </summary> private void TestThread(string threadName) { ...

  8. 多线程学习系列二(使用System.Threading)

    一.什么是System.Threading.Thread?如何使用System.Threading.Thread进行异步操作 System.Threading.Thread:操作系统实现线程并提供各种 ...

  9. 【异常记录(九)】 System.Threading.ThreadAbortException: 正在中止线程

    报错如下: System.Threading.ThreadAbortException: Thread was being aborted. at System.Threading.Thread.Ab ...

随机推荐

  1. 实现android apk反编译后代码混淆

    通常情况下我们需要对我们开发的android代码进行混淆,以免代码在反编译时暴露敏感信息及相关技术代码: 反编译测试工具:onekey-decompile-apk-1.0.1. 在高级版本的adt创建 ...

  2. js与objective-c的交互-备

    在写 JavaScript 的时候,可以使用一个叫做 window 的对象,像是我们想要从现在的网页跳到另外一个网页的时候,就会去修改 window.location.href 的位置:在我们的 Ob ...

  3. 在UC浏览器上很炫的一个效果

    效果简述: 这个效果将会强行去除UC浏览器的网址输入框和底部的菜单栏,这样网页将会占据整个手机界面.感觉看起来很像是一个APP. 浏览器界面右下角将会出现一个向上的标志,用来唤出简单的菜单栏. (界面 ...

  4. adb链接手机调试android应用

    adb链接手机调试android应用 hulk@hulk-Lenovo:~$ adb devices List of devices attached  ???????????? no permiss ...

  5. HTTPS证书生成原理和部署细节

    看看下面,部分电信用户访问京东首页的时候,会看到右下角有一个浮动广告: 小白用户以为是京东有意放置的,细心的用户会发现,这个 iframe 一层嵌一层的恶心广告很明显是电信/中间人通过 DNS 劫持注 ...

  6. 01_docker学习总结

    01 docker学习总结 toolbox https://hub.docker.com/ https://docs.docker.com/engine/installation/mac/#from- ...

  7. LINQ to SQL 增,删,改

    添加   InsertOnSubmit(单个对象)  或  InsertAllOnSubmit(集合) 删除   DeleteOnSubmit (单个对象)             DeleteAll ...

  8. 动态规划之最长公共子序列LCS(Longest Common Subsequence)

    一.问题描述 由于最长公共子序列LCS是一个比较经典的问题,主要是采用动态规划(DP)算法去实现,理论方面的讲述也非常详尽,本文重点是程序的实现部分,所以理论方面的解释主要看这篇博客:http://b ...

  9. 创建UIButton

    UIButtonCreate.h #import <UIKit/UIKit.h> @interface UIButtonCreate : UIButton /** * 创建UIButton ...

  10. uva 310 L--system(隐式图搜索+字符串处理)

     L-system  A D0L (Deterministic Lindenmayer system without interaction) system consists of a finite ...