日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網為廣大站長提供免費收錄網站服務,提交前請做好本站友鏈:【 網站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

一般來說軟件開發相關企業都會有自己內部的源代碼管理工具,比如私有部署的gitlab服務器。特別是企業上規模之后會有多個產品線,各個業務產品線各自的項目解決方案會非常多。

以我們公司為例,就招聘事業部來說,內部的大大小小的中臺ESB、MRest、各種Consumer消費端、各種工具等等解決方案現在已經上百個了。這個時候你就會遇到如下一些場景:

1.需要修改某個公共接口的參數或者某個基礎庫項目包中的公共方法,但是不知道到底哪些項目、哪些地方引用了該接口,不好評估影響點?

2.業務代碼中已知道某個Kafka Topic,但是當初寫代碼兄弟沒備注消費端的項目,找了很久就是找不到Consumer項目在哪兒?

3.我想通過某一些特定的關鍵詞搜索某一段代碼,記不清到底在哪些項目中使用了?

如果你有上述的困惑,那么下面介紹的這個gitlab 全局 Search代碼搜索工具能夠幫你解決這些問題。工具的實現采用Python/ target=_blank class=infotextkey>Python + selenium + chromedriver實現自動化登錄內部gitlab站點,通過勾選默認配置的產品分組,實現對多個分組內的項目代碼特定多個關鍵詞查詢搜索。工具的運行流程及界面大概如下面幾幅截圖所示:

step1.讀取配置文件信息自動登錄:

{
  "username": "yourname",
  "password": "yourpassword",
  "projectGroups": [
    "recrxxx",
    "platform-uiframework",
    "platform-infrastructure",
    "ux-share-platform"
  ]
}

 

step2: 登陸成功后主頁注入搜索填充信息,可選擇的搜索項目分組、關鍵詞錄入框等

 

step3:開始遍歷項目分組,獲取項目id,并執行關鍵詞搜索

 

step4:獲取命中結果展示,小于等于10個結果的會默認打開瀏覽器tab頁全部展開,大于10個結果的需要手動打開單個或全部

 

step5:因為使用的chromedriver來驅動實現的,需要注意chrome瀏覽器版本與chromedriver版本的匹配,如不匹配會記錄如下日志;

 

主要利用python 驅動 selenium 實現自動化控制gitlab項目頁面,通過注入特定html標簽代碼,實現自動化搜索gitlab項目代碼。下面是python腳本部分主要實現:

class GitLabSearchTool(object):
    def __init__(self):
        self.__username = ''
        self.__password = ''
        self.projectGroups = []
        self.usedKeywords = []
        self.__getConfigInfo()
        self.maxPageIndex = 50
        self.divId = 'spiderContainer'
        self.searchDivId = 'searchContainer'
        self.base_url = "http://gitlab.xxxcorp.com"
        self.baseLoginUrl = "http://gitlab.xxxcorp.com/users/sign_in"
        self.startTime = datetime.now()
        self.isSearching = False
        self.stopSearch = False
        self.isClose = False
        self.successUrls = dict()
        self.searchGroup = []
        self.keywords = []
        self.request = None
        self.driver = None

    def start(self):
        user_agent = "Mozilla/5.0 (windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/86.0.4240.111 Safari/537.36"
        chrome_options = Options() 
        chrome_options.add_argument('user-agent={}'.format(user_agent))
        chrome_options.add_argument('--disable-plugins')  # 禁用插件
        chrome_options.add_argument('--start-maximized')  # 啟動google Chrome就最大化
        chrome_options.add_experimental_option("excludeSwitches", ['enable-automation'])  # 隱藏"Chrome正在受到自動軟件的控制"
        pathItem = ['chromedriver.exe']
        driverPath = Path.cwd().joinpath(*pathItem)
        self.driver = webdriver.Chrome(driverPath, options=chrome_options) 
        self.driver.get(self.baseLoginUrl)
        if self.__username and self.__password:
            WebDriverWait(self.driver, 1000).until(
                EC.presence_of_element_located((By.XPATH, '//*[@id="new_ldap_user"]')))
            time.sleep(0.3)
            self.driver.find_element(By.XPATH, '//*[@id="username"]').send_keys(self.__username)
            time.sleep(0.3)
            self.driver.find_element(By.XPATH, '//*[@id="password"]').send_keys(self.__password)
            time.sleep(0.3)
            self.driver.find_element(By.XPATH, '//*[@id="remember_me"]').click()
            self.driver.find_element(By.XPATH, '//*[@id="new_ldap_user"]/input[3]').click()
        threading.Thread(target=self.__checkBrowserIsClose).start()
        self.request = requests.session()
        try: 
            while not self.isClose:
                try:
                    homediv = self.driver.find_element(By.ID, "xxxyoucangohomenow")
                    if homediv is not None:
                        self.driver.get(self.base_url)
                except:
                    pass
                try:
                    searchDiv = self.driver.find_element(By.ID, "xxxyoucanstartsearchnow")
                    if searchDiv is None:
                        time.sleep(1)
                    else:
                        self.startTime = datetime.now()
                        self.successUrls.clear()
                        self.searchGroup.clear()
                        self.keywords.clear()
                        chkList = self.driver.find_elements(By.XPATH,
                                                            '//*[@id="searchGroup"]/descendant::input[@type="checkbox"]')
                        for chk in chkList:
                            if chk.get_attribute('checked') == 'true':
                                self.searchGroup.append(chk.get_attribute('attrvalue').strip())
                        if len(self.searchGroup) <= 0:
                            return
                        keywordInput = self.driver.find_element(By.ID, 'searchKeyword')
                        searchKeyword = keywordInput.get_attribute('value').strip()
                        keywords = re.split(',|,', searchKeyword)
                        if len(keywords) > 0:
                            for kw in keywords:
                                kw = kw.strip()
                                if len(kw) > 0:
                                    self.keywords.append(kw)
                        if len(self.keywords) <= 0:
                            self.driver.execute_script("arguments[0].focus();", keywordInput)
                            return 
                        self._search()
                except : 
                    time.sleep(1)
            print('webdriver is close')
            return
        except Exception as ex:
            print('異常:{}'.format(ex))
            return

    def _search(self):
        self.isSearching = True
        self.stopSearch = False
        for group in self.searchGroup:
            if self.stopSearch:
                break
            for page in range(1, self.maxPageIndex):
                if self.stopSearch:
                    break
                url = "http://gitlab.xxxcorp.com/{}?page={}".format(group, page)
                self.driver.get(url)
                WebDriverWait(self.driver, 5).until(
                    EC.presence_of_element_located((By.XPATH, '//*[@id="content-body"]/div[2]/div[1]/ul/li[1]/a')))
                projects = self.driver.find_elements(By.XPATH,
                                                     '//*[@id="projects"]/div/ul/descendant::a[@class="project"]')
                if len(projects) <= 0:
                    break
                for proj in projects:
                    try:
                        stopSearch = self.driver.find_element(By.ID, 'xxxyoucanstopsearchnow')
                        if stopSearch is not None:
                            self.stopSearch = True
                            break
                    except:
                        pass
                    projUrl = proj.get_attribute('href')
                    self.__searchProject(projUrl)
        endTime = datetime.now()  
        delta = (endTime - self.startTime).seconds   
        successCount = len(self.successUrls)
        searchKeyword = ','.join(self.keywords)
        if successCount > 0:
            searchedPojectUrl = self.__getSearchedProject()
            html = '''<div style="text-align:center;margin-top:150px;font-size:20px;font-weight:bold;color:white;">
                           <span>查詢{}</span><br/>
                           <span>耗時:{} 秒! 命中{}個項目</span>
                           <button style="width:150px;margin-left:50px;color:red;font-size:16px;font-weight:normal;" 
                               type="button" onclick="gotohome()">跳轉搜索主頁</button>
                           <div id="searchresultdiv" style="font-size:18px;font-weight:normal;max-height:400px;
                                overflow:auto;margin:auto;margin-top:5px;width:50%;text-align:left;
                                border:1px solid white;border-radius:3px;padding:10px;scroll:auto;
                                ::-webkit-scrollbar {{width:4px;height:4px;}}">
                              <button style="width:150px;color:black;font-size:16px;font-weight:normal;" 
                               type="button" onclick="openAllUrl()">打開全部鏈接</button><br/>
                            {}</div>
                      </div>'''.format(searchKeyword, delta, successCount, searchedPojectUrl)
        else:
            html = '''<div style="text-align:center;margin-top:150px;font-size:20px;font-weight:bold;color:white;">
                           <span>查詢{}</span><br/>
                           <span>耗時:{} 秒! 命中{}個項目</span>
                           <button type="button" style="width: 150px;margin-left:50px;color:red;font-size:16px;font-weight:normal;" 
                                onclick="gotohome()">跳轉搜索主頁</button><br/>
                      </div>'''.format(searchKeyword, delta, successCount)
        self.__createDom(html)
        self.isSearching = False
        if len(self.successUrls) <= 10:
            for url, name in self.successUrls.items():
                self.driver.execute_script('window.open("{}")'.format(url))
    def __searchProject(self, projUrl):
        proj = self.__getProjectId(projUrl)
        if proj[0] <= 0:
            return
        for keyword in self.keywords:
            if not (keyword and len(keyword.strip()) > 0):
                continue
            searchUrl = '{}/search?utf8=&snippets=&scope=&search={}&project_id={}' 
                .format(self.base_url, keyword, proj[0])
            data = self.request.get(searchUrl).text
            html = etree.HTML(data)
            topResults = html.xpath('//*[@id="content-body"]/div[contains(@class,"prepend-top-10")]')
            if len(topResults) > 0:
                self.successUrls[searchUrl] = proj[1]
                # js = 'window.open("{}")'.format(searchUrl)
                # self.driver.execute_script(js)
                # self.driver.switch_to.window(self.driver.window_handles[0])
            successCount = len(self.successUrls)
            if successCount > 0:
                searchedPojectUrl = self.__getSearchedProject()
                html = '''<div style="text-align:center;margin-top:150px;font-size:22px;font-weight:bold;color:white;">
                           <button style="width:150px;color:red;font-size:16px;font-weight:normal;" 
                                 type="button" onclick="stopSearch()">停止搜索</button><br/>
                           <span>正在查詢"{}"</span><br/>
                           <span>{}</span><br/>
                           <span>查詢命中{}個項目</span><br/>
                           <div style="font-size:16px;max-height:400px;width:50%;scroll:auto;
                                       overflow:auto;margin:auto;margin-top:5px;text-align:left;
                                       border:1px solid white;border-radius:3px;padding:10px;
                                ::-webkit-scrollbar {{width:4px;height:4px;}}"">{}</div>
                          </div>'''.format(keyword, projUrl, successCount, searchedPojectUrl)
            else:
                html = '''<div style="text-align:center;margin-top:150px;font-size:22px;font-weight:bold;color:white;">
                           <button style="width:150px;color:red;font-size:16px;font-weight:normal;" 
                                type="button" onclick="stopSearch()">停止搜索</button><br/>
                           <span>正在查詢"{}"</span><br/>
                           <span>{}</span>
                          </div>'''.format(keyword, projUrl)
            self.__createDom(html)

    def __getProjectId(self, url):
        proj_id = 0
        proj_name = ''
        data = self.request.get(url).text
        html = etree.HTML(data)
        values = html.xpath('//*[@id="search_project_id"]/@value')
        if len(values) > 0:
            proj_id = int(values[0])
        names = html.xpath('//*[@id="search_project_id"]/@data-name')
        if len(names) > 0:
            proj_name = names[0]
        return (proj_id, proj_name)

.....

分享到:
標簽:python
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養生app2018-06-03

每日養生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定