Exemplo n.º 1
0
    def init_spider(self):
        for k, v in self.hash_pycode_Lists.iteritems():
            pluginObj = self._load_module(v)
            pluginObj.task_push = self.task_push
            pluginObj.curl = miniCurl.Curl()
            pluginObj.security_note = self._security_note
            pluginObj.security_info = self._security_info
            pluginObj.security_warning = self._security_warning
            pluginObj.security_hole = self._security_hole
            pluginObj.security_set = self._security_set
            pluginObj.debug = self._debug
            pluginObj.util = until
            pluginObj._G = self._TargetScanAnge
            pluginObj.hackhttp = hackhttp.hackhttp()
            pluginObj.ThreadPool = w8_threadpool

            try:
                pluginObj_tuple = pluginObj.assign("spider_file", "")
                if not isinstance(pluginObj_tuple, tuple):  # 判断是否是元组
                    pluginObj_tuple = pluginObj.assign("spider_end", "")
                    if not isinstance(pluginObj_tuple, tuple):
                        continue
                bool_value, agrs = pluginObj_tuple[0], pluginObj_tuple[1]
                if bool_value:
                    pconf = {}
                    pconf["pluginObj"] = pluginObj
                    pconf["service"] = "spider_file"
                    w9_hash_pycode.setdefault(k, pconf)
            except Exception as err_info:
                raise ToolkitMissingPrivileges("load spider plugins error! " +
                                               err_info)
Exemplo n.º 2
0
 def _load_module(self, chunk, name='<w9scan>'):
     try:
         pluginObj = imp.new_module(str(name))
         exec chunk in pluginObj.__dict__
     except Exception:
         raise ToolkitMissingPrivileges("Load Module excepting")
     return pluginObj
Exemplo n.º 3
0
 def _load_module(self, chunk, name='<Ajatar>'):
     pluginObj = imp.new_module(str(name))
     exec(chunk, pluginObj.__dict__)
     try:
         pluginObj = imp.new_module(str(name))
         exec(chunk, pluginObj.__dict__)
     except Exception:
         raise ToolkitMissingPrivileges("Load Module excepting")
     return pluginObj
Exemplo n.º 4
0
 def add_set(self, level, value, k='', domain=''):
     if domain not in self.dict:
         self.dict[domain] = dict()
         self.dict[domain]["info"] = CollectData()
         self.dict[domain]["note"] = CollectData()
         self.dict[domain]["warning"] = CollectData()
         self.dict[domain]["hole"] = CollectData()
     if level not in self.dict[domain]:
         raise ToolkitMissingPrivileges("Building error:level not in dict")
     self.dict[domain][level].add_set(k, value)
Exemplo n.º 5
0
def pluginScanRegister(args):
    if args.u and args.plugin:
        url = args.u
        urlconfig.mutiurl = True
        urlconfig.plugin = args.plugin
        
        if url.startswith("@"):
            fileName = url[1:]
            try:
                o = open(fileName,"r").readlines()
                for u in o:
                    urlconfig.url.append(makeurl(u.strip()))
            except IOError:
                raise ToolkitMissingPrivileges("Filename:'%s' open faild"%fileName)
            if len(o) == 0:
                raise ToolkitMissingPrivileges("The target address is empty")
            printMessage(urlconfig.url)
        else:
            urlconfig.url.append(makeurl(url))
Exemplo n.º 6
0
    def __init__(self, threadNum=15):
        self.hash_pycode_Lists = {}  #python代码字典 文件路径:代码
        self.lock_result = threading.Lock()  #
        self.task_result = []
        self.lock_output = threading.Lock()
        self.table_exception = set()

        #定义移除不用的插件
        remove_plugins = list(
            set(LIST_PLUGINS).difference(set(urlconfig.diyPlugin)))

        #过滤除exp文件外pyc init DS 文件
        def filter_func(file):
            return (True, False)['__init__' in file or ".pyc" in file
                                 or '.DS_Store' in file]

        #getExp
        def getExp():
            direxp = []
            #在目录树中游走输出在目录中的文件名 返回的是一个三元组(root,dirs,files)。
            for dirpath, _, filenames in os.walk(paths.Ajatar_Plugin_PATH):
                for filename in filenames:
                    #移除不用的插件
                    if filename.strip('.py') not in remove_plugins:
                        direxp.append(os.path.join(dirpath, filename))
            return direxp

        #过滤文件后的完整exp字典
        dir_exploit = filter(filter_func, getExp())
        #目标信息
        self._TargetScanAnge = {
            'target': urlconfig.url,
            'scanport': urlconfig.scanport,
            'find_service': urlconfig.find_service
        }

        try:
            for exp in dir_exploit:
                #读取python代码
                with open(exp, 'rb') as f:
                    reads = str(f.read())
                    f.close()
                    #保存文件:code
                    self.hash_pycode_Lists.setdefault(os.path.basename(exp),
                                                      reads)
        except Exception as error_info:
            raise ToolkitMissingPrivileges(error_info)

        self.buildHtml = buildHtml()  #生成网页报告
        self._print('Fetch %d new plugins' % len(self.hash_pycode_Lists))
        self.th = Ajatar_threadpool(threadNum, self._work,
                                    urlconfig.mutiurl)  #调用work函数进入线程池
        logger.info('Set threadnum:%d' % threadNum)
        self.url = ""
Exemplo n.º 7
0
def urlRegister(args):
    #url处理
    url = args.u
    urlconfig.usePlugin = True
    urlconfig.plugin = args.plugin
    urlconfig.diyPlugin = [urlconfig.plugin]

    if url.startswith("@"):  #判断是否是文件
        urlconfig.mutiurl = True
        filename = url[1:]  #取文件名
        try:
            o = open(filename, "r").readlines()
            for u in o:
                u = makeurl(u.strip())  #处理url
                urlconfig.url.append(u)
                printMessage(u)  #获取url的信息
        except IOError:
            raise ToolkitMissingPrivileges("Filename:'%s' open faild" %
                                           fileName)
        if len(o) == 0:
            raise ToolkitMissingPrivileges("The target address is empty")
    else:  #单个url处理
        urlconfig.url.append(makeurl(url))
Exemplo n.º 8
0
    def __init__(self, threadNum=15):
        self.hash_pycode_Lists = {}
        self.lock_result = threading.Lock()
        self.task_result = []
        self.lock_output = threading.Lock()
        self.table_exception = set()

        remove_plugins = list(
            set(LIST_PLUGINS).difference(set(urlconfig.diyPlugin)))

        def filter_func(file):
            return (True, False)['__init__' in file or ".pyc" in file
                                 or '.DS_Store' in file]

        def getExp():
            direxp = []
            for dirpath, _, filenames in os.walk(paths.w9scan_Plugin_Path):
                for filename in filenames:
                    if filename.strip('.py') not in remove_plugins:
                        direxp.append(os.path.join(dirpath, filename))
            return direxp

        dir_exploit = filter(filter_func, getExp())

        self._TargetScanAnge = {
            'target': urlconfig.url,
            'scanport': urlconfig.scanport,
            'find_service': urlconfig.find_service
        }

        try:
            for exp in dir_exploit:
                with open(exp, 'rb') as f:
                    reads = str(f.read())
                    f.close()
                    self.hash_pycode_Lists.setdefault(os.path.basename(exp),
                                                      reads)
        except Exception as error_info:
            raise ToolkitMissingPrivileges(error_info)

        self.buildHtml = buildHtml()
        self._print('Fetch %d new plugins' % len(self.hash_pycode_Lists))
        self.th = w8_threadpool(threadNum, self._work, urlconfig.mutiurl)
        logger.info('Set threadnum:%d' % threadNum)
        self.url = ""
Exemplo n.º 9
0
    def init_spider(self):
        #items() 迭代器 k exp文件 v 代码
        for k, v in self.hash_pycode_Lists.iteritems():
            pluginObj = self._load_module(v)  #动态加载代码
            for each in ESSENTIAL_MODULE_METHODS:  #bugcsan插件的两个主要函数
                if not hasattr(pluginObj, each):
                    errorMsg = "Can't find essential method:'{}' in current script,Please modify your {}.".format(
                        each, k)
                    logger.error(errorMsg)
                    continue
            pluginObj.task_push = self.task_push
            pluginObj.curl = miniCurl.Curl()  #bugscan 旧版http
            #Bugscan 漏洞等级
            pluginObj.security_note = self._security_note
            pluginObj.security_info = self._security_info
            pluginObj.security_warning = self._security_warning
            pluginObj.security_hole = self._security_hole
            pluginObj.security_set = self._security_set
            pluginObj.debug = self._debug
            pluginObj.util = until
            pluginObj._G = self._TargetScanAnge  #目标信息
            pluginObj.hackhttp = hackhttp.hackhttp()  #bugscan http
            pluginObj.ThreadPool = Ajatar_threadpool  #线程池

            try:
                #判断是否为爬虫插件 xss那些..
                pluginObj_tuple = pluginObj.assign("spider_file", "")  #
                if not isinstance(pluginObj_tuple, tuple):  # 判断是否是元组
                    pluginObj_tuple = pluginObj.assign("spider_end", "")
                    if not isinstance(pluginObj_tuple, tuple):
                        continue
                bool_value, agrs = pluginObj_tuple[0], pluginObj_tuple[1]
                if bool_value:  #爬虫插件返回True
                    pconf = {}
                    pconf["pluginObj"] = pluginObj  #保存爬虫插件对象
                    pconf["service"] = "spider_file"
                    Ajatar_hash_pycode.setdefault(k, pconf)  #保存文件名,对象
            except Exception as err_info:
                raise ToolkitMissingPrivileges("load spider plugins error! " +
                                               err_info)
Exemplo n.º 10
0
    def init_spider(self):
        for k, v in self.hash_pycode_Lists.iteritems():
            pluginObj = self._load_module(v)
            for each in ESSENTIAL_MODULE_METHODS:
                if not hasattr(pluginObj, each):
                    errorMsg = "Can't find essential method:'{}' in current script,Please modify your {}.".format(
                        each, k)
                    logger.error(errorMsg)
                    continue
            pluginObj.task_push = self.task_push
            pluginObj.curl = miniCurl.Curl()
            pluginObj.security_note = self._security_note
            pluginObj.security_info = self._security_info
            pluginObj.security_warning = self._security_warning
            pluginObj.security_hole = self._security_hole
            pluginObj.security_set = self._security_set
            pluginObj.debug = self._debug
            pluginObj.util = until
            pluginObj._G = self._TargetScanAnge
            pluginObj.hackhttp = hackhttp.hackhttp()
            pluginObj.ThreadPool = w8_threadpool

            try:
                pluginObj_tuple = pluginObj.assign("spider_file", "")
                if not isinstance(pluginObj_tuple, tuple):  # 判断是否是元组
                    pluginObj_tuple = pluginObj.assign("spider_end", "")
                    if not isinstance(pluginObj_tuple, tuple):
                        continue
                bool_value, agrs = pluginObj_tuple[0], pluginObj_tuple[1]
                if bool_value:
                    pconf = {}
                    pconf["pluginObj"] = pluginObj
                    pconf["service"] = "spider_file"
                    w9_hash_pycode.setdefault(k, pconf)
            except Exception as err_info:
                raise ToolkitMissingPrivileges("load spider plugins error! " +
                                               err_info)
Exemplo n.º 11
0
    def mutiBuild(self):
        # build base info
        versionPlace = VERSION
        reportTime = time.strftime('%Y-%m-%d %H:%M:%S',
                                   time.localtime(time.time()))
        selectPlugin = ' '.join(urlconfig.diyPlugin)
        Ajatar_html = "PCFET0NUWVBFIGh0bWw+CjxodG1sIGxhbmc9ImVuIj4KICA8aGVhZD4KICAgIDxtZXRhIGNoYXJzZXQ9InV0Zi04Ij4KICAgIDxtZXRhIGh0dHAtZXF1aXY9IlgtVUEtQ29tcGF0aWJsZSIgY29udGVudD0iSUU9ZWRnZSI+CiAgICA8bWV0YSBuYW1lPSJ2aWV3cG9ydCIgY29udGVudD0id2lkdGg9ZGV2aWNlLXdpZHRoLCBpbml0aWFsLXNjYWxlPTEiPgoKICAgIDx0aXRsZT5BamF0YXIg5om56YeP5ryP5rSe5omr5o+P5oql5ZGKPC90aXRsZT4KCiAgICA8bWV0YSBuYW1lPSJkZXNjcmlwdGlvbiIgY29udGVudD0iU291cmNlIGNvZGUgZ2VuZXJhdGVkIHVzaW5nIGxheW91dGl0LmNvbSI+CiAgICA8bWV0YSBuYW1lPSJhdXRob3IiIGNvbnRlbnQ9IkxheW91dEl0ISI+CgogICAgPGxpbmsgcmVsPSJzdHlsZXNoZWV0IiBocmVmPSJodHRwOi8vY2RuLmJvb3Rjc3MuY29tL2Jvb3RzdHJhcC8zLjMuMC9jc3MvYm9vdHN0cmFwLm1pbi5jc3MiPiAKICAgIDxsaW5rIHJlbD0ic3R5bGVzaGVldCIgaHJlZj0iaHR0cDovL2Nkbi5ib290Y3NzLmNvbS9mb250LWF3ZXNvbWUvNC4yLjAvY3NzL2ZvbnQtYXdlc29tZS5taW4uY3NzIj4gCgogIDwvaGVhZD4KICA8Ym9keT4KCiAgICA8ZGl2IGNsYXNzPSJjb250YWluZXItZmx1aWQiPgoJPGRpdiBjbGFzcz0icm93Ij4KCQk8ZGl2IGNsYXNzPSJjb2wtbWQtMTIiPgoJCQk8ZGl2IGNsYXNzPSJwYWdlLWhlYWRlciI+CgkJCQk8aDE+CgkJCQkJQWphdGFy5om56YeP5omr5o+P5oql5ZGKICA8c21hbGw+dnt7dmVyc2lvbn19PC9zbWFsbD4KCQkJCTwvaDE+CgkJCTwvZGl2PiA8c3BhbiBjbGFzcz0ibGFiZWwgbGFiZWwtcHJpbWFyeSI+55Sf5oiQ5pe26Ze077yae3tyZXBvcnRUaW1lfX08L3NwYW4+CiAgICAgICAgICAgIDxzcGFuIGNsYXNzPSJsYWJlbCBsYWJlbC1zdWNjZXNzIj7pgInmi6nmj5Lku7bvvJp7e3NlbGVjdFBsdWdpbn19PC9zcGFuPgogICAgICAgICAgICA8c3BhbiBjbGFzcz0ibGFiZWwgbGFiZWwtZGFuZ2VyIj5TY2FuIHRpbWUJe3tzY2FudGltZX19PC9zcGFuPgogICAgICAgICAgICA8L2JyPjwvYnI+CgkJCTx0YWJsZSBjbGFzcz0idGFibGUiPgoJCQkJPHRoZWFkPgoJCQkJCTx0cj4KICAgIDx0aD4jPC90aD4KICAgIDx0aD5Vcmw8L3RoPgogICAgPHRoPlRpdGxlPC90aD4KICAgIDx0aD5CdWlsZHdpdGg8L3RoPgogICAgPHRoPkluZm88L3RoPgogICAgPHRoPk5vdGU8L3RoPgogICAgPHRoPldhcm5pbmc8L3RoPgogICAgPHRoPkhvbGU8L3RoPgogICAgICAgICAgICAgICAgICAgICAgICAgICAgPC90cj4KCQkJCTwvdGhlYWQ+CiAgICAgICAgICAgICAgICAKCQkJCTx0Ym9keT4KICAgICAgICAgICAgICAgICAgICB7e2NvbnRlbnR9fQoJCQkJPC90Ym9keT4KCQkJPC90YWJsZT4KCQk8L2Rpdj4KCTwvZGl2Pgo8L2Rpdj4KICA8L2JvZHk+CjwvaHRtbD4K"
        Ajatar_html = base64.b64decode(Ajatar_html)
        Ajatar_html = Ajatar_html.replace("{{version}}", str(versionPlace))
        Ajatar_html = Ajatar_html.replace("{{reportTime}}", str(reportTime))
        Ajatar_html = Ajatar_html.replace("{{scantime}}",
                                          runningTime(urlconfig.runningTime))
        Ajatar_html = Ajatar_html.replace("{{selectPlugin}}",
                                          str(selectPlugin))

        htmlDict = dict()
        index = 0
        full = []
        try:
            for url, content in self.dict.items():
                htmlDict[url] = dict()
                index = index + 1
                Total = dict()

                title = ""
                server = ""

                for key, value in content.items():
                    htmlDict[url][key] = value.getData()

                    if len(htmlDict[url][key]):
                        infoList = list()
                        if key == "info":
                            if "title" in htmlDict[url][key]:
                                title = htmlDict[url][key]["title"]
                                if isinstance(title, list):
                                    title = ''.join(title)
                                htmlDict[url][key].pop("title")
                            if "WebStruct" in htmlDict[url][key]:
                                server = htmlDict[url][key]["WebStruct"]
                                htmlDict[url][key].pop("WebStruct")

                        for k, v in htmlDict[url][key].items():
                            f = v
                            if isinstance(v, list):
                                f = '[/br]'.join(v)
                            elif isinstance(v, set):
                                f = '[/br]'.join([i for i in f])
                            f = self.escape(f).replace('[/br]', '</br>')
                            infoList.append(self.addmutibug(str(k), str(f)))
                        info_page = ''.join(infoList)
                    else:
                        info_page = ""
                    Total[key] = info_page.replace('[/br]', '</br>')

                tr = "<tr><td>%d</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td><td>  %s</td><td>%s</td><td>%s</td></tr>" % (
                    index, url, title, server, Total["info"], Total["note"],
                    Total["warning"], Total["hole"])
                full.append(tr)
        except Exception as err:
            raise ToolkitMissingPrivileges("Building result faild!")

        Ajatar_html = Ajatar_html.replace("{{content}}", ' '.join(full))
        filename = os.path.join(
            paths.Ajatar_Output_PATH,
            "BatchScanning" + "_" + str(int(time.time())) + ".html")
        result = open(filename, "w")
        result.write(Ajatar_html)
        result.close()
        logger.info("success saved :" + filename)
Exemplo n.º 12
0
    def build(self):
        # build base info
        reportTime = time.strftime('%Y-%m-%d %H:%M:%S',
                                   time.localtime(time.time()))

        # build scan info
        htmlDict = dict()
        Total = {"hole": '0', "note": '0', "warning": '0', "info": '0'}

        # build
        DomainRoot = get_domain_root(''.join(urlconfig.url))
        Ajatar_html = "<!DOCTYPE html>
<!--[if IE 8]><html class="ie ie8"> <![endif]-->
<!--[if IE 9]><html class="ie ie9"> <![endif]-->
<!--[if gt IE 9]><!-->
<html> <!--<![endif]-->
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <meta name="description" content="Cobra is a code static scan system">
    <meta name="author" content="Feei <feei@feei.cn>">
    <title>Ajatar security report</title>

    <!-- Favicon-->
    <link rel="shortcut icon" href="./asset/ico/favicon.ico" type="image/x-icon">
    
    <link href="https://cdn.bootcss.com/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet">
    <!-- CSS -->
    <link href="https://bugs.hacking8.com/cdn/asset/css/base.css" rel="stylesheet">
    <link href="https://bugs.hacking8.com/cdn/asset/css/report.css" rel="stylesheet">

    <!--[if lt IE 9]>
      <script src="js/html5shiv.min.js"></script>
      <script src="js/respond.min.js"></script>
    <![endif]-->

</head>
<body>
<div class="container-fluid">
    <div class="row">
        <div class="col-xs-12">
            <div class="invoice-title">
                <h2>Ajatar</h2>
                <h3 class="pull-right"></h3>
            </div>
            <hr>
            <ul class="nav nav-tabs" id="myTabs">
                <li class="active"><a data-id="inf" data-toggle="tab">Information</a></li>
            </ul>
            <div class="tab-content">
                <div class="tab-pane active" id="inf">
                    <div class="row">
                        <div class="col-md-4 column">
                            <h4>Welcome to Ajatar!</h4>
                            <div class="row">
                                <div class="col-xs-12">
                                    <address>
                                        <h5>Project information</h5>
                                        <table class="table table-striped table-bordered table-condensed">
                                            <thead>
                                            <tr>
                                                <th>Item</th>
                                                <th>Value</th>
                                            </tr>
                                            </thead>
                                            <tbody>
                                            <tr>
                                                <td>Domain</td>
                                                <td>{{url}}</td>
                                            </tr>
                                            <tr>
                                                <td>Select plugin</td>
                                                <td>{{select_plugin}}</td>
                                            </tr>
                                            <tr>
                                                <td>scan all port</td>
                                                <td>{{scan_all_port}}</td>
                                            </tr>
                                            <tr>
                                                <td>ThreadNum</td>
                                                <td>{{ThreadNum}}</td>
                                            </tr>
                                            </tbody>
                                        </table>
                                    </address>
                                </div>
                                <div class="col-xs-12">
                                    <address>
                                        <h5>Scan information</h5>
                                        <table class="table table-striped table-bordered table-condensed">
                                            <thead>
                                            <tr>
                                                <th>Item</th>
                                                <th>Value</th>
                                            </tr>
                                            </thead>
                                            <tbody>
                                            <tr>
                                                <td>Report time</td>
                                                <td>{{reportTime}}</td>
                                            </tr>
                                            <tr>
                                                <td>Scan time</td>
                                                <td>{{scantime}}</td>
                                            </tr>
                                            </tbody>
                                        </table>
                                    </address>
                                </div>
                                <div class="col-xs-12">
                                    <address>
                                        <h5>Number of vulnerabilities</h5>
                                        <table class="table table-striped table-bordered table-condensed">
                                            <thead>
                                            <tr>
                                                <th>Level</th>
                                                <th>Total</th>
                                            </tr>
                                            </thead>
                                            <tbody class="n-o-v">
                                            <tr>
                                                <td>Hole</td>
                                                <td>{{total_Hole}}</td>
                                            </tr>
                                            <tr>
                                                <td>Note</td>
                                                <td>{{total_Note}}</td>
                                            </tr>
                                            <tr>
                                                <td>Warning</td>
                                                <td>{{total_Warning}}</td>
                                            </tr>
                                            <tr>
                                                <td>Info</td>
                                                <td>{{total_Info}}</td>
                                            </tr>
                                            </tbody>
                                        </table>
                                    </address>
                                </div>
                            </div>
                        </div>
                        <div class="col-md-8 column">
                            <h4>Vulnerability statistics</h4>
                                <div class="bs-example" data-example-id="media-list">
    <ul class="media-list">
      <li class="media">
        <div class="media-left">
          <a href="#">
            <i class="fa fa-circle m-l-5 text-purple"></i>
          </a>
        </div>
        <div class="media-body">
          <h4 class="media-heading">Report Level</h4>
          <p>w9scan扫描报告等级按照严重性分为四级 info note warning hole.</p>
          <!-- Nested media object -->
          <div class="media">
            <div class="media-left">
              <a href="#">
              <i class="fa fa-circle m-l-5 text-info"></i>
              </a>
            </div>
            <div class="media-body">
              <h4 class="media-heading">Info level</h4>
              Info level 搜集网站的一些基本.
              <!-- Nested media object -->
              {{info_content}}
            </div>
          </div>
          <!-- Nested media object -->
          <div class="media">
            <div class="media-left">
              <a href="#">
                <i class="fa fa-circle m-l-5 text-success"></i>
              </a>
            </div>
            <div class="media-body">
              <h4 class="media-heading">Note level</h4>
              Note level 提醒网站的一些信息可能被泄露.
              {{note_content}}
            </div>
          </div>
          <!-- Nested media object -->
          <div class="media">
            <div class="media-left">
              <a href="#">
                <i class="fa fa-circle m-l-5 text-warning"></i>
              </a>
            </div>
            <div class="media-body">
              <h4 class="media-heading">Warning level</h4>
              Warning level 警告网站某些地方可能被利用.
              {{warning_content}}
            </div>
          </div>
          <!-- Nested media object -->
          <div class="media">
            <div class="media-left">
              <a href="#">
                <i class="fa fa-circle m-l-5 text-hole"></i>
              </a>
            </div>
            <div class="media-body">
              <h4 class="media-heading">Hole level</h4>
              Hole level 高危等级 警告网站某些地方可能存在严重的安全问题.
              {{hole_content}}
            </div>
          </div>
        </div>
      </li>
    </ul>
    
  </div>
                        </div>
                    </div><!-- End row -->
                </div><!-- End rab -->
            </div>
        </div>
    </div>
    <hr>
    <!-- Containers -->
    <div class="row">
        <div class="col-md-6">
            <div>
                <p style="float:left;">
                    Copyright &copy; 2018 <a href="https://github.com/Ajatars/Ajatar" target="_blank">Ajatar</a>. All rights reserved
                </p>
            </div>
        </div>
        <div class="col-md-6">
            <div>
                <p style="float:right;">
                    <a href="https://github.com/Ajatars/Ajatar" target="_blank">Github</a> -
                    <a href="https://github.com/Ajatars/Ajatar" target="_blank">Ajatar</a>
                </p>
            </div>
        </div>
    </div>
</div>
</body>
</html>"
        try:
            Ajatar_html = base64.b64decode(Ajatar_html)
            Ajatar_html = Ajatar_html.replace("{{url}}", str(urlconfig.url))
            Ajatar_html = Ajatar_html.replace("{{scan_all_port}}",
                                              str(urlconfig.scanport))
            Ajatar_html = Ajatar_html.replace("{{ThreadNum}}",
                                              str(urlconfig.threadNum))
            Ajatar_html = Ajatar_html.replace(
                "{{select_plugin}}", str(' '.join(urlconfig.diyPlugin)))
            Ajatar_html = Ajatar_html.replace("{{reportTime}}",
                                              str(reportTime))
            Ajatar_html = Ajatar_html.replace(
                "{{scantime}}", runningTime(urlconfig.runningTime))
        except Exception:
            raise ToolkitMissingPrivileges("BuildHtml Error Exception")

        try:
            for url, content in self.dict.items():
                htmlDict[url] = dict()
                for key, value in content.items():
                    try:
                        htmlDict[url][key] = value.getData()
                        if len(htmlDict[url][key]):
                            infoList = list()
                            for k, v in htmlDict[url][key].items():
                                f = v
                                if isinstance(v, list):
                                    f = '[/br]'.join(v)
                                elif isinstance(v, set):
                                    f = '[/br]'.join([i for i in f])
                                f = self.escape(f).replace('[/br]', '</br>')
                                infoList.append(
                                    self.addbug(key, str(k), str(f)))
                            info_page = ''.join(infoList)
                            substr = "{{%s_content}}" % key
                            Ajatar_html = Ajatar_html.replace(
                                substr, info_page)
                        else:
                            substr = "{{%s_content}}" % key
                            Ajatar_html = Ajatar_html.replace(substr, '')

                        Total[key] = str(len(value.getData()))
                    except Exception:
                        raise ToolkitMissingPrivileges("Save Report Exception")

            Ajatar_html = Ajatar_html.replace("{{total_Hole}}", Total["hole"])
            Ajatar_html = Ajatar_html.replace("{{total_Note}}", Total["note"])
            Ajatar_html = Ajatar_html.replace("{{total_Warning}}",
                                              Total["warning"])
            Ajatar_html = Ajatar_html.replace("{{total_Info}}", Total["info"])

            filename = DomainRoot + "_" + str(int(time.time())) + ".html"
            filename = filename.replace(":", "_")
            filename = os.path.join(paths.Ajatar_Output_PATH, filename)
            result = open(filename, "w")
            result.write(Ajatar_html)
            result.close()
            logger.info("success saved :" + filename)

        except Exception as err:
            raise ToolkitMissingPrivileges("Sava Faild! error:" + err)