成都创新互联网站制作重庆分公司

python中怎么实现分布式抓取网页

python中怎么实现分布式抓取网页,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

成都创新互联公司专注为客户提供全方位的互联网综合服务,包含不限于成都做网站、网站制作、安吉网络推广、重庆小程序开发、安吉网络营销、安吉企业策划、安吉品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;成都创新互联公司为所有大学生创业者提供安吉建站搭建服务,24小时服务热线:13518219792,官方网址:www.cdcxhl.com

[python]
view plaincopy

  1. '''''

  2. Created on 2010-9-15

  3. @author: chenggong

  4. '''

  5. import urllib2  

  6. import re  

  7. import socket  

  8. DEBUG = 0

  9. '''''

  10. 工具类

  11. '''

  12. class Tools():  

  13.     #log函数

  14.     @staticmethod

  15.     def writelog(level,info,notify=False):  

  16.         if DEBUG == 0:  

  17.             try:  

  18.                 print "["+level+"]"+info.decode('UTF-8').encode('GBK')   

  19.             except:  

  20.                 print "["+level+"]"+info.encode('GBK')   

  21.         else:  

  22.             print "["+level+"]"+info  

  23.         #if notify:

  24.         #    print "[notify]报告管理员!!"

  25.     #转unicode

  26.     @staticmethod

  27.     def toUnicode(s,charset):  

  28.         if( charset == "" ):  

  29.             return s  

  30.         else:  

  31.             try:  

  32.                 u = unicode( s, charset )  

  33.             except:  

  34.                 u = ""  

  35.         return u   

  36.     #正则抓取

  37.     #@param single 是否只抓取一个

  38.     @staticmethod

  39.     def getFromPatten(patten,src,single=False):  

  40.         rst = "";  

  41.         p = re.compile(patten,re.S)  

  42.         all = p.findall(src)  

  43.         for matcher in all:  

  44.             rst += matcher + " "

  45.             if( single ):  

  46.                 break

  47.         return rst.strip()  

  48. '''''

  49. 网页内容爬虫

  50. '''

  51. class PageGripper():  

  52.     URL_OPEN_TIMEOUT = 10 #网页超时时间

  53.     MAX_RETRY = 3 #最大重试次数

  54.     def __init__(self):  

  55.         socket.setdefaulttimeout(self.URL_OPEN_TIMEOUT)  

  56.     #获取字符集

  57.     def getCharset(self,s):  

  58.         rst = Tools.getFromPatten(u'charset=(.*?)"',s,True)  

  59.         if rst != "":  

  60.             if rst == "utf8":  

  61.                 rst = "utf-8"

  62.         return rst  

  63.     #尝试获取页面

  64.     def downloadUrl(self,url):  

  65.         charset = ""  

  66.         page = ""  

  67.         retry = 0

  68.         while True:  

  69.             try:  

  70.                 fp = urllib2.urlopen(url)  

  71.                 break

  72.             except urllib2.HTTPError,e: #状态错误

  73.                 Tools.writelog('error','HTTP状态错误 code='+e.code)  

  74.                 raise urllib2.HTTPError  

  75.             except urllib2.URLError,e: #网络错误超时

  76.                 Tools.writelog('warn','页面访问超时,重试..')  

  77.                 retry+=1

  78.                 if( retry > self.MAX_RETRY ):  

  79.                     Tools.writelog('warn','超过最大重试次数,放弃')  

  80.                     raise urllib2.URLError  

  81.         while True:  

  82.             line = fp.readline()  

  83.             if charset == "":  

  84.                 charset = self.getCharset(line)  

  85.             if not line:  

  86.                 break

  87.             page += Tools.toUnicode(line,charset)  

  88.         fp.close()  

  89.         return page  

  90.     #获取页面

  91.     def getPageInfo(self,url):  

  92.         Tools.writelog( "info","开始抓取网页,url= "+url)  

  93.         info = ""  

  94.         try:  

  95.             info = self.downloadUrl(url)  

  96.         except:  

  97.             raise

  98.         Tools.writelog("debug","网页抓取成功")  

  99.         return info  

  100. '''''

  101. 内容提取类

  102. '''

  103. class InfoGripper():  

  104.     pageGripper = PageGripper()  

  105.     def __init__(self):  

  106.         Tools.writelog('debug',"爬虫启动")  

  107.     #抓取标题

  108.     def griptitle(self,data):  

  109.         title = Tools.getFromPatten(u'box2t sp">

    (.*?)

    ', data, True)  

  110.         if title == "":  

  111.             title = Tools.getFromPatten(u'(.*?)[-<]',data,True)  </p></li><li><p>        return title.strip()  </p></li><li><p></p></li><li><p>    #抓取频道</p></li><li><p>    def gripchannel(self,data):  </p></li><li><p>        zone = Tools.getFromPatten(u'频道:(.*?)</span>',data,True)  </p></li><li><p>        channel = Tools.getFromPatten(u'<a.*?>(.*?)</a>',zone,True)  </p></li><li><p>        return channel  </p></li><li><p></p></li><li><p>    #抓取标签</p></li><li><p>    def griptag(self,data):  </p></li><li><p>        zone = Tools.getFromPatten(u'标签:(.*?)</[^a].*>',data,True);  </p></li><li><p>        rst = Tools.getFromPatten(u'>(.*?)</a>',zone,False);  </p></li><li><p>        return rst  </p></li><li><p></p></li><li><p>    #抓取观看次数</p></li><li><p>    def gripviews(self,data):  </p></li><li><p>        rst = Tools.getFromPatten(u'已经有<em class="hot" id="viewcount">(.*?)</em>次观看',data);  </p></li><li><p>        return rst  </p></li><li><p></p></li><li><p>    #抓取发布时间</p></li><li><p>    def griptime(self,data):  </p></li><li><p>        rst = Tools.getFromPatten(u'在<em>(.*?)</em>发布',data,True)  </p></li><li><p>        return rst  </p></li><li><p></p></li><li><p>    #抓取发布者</p></li><li><p>    def gripuser(self,data):  </p></li><li><p>        rst = Tools.getFromPatten(u'title="点击进入(.*?)的用户空间"',data,True)  </p></li><li><p>        return rst  </p></li><li><p></p></li><li><p>    #获取页面字符集</p></li><li><p>    def getPageCharset(self,data):  </p></li><li><p>        charset = Tools.getFromPatten(u'charset=(.*?)"',data,True)  </p></li><li><p></p></li><li><p>        if( charset == "utf8" ):  </p></li><li><p>            charset = "utf-8"</p></li><li><p>        return charset  </p></li><li><p></p></li><li><p>    #获取CC相关数据</p></li><li><p>    def getCCData(self,data):  </p></li><li><p></p></li><li><p>        zone = Tools.getFromPatten(u'SWFObject(.*?)</script>',data,True)  </p></li><li><p></p></li><li><p>        #判断是否使用bokecc播放</p></li><li><p>        isFromBokeCC = re.match('.*bokecc.com.*', zone)  </p></li><li><p>        if( not isFromBokeCC ):  </p></li><li><p>            return "",""  </p></li><li><p></p></li><li><p>        ccSiteId = Tools.getFromPatten(u'siteid=(.*?)[&,"]',zone,True)  </p></li><li><p>        ccVid = Tools.getFromPatten(u'vid=(.*?)[&,"]',zone,True)  </p></li><li><p>        return ccSiteId,ccVid  </p></li><li><p></p></li><li><p>    #获取站内vid</p></li><li><p>    def gripVideoId(self,data):  </p></li><li><p>        vid = Tools.getFromPatten(u'var vid = "(.*?)"',data,True)  </p></li><li><p>        return vid  </p></li><li><p></p></li><li><p>    #获取点击量</p></li><li><p>    def gripViewsAjax(self,vid,url,basedir):  </p></li><li><p>        host = Tools.getFromPatten(u'http://(.*?)/',url,True)  </p></li><li><p>        ajaxAddr = "http://" + host + basedir + "/index.php/ajax/video_statistic/" + vid  </p></li><li><p>        '''''</p></li><li><p>        try:</p></li><li><p>            content = self.pageGripper.getPageInfo(ajaxAddr)</p></li><li><p>        except Exception,e:</p></li><li><p>            print e</p></li><li><p>            Tools.writelog ("error", ajaxAddr+u"抓取失败")</p></li><li><p>            return "error"</p></li><li><p>        '''</p></li><li><p>        Tools.writelog('debug', u"开始获取点击量,url="+ajaxAddr)  </p></li><li><p>        while True:  </p></li><li><p>            try:  </p></li><li><p>                fp = urllib2.urlopen(ajaxAddr)  </p></li><li><p>                break</p></li><li><p>            except urllib2.HTTPError,e: #状态错误</p></li><li><p>                Tools.writelog('error','HTTP状态错误 code='+"%d"%e.code)  </p></li><li><p>                return ""  </p></li><li><p>            except urllib2.URLError,e: #网络错误超时</p></li><li><p>                Tools.writelog('warn','页面访问超时,重试..')  </p></li><li><p>                retry+=1</p></li><li><p>                if( retry > self.MAX_RETRY ):  </p></li><li><p>                    Tools.writelog('warn','超过最大重试次数,放弃')  </p></li><li><p>                    return ""  </p></li><li><p>        content = fp.read()  </p></li><li><p>        fp.close()  </p></li><li><p>        views = Tools.getFromPatten(u'"viewcount":(.*?),',content,True)  </p></li><li><p>        views = views.replace('"','')  </p></li><li><p>        return views  </p></li><li><p></p></li><li><p>    #从网页内容中爬取点击量 </p></li><li><p>    def gripViewsFromData(self,data):  </p></li><li><p>        views = Tools.getFromPatten(u'已经有<.*?>(.*?)<.*?>次观看',data,True)  </p></li><li><p>        return views  </p></li><li><p></p></li><li><p>    def gripBaseDir(self,data):  </p></li><li><p>        dir = Tools.getFromPatten(u"base_dir = '(.*?)'",data,True)  </p></li><li><p>        return dir  </p></li><li><p></p></li><li><p>    #抓取数据</p></li><li><p>    def gripinfo(self,url):   </p></li><li><p></p></li><li><p>        try:  </p></li><li><p>            data = self.pageGripper.getPageInfo(url)  </p></li><li><p>        except:  </p></li><li><p>            Tools.writelog ("error", url+" 抓取失败")  </p></li><li><p>            raise</p></li><li><p></p></li><li><p>        Tools.writelog('info','开始内容匹配')  </p></li><li><p>        rst = {}  </p></li><li><p>        rst['title'] = self.griptitle(data)  </p></li><li><p>        rst['channel'] = self.gripchannel(data)  </p></li><li><p>        rst['tag'] = self.griptag(data)  </p></li><li><p>        rst['release'] = self.griptime(data)  </p></li><li><p>        rst['user'] = self.gripuser(data)  </p></li><li><p>        ccdata = self.getCCData(data)  </p></li><li><p>        rst['ccsiteId'] = ccdata[0]  </p></li><li><p>        rst['ccVid'] = ccdata[1]  </p></li><li><p>        views = self.gripViewsFromData(data)  </p></li><li><p>        if views =="" or not views:  </p></li><li><p>            vid = self.gripVideoId(data)  </p></li><li><p>            basedir = self.gripBaseDir(data)  </p></li><li><p>            views = self.gripViewsAjax(vid,url,basedir)  </p></li><li><p>            if( views == "" ):  </p></li><li><p>                views = "error"</p></li><li><p>            if( views == "error"):  </p></li><li><p>                Tools.writelog("error","获取观看次数失败")  </p></li><li><p>        Tools.writelog("debug","点击量:"+views)  </p></li><li><p>        rst['views'] = views  </p></li><li><p>        Tools.writelog('debug','title=%s,channel=%s,tag=%s'%(rst['title'],rst['channel'],rst['tag']))  </p></li><li><p>        return rst  </p></li><li><p></p></li><li><p>'''''</p></li><li><p>单元测试</p></li><li><p>'''</p></li><li><p>if __name__ == '__main__':  </p></li><li><p>    list = [  </p></li><li><p>            'http://008yx.com/xbsp/index.php/video/index/3138',  </p></li><li><p>            'http://vblog.xwhb.com/index.php/video/index/4067',  </p></li><li><p>            'http://demo.ccvms.bokecc.com/index.php/video/index/3968',  </p></li><li><p>            'http://vlog.cnhubei.com/wuhan/20100912_56145.html',  </p></li><li><p>            'http://vlog.cnhubei.com/html/js/30271.html',  </p></li><li><p>            'http://www.ddvtv.com/index.php/video/index/15',  </p></li><li><p>            'http://boke.2500sz.com/index.php/video/index/60605',  </p></li><li><p>            'http://video.zgkqw.com/index.php/video/index/334',  </p></li><li><p>            'http://yule.hitmv.com/html/joke/27041.html',  </p></li><li><p>            'http://www.ddvtv.com/index.php/video/index/11',  </p></li><li><p>            'http://www.zgnyyy.com/index.php/video/index/700',  </p></li><li><p>            'http://www.kdianshi.com/index.php/video/index/5330',  </p></li><li><p>            'http://www.aoyatv.com/index.php/video/index/127',  </p></li><li><p>            'http://v.ourracing.com/html/channel2/64.html',  </p></li><li><p>            'http://v.zheye.net/index.php/video/index/93',  </p></li><li><p>            'http://vblog.thmz.com/index.php/video/index/7616',  </p></li><li><p>            'http://kdianshi.com/index.php/video/index/5330',  </p></li><li><p>            'http://tv.seeyoueveryday.com/index.php/video/index/95146',  </p></li><li><p>            'http://sp.zgyangzhi.com/html/ji/2.html',  </p></li><li><p>            'http://www.xjapan.cc/index.php/video/index/146',  </p></li><li><p>            'http://www.jojy.cn/vod/index.php/video/index/399',  </p></li><li><p>            'http://v.cyzone.cn/index.php/video/index/99',  </p></li><li><p>            ]  </p></li><li><p></p></li><li><p>    list1 = ['http://192.168.25.7:8079/vinfoant/versionasdfdf']  </p></li><li><p></p></li><li><p>    infoGripper = InfoGripper()  </p></li><li><p>    for url in list:  </p></li><li><p>        infoGripper.gripinfo(url)  </p></li><li><p>    del infoGripper  </p></li></ol><p>WEB服务及任务调度</p><p><strong>[python]</strong><br/>view plaincopy</p><ol><li><p>'''''</p></li><li><p>Created on 2010-9-15</p></li><li><p></p></li><li><p>@author: chenggong</p></li><li><p>'''</p></li><li><p># -*- coding: utf-8 -*-</p></li><li><p>import string,cgi,time  </p></li><li><p>from os import curdir,sep  </p></li><li><p>from BaseHTTPServer import BaseHTTPRequestHandler,HTTPServer  </p></li><li><p>from InfoGripper import *  </p></li><li><p>import re  </p></li><li><p>import MySQLdb  </p></li><li><p>import time  </p></li><li><p>import threading  </p></li><li><p>import urllib  </p></li><li><p>import urllib2  </p></li><li><p></p></li><li><p>PORT = 8079</p></li><li><p>VERSION = 0.1</p></li><li><p>DBCHARSET = "utf8"</p></li><li><p>PARAMS = [  </p></li><li><p>          'callback',  </p></li><li><p>          'sessionId',  </p></li><li><p>          'retry',  </p></li><li><p>          'retryInterval',  </p></li><li><p>          'dbhost',  </p></li><li><p>          'dbport',  </p></li><li><p>          'db',  </p></li><li><p>          'dbuser',  </p></li><li><p>          'dbpass',  </p></li><li><p>          'videoId'</p></li><li><p>          ]  </p></li><li><p></p></li><li><p>DBMAP = ['video_id',  </p></li><li><p>         'ccsiteid',  </p></li><li><p>         'ccvid',  </p></li><li><p>         'desc_url',  </p></li><li><p>         'site_id',  </p></li><li><p>         'title',  </p></li><li><p>         'post_time',  </p></li><li><p>         'author',  </p></li><li><p>         'elapse',  </p></li><li><p>         'channel',  </p></li><li><p>         'tags',  </p></li><li><p>         'create_time',  </p></li><li><p>         'check_time',  </p></li><li><p>         'status']  </p></li><li><p></p></li><li><p>'''''</p></li><li><p>ERROR CODE定义</p></li><li><p>'''</p></li><li><p>ERR_OK = 0</p></li><li><p>ERR_PARAM = 1</p></li><li><p>ERR_HTTP_TIMEOUT = 5</p></li><li><p>ERR_HTTP_STATUS = 6</p></li><li><p>ERR_DB_CONNECT_FAIL = 8</p></li><li><p>ERR_DB_SQL_FAIL = 9</p></li><li><p>ERR_GRIPVIEW = 11</p></li><li><p>ERR_UNKNOW = 12</p></li><li><p></p></li><li><p>'''''</p></li><li><p>数据库适配器</p></li><li><p>'''</p></li><li><p>class DBAdapter(object):  </p></li><li><p></p></li><li><p>    def __init__(self):  </p></li><li><p>        self.param = {'ip':'',  </p></li><li><p>                      'port':0,  </p></li><li><p>                      'user':'',  </p></li><li><p>                      'pw':'',  </p></li><li><p>                      'db':''}  </p></li><li><p>        self.connect_once = False  #是否连接过数据库</p></li><li><p></p></li><li><p>    '''''</p></li><li><p>            创建/更新数据库连接池</p></li><li><p>    '''</p></li><li><p>    def connect(self,ip,port,user,pw,db):  </p></li><li><p>        if( ip != self.param['ip'] or</p></li><li><p>            port != self.param['port'] or</p></li><li><p>            user != self.param['user'] or</p></li><li><p>            pw != self.param['pw'] or</p></li><li><p>            db != self.param['db']):  </p></li><li><p>            Tools.writelog('info','更换数据库连接池,ip='+ip+',port='+port+',user='+user+',pw='+pw+',db='+db)  </p></li><li><p>            try:  </p></li><li><p>                if self.connect_once == True: #释放上次连接</p></li><li><p>                    self.cur.close()  </p></li><li><p>                    self.conn.close()  </p></li><li><p>                self.conn=MySQLdb.connect(user=user,passwd=pw,db=db,host=ip,port=int(port))  </p></li><li><p>                self.conn.set_character_set(DBCHARSET)  </p></li><li><p>                self.connect_once = True</p></li><li><p>                self.cur=self.conn.cursor(MySQLdb.cursors.Cursor)  </p></li><li><p>                self.param['ip'] = ip  </p></li><li><p>                self.param['port'] = port  </p></li><li><p>                self.param['user'] = user  </p></li><li><p>                self.param['pw'] = pw  </p></li><li><p>                self.param['db'] = db  </p></li><li><p>            except:  </p></li><li><p>                Tools.writelog('error',u'数据库连接失败',True)   </p></li><li><p>                raise</p></li><li><p>            else:  </p></li><li><p>                Tools.writelog('info',u'数据库连接成功')  </p></li><li><p></p></li><li><p>    '''''</p></li><li><p>            执行SQL语句</p></li><li><p>    '''</p></li><li><p>    def execute(self,sql):  </p></li><li><p>        Tools.writelog('debug',u'执行SQL: '+sql)  </p></li><li><p>        try:  </p></li><li><p>            self.cur.execute(sql)  </p></li><li><p>        except:  </p></li><li><p>            Tools.writelog('error',u'SQL执行错误:'+sql)  </p></li><li><p>            raise</p></li><li><p></p></li><li><p>    '''''</p></li><li><p>            查询数据库</p></li><li><p>    '''</p></li><li><p>    def query(self,sql):  </p></li><li><p>        row = {}  </p></li><li><p>        self.execute(sql)  </p></li><li><p>        row=self.cur.fetchall()  </p></li><li><p>        return row  </p></li><li><p></p></li><li><p>    '''''</p></li><li><p>            视频错误</p></li><li><p>    '''</p></li><li><p>    def updateErr(self,videoId):  </p></li><li><p>        nowtime = time.strftime('%Y-%m-%d-%H-%M-%S',time.localtime(time.time()))  </p></li><li><p>        sql = "UPDATE videos SET "</p></li><li><p>        sql += "check_time='" + nowtime +"',"</p></li><li><p>        sql += "status=-1 "</p></li><li><p>        sql += "WHERE video_id="+videoId  </p></li><li><p>        self.execute(sql)  </p></li><li><p>        self.conn.commit()   </p></li><li><p></p></li><li><p>    '''''</p></li><li><p>            更新查询结果</p></li><li><p>    '''</p></li><li><p>    def update(self,obj,videoId,isUpdateTitle=True):  </p></li><li><p></p></li><li><p>        Tools.writelog('debug','开始更新数据库')  </p></li><li><p>        try:  </p></li><li><p>            #更新video表</p></li><li><p>            sql = "UPDATE videos SET "</p></li><li><p>            if(obj['ccsiteId'] !="" ):  </p></li><li><p>                sql += "ccsiteid='" + obj['ccsiteId'] + "',"  </p></li><li><p>            if(obj['ccVid'] != "" ):  </p></li><li><p>                sql += "ccvid='" + obj['ccVid'] + "',"  </p></li><li><p>            if isUpdateTitle:  </p></li><li><p>                sql += "title='" + obj['title'] + "',"  </p></li><li><p>            sql += "post_time='" + obj['release'] + "',"  </p></li><li><p>            sql += "author='" + obj['user'] + "',"  </p></li><li><p>            sql += "channel='" + obj['channel'] + "',"  </p></li><li><p>            sql += "tags='" + obj['tag'] + "',"  </p></li><li><p>            nowtime = time.strftime('%Y-%m-%d-%H-%M-%S',time.localtime(time.time()))  </p></li><li><p>            sql += "check_time='" + nowtime +"',"</p></li><li><p>            sql += "status=0 "</p></li><li><p>            sql += "WHERE video_id="+videoId  </p></li><li><p></p></li><li><p>            self.execute(sql)  </p></li><li><p></p></li><li><p>            #更新count表</p></li><li><p>            if( obj['views'] != 'error' ):  </p></li><li><p>                nowdate = time.strftime('%Y-%m-%d',time.localtime(time.time()))  </p></li><li><p>                sql = "SELECT * FROM counts WHERE "</p></li><li><p>                sql += "date = '" + nowdate + "' and video_id=" + videoId  </p></li><li><p>                rst = self.query(sql)  </p></li><li><p>                if len(rst) > 0:#如果当天已有记录,则更新</p></li><li><p>                    sql = "UPDATE counts SET count="+obj['views']  </p></li><li><p>                    sql +=" WHERE video_id=" + videoId + " AND date='" + nowdate+ "'"</p></li><li><p>                else:#否则插入</p></li><li><p>                    sql = "INSERT INTO counts VALUES"</p></li><li><p>                    sql += "(null," +videoId+",'"+nowdate+"',"+obj['views'] + ")"</p></li><li><p>            self.execute(sql)                 </p></li><li> <br> 标题名称:python中怎么实现分布式抓取网页 <br> 网页链接:<a href="http://cxhlcq.com/article/ijgchi.html">http://cxhlcq.com/article/ijgchi.html</a> </div> </div> </div> <div class="other container"> <h3>其他资讯</h3> <ul> <li> <a href="/article/dcigods.html">腾讯云服务器1兆速度如果 腾讯云服务器带宽多少合适</a> </li><li> <a href="/article/dciihpc.html">Go语言get下载 go语言最新版本</a> </li><li> <a href="/article/dciihpg.html">怎么修改企业号领域名称 怎么修改企业号领域名称呢</a> </li><li> <a href="/article/dcigooo.html">万网买的域名怎么用 万网域名是什么意思</a> </li><li> <a href="/article/dcigooh.html">C语言像素点控制函数 c语言像素画图</a> </li> </ul> </div> <div class="footer"> <div class="foota container"> <div class="foot_nav fl col-lg-8 col-md-8 col-sm-12 col-xs-12"> <ul> <li class="col-lg-3 col-md-3 col-sm-3 col-xs-6"> <h3>网站制作</h3> <a href="http://m.cdcxhl.com/" target="_blank">成都网站制作</a><a href="http://www.cxjianzhan.com/mobile/" target="_blank">wap网站制作</a><a href="http://www.cxjianzhan.com/" target="_blank">网站制作公司</a><a href="http://www.cdxtjz.com/" target="_blank">网站制作</a><a href="http://chengdu.cdcxhl.com/" target="_blank">成都网站制作</a><a href="http://www.cxhljz.cn/" target="_blank">成都网站制作</a> </li> <li class="col-lg-3 col-md-3 col-sm-3 col-xs-6"> <h3>企业服务</h3> <a href="https://www.cdcxhl.com/link/" target="_blank">友情链接出售</a><a href="https://www.cdcxhl.com/mianfei/jianzhan/" target="_blank">免费建站模板</a><a href="https://www.cdcxhl.com/shoulu/" target="_blank">分类目录网站</a><a href="https://www.cdcxhl.com/shoulu/" target="_blank">网站免费收录</a><a href="https://www.cdcxhl.com/service/licence.html" target="_blank">药房许可证</a><a href="https://www.cdcxhl.com/service/gongsizhuce.html" target="_blank">注册公司</a> </li> <li class="col-lg-3 col-md-3 col-sm-3 col-xs-6"> <h3>网站建设</h3> <a href="http://www.cqcxhl.com/" target="_blank">重庆企业网站建设</a><a href="http://m.cdcxhl.cn/shop/" target="_blank">成都商城网站建设公司</a><a href="http://www.cdkjz.cn/fangan/jianshe/" target="_blank">网站建设报价方案</a><a href="https://www.cdxwcx.com/wangzhan/" target="_blank">成都网站建设</a><a href="http://m.cdxwcx.com/" target="_blank">成都网站建设公司</a><a href="http://www.wjzwz.com/" target="_blank">温江网站建设</a> </li> <li class="col-lg-3 col-md-3 col-sm-3 col-xs-6"> <h3>服务器托管</h3> <a href="http://www.cqfuwuqi.com/" target="_blank">重庆服务器托管</a><a href="https://www.cdcxhl.com/jigui/" target="_blank">成都机柜租用</a><a href="https://www.cdcxhl.com/tuoguan/zongshu/" target="_blank">成都棕树机房</a><a href="https://www.cdcxhl.com/jigui/" target="_blank">服务器机柜租赁</a><a href="https://www.cdcxhl.com/jigui/" target="_blank">机柜租用</a><a href="https://www.cdcxhl.com/idc/yaan.html" target="_blank">雅安服务器托管</a> </li> </ul> </div> <div class="footar fl col-lg-4 col-md-4 col-sm-12 col-xs-12"> <p>全国免费咨询:</p> <b>400-028-6601</b> <p>业务咨询:028-86922220 / 13518219792</p> <p>节假值班:18980820575 / 13518219792</p> <p>联系地址:成都市太升南路288号锦天国际A幢1002号</p> </div> </div> <div class="footb"> <div class="copy container"> <div class="fl">Copyright © 成都创新互联科技有限公司重庆分公司 <a href="https://beian.miit.gov.cn/" target="_blank">渝ICP备2021005571号</a></div> <!--<div class="fr"><a href="https://www.cdxwcx.com/" target="_blank">成都网站建设</a>:<a href="https://www.cdcxhl.com/" target="_blank">创新互联</a></div>--> </div> </div> <div class="link"> <div class="container"> 友情链接:: <a href="https://www.cdcxhl.com/" target="_blank">成都网站建设</a> <a href="https://www.cdcxhl.com/city/chongqing.html" target="_blank">重庆网站建设</a> <a href="">四川网站建设</a> <a href="">重庆建设网站</a> <a href="https://www.cdxwcx.com/jifang/xiyun.html" target="_blank">移动服务器托管</a> <a href="http://www.cdfuwuqi.com/" target="_blank">成都服务器托管</a> <a href="https://www.cdcxhl.cn/" target="_blank">云服务器</a> <a href="http://www.cdhuace.com/" target="_blank">广告设计制作</a> <a href="https://www.cdcxhl.com/sheji/chongqing.html" target="_blank">重庆网页设计</a> <a href="https://www.cdcxhl.com/zuo/chongqing.html" target="_blank">重庆做网站</a> <a href="https://www.cdcxhl.com/zhizuo/chongqing.html" target="_blank">重庆网站制作</a> <a href="">重庆网站建设</a> <a href="">重庆网站公司</a> <a href="">渝中网站制作</a> <a href="">重庆网站设计</a> </div> </div> </div> <div class="foot"> <ul class="public-celan"> <li> <a href="https://p.qiao.baidu.com/cps3/chatIndex?siteToken=6ce441ff9e2d6bedbdfc2a4138de449e&speedLogId=162260383240185e3_1622603832401_02407&eid=6256368&reqParam=%7B%22from%22%3A1%2C%22sessionid%22%3A%22-100%22%2C%22siteId%22%3A%2211284691%22%2C%22tid%22%3A%22-1%22%2C%22userId%22%3A%226256368%22%2C%22ttype%22%3A1%2C%22pageId%22%3A0%7D" target="_blank" class="a1 db tc"> <img src="/Public/Home/img/icon-23.png" alt="" class="db auto"> <span class="span-txt">在线咨询</span> </a> </li> <li> <a href="tel:18980820575" class="a1 db tc"> <img src="/Public/Home/img/icon-24.png" alt="" class="db auto"> <span class="span-txt">电话咨询</span> </a> </li> <li> <a target="_blank" href="tencent://message/?uin=1683211881&Site=&Menu=yes" class="a1 db tc"> <img src="/Public/Home/img/icon-25.png" alt="" class="db auto"> <span class="span-txt">QQ咨询</span> </a> </li> <li> <a target="_blank" href="tencent://message/?uin=532337155&Site=&Menu=yes" class="a1 db tc public-yuyue-up"> <img src="/Public/Home/img/icon-26.png" alt="" class="db auto"> <span class="span-txt">预约顾问</span> </a> </li> </ul> </div> <div class="customer"> <dl class="icon1"> <dt> <a href="tencent://message/?uin=1683211881&Site=&Menu=yes"> <i class="iconT"><img src="/Public/Home/img/QQ.png" alt=""></i> <p>在线咨询</p> </a> </dt> </dl> <dl class="icon2"> <dt><i><img src="/Public/Home/img/weixin.png" alt=""></i><p>微信咨询</p></dt> <dd><img src="/Public/Home/img/ewm.png"></dd> </dl> <dl class="icon3"> <dt><i><img src="/Public/Home/img/dianhua.png" alt=""></i><p>电话咨询</p></dt> <dd> <p>028-86922220(工作日)</p> <p>18980820575(7×24)</p> </dd> </dl> <dl class="icon4"> <dt class="sShow"> <a href="tencent://message/?uin=244261566&Site=&Menu=yes"> <i><img src="/Public/Home/img/dengji.png" alt=""></i><p>提交需求</p> </a> </dt> </dl> <dl class="icon5"> <dt class="gotop"> <a href="#top"> <i><img src="/Public/Home/img/top.png" alt=""></i><p>返回顶部</p> </a> </dt> </dl> </div> </body> </html> <script> $(".con img").each(function(){ var src = $(this).attr("src"); //获取图片地址 var str=new RegExp("http"); var result=str.test(src); if(result==false){ var url = "https://www.cdcxhl.com"+src; //绝对路径 $(this).attr("src",url); } }); window.onload=function(){ document.oncontextmenu=function(){ return false; } } </script>