使用蜘蛛程序来实现电影资料库中的自动填写功能

80酷酷网    80kuku.com

  程序

在新版的“电影资料库”中,ajax被我大范围尝试,以此来提高界面的友好性,比如输入提示效果,div模拟对话框和服务端方法异步调用。

其中,我最得意的是依靠ajax技术实现了一个类似蜘蛛程序(spider),完成表单自动填写。所谓蜘蛛程序,是一个自动在网络上抓取页面内容的程序,这项技术被广泛使用于搜索引擎中,类似google的蜘蛛程序在你的网站上从index开始抓取html内容,遇到连接在按照原先设置好的规则进入下一级页面抓取内容。而这原理也非常简单,只要实现一个类似xml-http访问指定的地址,剩下的就是如何分析html源代码及进行连接跳转了。

在新版本的电影资料库中,使用了asp.net2.0,webservices,atlas来实现所有的ajax实现。关于自动填写电影数据表单,是用户提供一个电影imdb编码,用户点一个连接来使用客户端的js方法来调用一个webservice,页面的内容抓取和分析都依靠webservice中的服务器端方法。调用返回后,在回调函数中赋值到对应的各项(关于atlas:http://atlas.asp.net)

function StartWebSpider()
        {           
            var spider_loading=document.getElementById("spider_loading");
            var imdbresult=document.getElementById('imdbresult');
            var imdbvalue="/document.getElementById('<%=tx_imdb.ClientID" %>').value;
            if (imdbvalue=='')
            {               
                imdbresult.innerHTML="<span spider_loading.innerHTML="";
                return;
            }
            //////web_spider 抓取
            tbmtg.style.visibility="visible";/////显示详细的表单内容
            imdbresult.innerHTML="";
            mtgreleased=
                com.thmz.mtgdb.service.Imdbservice.WebSpiderSearch(imdbvalue,
                OnSpiderSearchComplete,OnTimeOut,OnError);//////调用webservice,实现抓取
            /////显示loading图标           
            spider_loading.innerHTML="<img src="http://www.pushad.com/images/indicator.gif"/>抓取影片数据中...";
            spider_loading.style.visibility="visible";
        }
        //////异步调用超时时调用
        function OnTimeOut(result)
        {
            //alert('time out');
            var imdbresult=document.getElementById('imdbresult');
            imdbresult.innerHTML="<span }
        ///////调用中发生异常时
        function OnError(result)
        {
//            var imdbresult=document.getElementById('imdbresult');
//            imdbresult.innerHTML="<span -_-! </span>";
              var spider_loading=document.getElementById("spider_loading");
                spider_loading.innerHTML="<span spider_loading.style.visibility="visible";
        }
        ////////抓取成功后被调用的函数,在这里给各项表单赋值,返回的result为webservice返回的类型,这里为映射到电影数据库电影表中各个字段的一个简单类(参看ormapping)
        function OnSpiderSearchComplete(result)
        {
            var imdbresult=document.getElementById('imdbresult');
            var imdbvalue="/document.getElementById('<%=tx_imdb.ClientID" %>').value;
            if (result!=null)
            {
                var tbmtg=document.getElementById("tbmtg");
                tbmtg.style.visibility="visible";
                //alert(result.titlecn)
                //debug.dump(result,'result',true);////atlas的调试方法
                //imdbresult.innerHTML=result.titlecn;
                //填充到表单各项
                var tx_titlecn=new Sys.UI.TextBox($('<%=tx_titlecn.ClientID %>'));
                tx_titlecn.initialize();
                var tx_titleen=new Sys.UI.TextBox($('<%=tx_titleen.ClientID %>'));
                tx_titleen.initialize();
                var tx_officalsite=new Sys.UI.TextBox($('<%=tx_officalsite.ClientID %>'));
                tx_officalsite.initialize();
                var tx_manufacture=new Sys.UI.TextBox($('<%=tx_manufacture.ClientID %>'));
                tx_manufacture.initialize();
                var tx_certificate=new Sys.UI.TextBox($('<%=tx_certificate.ClientID %>'));
                tx_certificate.initialize();
                var tx_runtime=new Sys.UI.TextBox($('<%=tx_runtime.ClientID %>'));
                tx_runtime.initialize();
                var tx_tbyear=new Sys.UI.TextBox($('<%=tx_tbyear.ClientID %>'));
                tx_tbyear.initialize();
                if (result.titlecn!=null)
                    tx_titlecn.set_text(result.titlecn);
                if (result.titleen!=null)
                    tx_titleen.set_text(result.titleen);
                if (result.officalsite!=null)
                    tx_officalsite.set_text(result.officalsite);
                if (result.manufacture!=null)
                    tx_manufacture.set_text(result.manufacture);
                if (result.certificate!=null)
                    tx_certificate.set_text(result.certificate);
                if (result.runtime!=null)
                    tx_runtime.set_text(result.runtime);
                if (result.tbyear!=null)
                    tx_tbyear.set_text(result.tbyear);
               
                var genrecol=result.genre.split("/");
                for(g_i=0;g_i<genrecol.length;g_i++)
                {
                    PutCheck(genrecol[g_i]);/////钩上对应的复选框
                }
                var countrycol=result.country.split("/");
                for(c_i=0;c_i<countrycol.length;c_i++)
                {
                    PutCheck(countrycol[c_i]);
                }
                var languagecol=result.dialoglanguage.split("/");
                for(l_i=0;l_i<languagecol.length;l_i++)
                {
                    PutCheck(languagecol[l_i]);
                }
                var colorcol=result.color.split("/");
                for(cl_i=0;cl_i<colorcol.length;cl_i++)
                {
                    PutCheck(colorcol[cl_i]);
                }
                var soundmixcol=result.soundmix.split("/");
                for(s_i=0;s_i<soundmixcol.length;s_i++)
                {
                    PutCheck(soundmixcol[s_i]);////
                }
                               
               
            }
            //////结束loading标记
            var spider_loading=document.getElementById("spider_loading");
            spider_loading.innerHTML="<img src="http://www.pushad.com/images/indicator.gif"/>抓取导演数据中...";
            spider_loading.style.visibility="visible";
        }
       //////钩选对应的复选框
       function PutCheck(checkvalue)
        {
            alllabel=document.all.tags("label");
           
            for(i=0;i<alllabel.length;i++)
            {
                //alert(alllabel(i).innerText);
                if (alllabel(i).innerText==checkvalue)
                {
                    var targetcheck=document.getElementById(alllabel(i).htmlFor);
                    if (targetcheck!=null)
                    {
                        targetcheck.checked=true;
                    }
                }
            }
        }

 



分享到
  • 微信分享
  • 新浪微博
  • QQ好友
  • QQ空间
点击: