答案:除非你代碼里面做了特殊判斷,否則仍然正在執(zhí)行。

注意點(diǎn):

1、客戶端顯示頁面的時(shí)候,后 " /> 国产成人小视频,高h gl肉文,国产亚洲一区二区三区啪

天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

ASP.net 頁面被關(guān)閉后,服務(wù)器端是否仍然執(zhí)行中?

問題:當(dāng)一個(gè)正在執(zhí)行中的ASPX頁面執(zhí)行到一半的時(shí)候,瀏覽器中你關(guān)閉了這個(gè)頁面,服務(wù)器端對(duì)應(yīng)的這個(gè)頁面的代碼仍然在執(zhí)行么?

答案:除非你代碼里面做了特殊判斷,否則仍然正在執(zhí)行。  

注意點(diǎn):

1、客戶端顯示頁面的時(shí)候,后臺(tái)已經(jīng)執(zhí)行完了的頁面對(duì)象早已經(jīng)不存在了。當(dāng)然這時(shí)候談不上服務(wù)器段執(zhí)行不執(zhí)行的問題了。

2、頁面還沒有返回,處于等待狀態(tài)的時(shí)候。關(guān)閉ASPX頁面,才會(huì)涉及到上面提到的服務(wù)器端仍然在執(zhí)行的情況。

3、客戶端關(guān)閉的時(shí)候根本不向服務(wù)器發(fā)送指令。

4、除非你代碼里面做了特殊判斷,這里的特殊判斷指用 if(!Response.IsClientConnected) 來檢測(cè)狀態(tài)而用代碼終止運(yùn)行。

下面的簡(jiǎn)單代碼就是演示關(guān)閉頁面后,看是否仍然在執(zhí)行?

你可以在這個(gè)頁面打開后, 還沒有返回任何信息的時(shí)候把這個(gè)頁面關(guān)閉,然后看指定目錄下是否有對(duì)應(yīng)文件被創(chuàng)建并填寫內(nèi)容。

        protected void Page_Load(object sender, EventArgs e)
        {
            StringBuilder txt = new StringBuilder();

            txt.AppendLine();
            txt.AppendLine(DateTime.Now.ToString("u"));
            txt.AppendLine("asvd");

            Response.Write(DateTime.Now.ToString("u"));
            Response.Write("<br />/r/n");
            Thread.Sleep(50000);


            txt.AppendLine(DateTime.Now.ToString("u"));
            Response.Write(DateTime.Now.ToString("u"));
            Response.Write("<br />/r/n");

            // 把一些信息寫到另外一個(gè)文件,借此察看是否正在運(yùn)行
            string dir = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "logs");
            if (!Directory.Exists(dir))
                Directory.CreateDirectory(dir);
            DateTime dt = DateTime.Now;
            string shortfileName = string.Format("errors_{0:0000}{1:00}{2:00}.log", dt.Year, dt.Month, dt.Day);
            string fileName = Path.Combine(dir, shortfileName);

            StreamWriter sw;
            if (File.Exists(fileName))
                sw = File.AppendText(fileName);
            else
                sw = File.CreateText(fileName);

            sw.Write(txt.ToString());
            sw.Close();
            sw = null;

        } 

作了特殊判斷的情況簡(jiǎn)單例子:

注意: IsClientConnected 的判斷在 VS.NET 開發(fā)工具自帶的開發(fā)站點(diǎn) ASP.NET Development Server  是不支持的。 ASP.NET Development Server 永遠(yuǎn)返回 true 。

IIS 才是支持的。

        protected void Page_Load(object sender, EventArgs e)
        {

            StringBuilder txt = new StringBuilder();

            for (int i = 0; i < 100; i++)
            {
                if (this.Response.IsClientConnected)
                {
                    txt.AppendLine();
                    txt.AppendLine(DateTime.Now.ToString("u"));
                    txt.AppendLine(i.ToString());

                    Response.Write(DateTime.Now.ToString("u"));
                    Response.Write("<br />/r/n");
                    Thread.Sleep(500);
                }
                else
                {
                    Response.End();
                    return;
                }
            }

            txt.AppendLine(DateTime.Now.ToString("u"));
            Response.Write(DateTime.Now.ToString("u"));
            Response.Write("<br />/r/n");

            // 把一些信息寫到另外一個(gè)文件,借此察看是否正在運(yùn)行
            string dir = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "logs");
            if (!Directory.Exists(dir))
                Directory.CreateDirectory(dir);
            DateTime dt = DateTime.Now;
            string shortfileName = string.Format("errors_{0:0000}{1:00}{2:00}.log", dt.Year, dt.Month, dt.Day);
            string fileName = Path.Combine(dir, shortfileName);

            StreamWriter sw;
            if (File.Exists(fileName))
                sw = File.AppendText(fileName);
            else
                sw = File.CreateText(fileName);

            sw.Write(txt.ToString());
            sw.Close();
            sw = null;
        }這個(gè)例子中是發(fā)現(xiàn)中斷,就拋棄之前做的任何東西。

當(dāng)然我們也可以簡(jiǎn)單的修改上述代碼,讓把已經(jīng)處理完成的東西記錄下來,類似下面的代碼

        protected void Page_Load(object sender, EventArgs e)
        {
            StringBuilder txt = new StringBuilder();

            for (int i = 0; i < 100; i++)
            {
                if (this.Response.IsClientConnected)
                {
                    txt.AppendLine();
                    txt.AppendLine(DateTime.Now.ToString("u"));
                    txt.Append("**********  ");
                    txt.AppendLine(i.ToString());

                    Response.Write(DateTime.Now.ToString("u"));
                    Response.Write("<br />/r/n");
                    Thread.Sleep(500);
                }
                else
                {
                    break;
                }
            }

            txt.AppendLine(DateTime.Now.ToString("u"));
            Response.Write(DateTime.Now.ToString("u"));
            Response.Write("<br />/r/n");

            // 把一些信息寫到另外一個(gè)文件,借此察看是否正在運(yùn)行
            string dir = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "logs");
            if (!Directory.Exists(dir))
                Directory.CreateDirectory(dir);
            DateTime dt = DateTime.Now;
            string shortfileName = string.Format("errors_{0:0000}{1:00}{2:00}.log", dt.Year, dt.Month, dt.Day);
            string fileName = Path.Combine(dir, shortfileName);

            StreamWriter sw;
            if (File.Exists(fileName))
                sw = File.AppendText(fileName);
            else
                sw = File.CreateText(fileName);

            sw.Write(txt.ToString());
            sw.Close();
            sw = null;
        }需要注意的是, 使用 isClientConnected   是要占用一定的系統(tǒng)資源的。 

isClientConnected   實(shí)際上需要向客戶端輸出一點(diǎn)東西,然后才知道客戶端是否仍然在線。

這樣,除非你的應(yīng)用非常耗時(shí),否則建議你不要用 isClientConnected   。 免得判斷 isClientConnected   使用的資源比你實(shí)際業(yè)務(wù)邏輯使用的資源還要多。

在任何情況下, Response.IsClientConnected 都要有些開銷,所以,只有在執(zhí)行至少要用 500 毫秒(如果想維持每秒幾十頁的吞吐量,這是一個(gè)很長(zhǎng)的時(shí)間了)的操作前才使用它。作為通常的規(guī)則,不要在緊密循環(huán)的每次迭代中調(diào)用它,例如當(dāng)繪制表中的行,可能每  20 行或每 50 行調(diào)用一次。

AspNet技術(shù)ASP.net 頁面被關(guān)閉后,服務(wù)器端是否仍然執(zhí)行中?,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 4455永久在线毛片观看 | 毛片亚洲毛片亚洲毛片 | 国产亚洲精品久久久久久国 | 小蝌蚪视频在线观看免费观看WWW | 日本学生VIDEOVIDEOS更新 日本性xxx | 韩国羞羞秘密教学子开车漫书 | 精品视频免费在线观看 | 亚洲黄色免费在线观看 | 色综合精品无码一区二区三区 | 亚洲香蕉视频在线播放 | 日韩精品亚洲专区在线电影不卡 | 免费在线观看的毛片 | 秀婷程仪公欲息肉婷在线观看 | 色尼玛亚洲综合 | 久久亚洲精品永久网站 | 丰满老熟女白浆直流 | 国产高清-国产av | 久久AV国产麻豆HD真实 | A级韩国乱理伦片在线观看 a级成人免费毛片完整版 | 国产人成精品综合欧美成人 | 和尚扒开双腿蹂躏 | 琪琪SEE色原网色原网站18 | 视频区 国产 欧美 日韩 | 伦理片飘花手机在线 | 亚在线观看免费视频入口 | 性xxxx直播放免费 | 97久久超碰中文字幕 | 真实国产乱子伦精品一区二区三区 | 免费人妻AV无码专区五月 | 啦啦啦WWW在线观看免费高清版 | 中文字幕视频在线免费观看 | 748亚洲大胆国模人体 | 国产99久久久欧美黑人刘玥 | 日本高清免费一本视频在线观看 | av在线不卡中文网 | 国产麻豆剧果冻传媒免费网站 | 欧美日韩精品 | 色mimi| 1973性农场未删减版 | 国产成人亚洲精品午夜国产馆 | 欧美video巨大粗暴18 |