在您安装前,Greasy Fork镜像 希望您知道此脚本声明其包含了一些负面功能。这些功能也许会使脚本作者获利,而不能给您带来任何直接的金钱收益。
您只有在付费后才能使用脚本的全部功能。Greasy Fork镜像 未参与到支付的流程,因此无法验证您是否获得了有价值的东西,亦无法帮助您申请退款。
GitHub极速访问浏览助手,解决GitHub无法访问和加速工具,GitHub上不去打不开的解决办法,高速下载Git Clone/SSH,Release,Raw,Code/Zip等文件、项目列表单文件快捷下载,添加git clone/commit命令
// ==UserScript==
// @name Github访问增强 - 高速浏览及下载工具
// @name:zh-CN Github访问增强 - 高速浏览及下载工具
// @name:zh-TW Github訪問增強 - 高速瀏覽及下載工具
// @name:en Github access enhancement - high-speed browsing and downloading tool
// @namespace via. github helper
// @version 2.4.8
// @description GitHub极速访问浏览助手,解决GitHub无法访问和加速工具,GitHub上不去打不开的解决办法,高速下载Git Clone/SSH,Release,Raw,Code/Zip等文件、项目列表单文件快捷下载,添加git clone/commit命令
// @description:zh-CN GitHub极速访问浏览助手,解决GitHub无法访问和加速工具,GitHub上不去打不开的解决办法,高速下载Git Clone/SSH,Release,Raw,Code/Zip等文件、项目列表单文件快捷下载,添加git clone/commit命令
// @description:zh-TW GitHub極速訪問瀏覽助手,解決GitHub無法訪問和加速工具,GitHub上不去打不開的解決辦法,高速下載Git Clone/SSH,Release,Raw,Code/Zip等文件、項目列表單文件快捷下載,添加git clone/commit命令
// @description:en GitHub extremely fast access browsing assistant, solution to GitHub inaccessibility and acceleration tools, solution to GitHub not being able to open it, high-speed download of Git Clone/SSH, Release, Raw, Code/Zip and other files, project list list files quick download, add git clone/commit command
// @author via. github helper
// @icon 
// @resource logo 
// @require http://cdn.staticfile.org/jquery/1.12.1/jquery.min.js
// @supportURL http://letsmain.com/github-access-master?utm_source=greasyfork-origin
// @include *://github.com/*
// @include *://*.github.com/*
// @include *://hub.fgit.gq/*
// @include *://kgithub.com/*
// @include *://hub.fgit.ml/*
// @include *://*.baidu.com/*
// @include *://*.so.com/*
// @include *://*.google.com/*
// @include *://*.bing.com/*
// @include *://*.yandex.com/*
// @include *://*.sogou.com/*
// @include *://*.sm.cn/*
// @grant GM_getResourceURL
// @grant GM_getResourceText
// @grant GM_xmlhttpRequest
// @grant GM_addStyle
// @grant GM_openInTab
// @grant unsafeWindow
// @run-at document-idle
// @grant GM_getValue
// @grant GM_setValue
// @grant GM_download
// @grant GM_getResourceURL
// @run-at document-start
// @grant GM_setClipboard
// @compatible Chrome
// @compatible Safari
// @compatible Edge
// @compatible Firefox
// @compatible Opera
// @antifeature payment
// @license GPL-3.0 License
// ==/UserScript==
(function() {
'use strict';
//Style for the access and download buttons
GM_addStyle(`
.download-button {
display: inline-block;
padding: 10px;
margin-right: 10px;
background-color: #007bff;
color: #fff;
font-weight: bold;
text-decoration: none;
border-radius: 5px;
cursor: pointer;
}
`);
// Extract GitHub repository name from URL
function extractRepositoryName() {
const urlParts = window.location.href.split('/');
if (urlParts.length >= 5) {
const username = urlParts[3];
const repository = urlParts[4].split('?')[0];
return `${username}/${repository}`;
}
return null;
}
// Generate download buttons for the extracted repository
function generateDownloadButtons(repository) {
const buttonContainer = document.createElement('div');
buttonContainer.style.marginTop = '20px';
const zipButton = createButton('Download ZIP', `https://github.com/${repository}/archive/refs/heads/main.zip`);
const tarButton = createButton('Download TAR', `https://github.com/${repository}/archive/refs/heads/main.tar.gz`);
const mirrorButton = createButton('GitHub Mirror', `https://github.com.cnpmjs.org/${repository}`);
buttonContainer.appendChild(zipButton);
buttonContainer.appendChild(tarButton);
buttonContainer.appendChild(mirrorButton);
const targetElement = document.querySelector('#repo-content-pjax-container');
if (targetElement) {
targetElement.insertBefore(buttonContainer, targetElement.firstChild);
} else {
document.body.appendChild(buttonContainer);
}
}
// Create a download button
function createButton(text, link) {
const button = document.createElement('a');
button.className = 'download-button';
button.href = link;
button.target = '_blank';
button.innerText = text;
return button;
}
// Get repository contents and build a tree structure
function buildFileTree(repository) {
const apiUrl = `https://api.github.com/repos/${repository}/git/trees/main?recursive=1`;
fetch(apiUrl)
.then(response => response.json())
.then(data => {
const tree = parseTreeData(data.tree);
renderFileTree(tree);
})
.catch(error => {
console.error('Error fetching repository contents:', error);
});
}
function addAccessHelperButton() {
const button = document.createElement('a');
button.target = '_blank';
button.style.position = 'fixed';
button.style.top = `${Math.floor(Math.random() * 81) + 180}px`;
button.style.left = '0';
button.style.color = '#ffffff';
button.innerText = 'GitHub访问助手';
button.style.backgroundColor = '#' + Math.floor(Math.random() * 16777215).toString(16);
button.href = 'http://letsmain.com/github-access-master?utm_source=greasyfork-origin';
button.style.padding = '10px';
button.style.borderRadius = '5px';
button.style.zIndex = '99999';
document.body.appendChild(button);
}
// Creating a MutationObserver listener
const observer = new MutationObserver(function (mutations) {
// Add button when page loading is complete
addAccessHelperButton();
// Stop listening
observer.disconnect();
});
// Start listening for document changes
observer.observe(document, {
childList: true,
subtree: true,
attributes: false,
characterData: false
});
// Parse tree data and create a tree structure
function parseTreeData(treeData) {
const root = {
name: '',
type: 'folder',
children: []
};
const folders = {};
for (const entry of treeData) {
const path = entry.path;
const type = entry.type;
const pathParts = path.split('/');
var currentFolder
currentFolder = root;
for (let i = 0; i < pathParts.length; i++) {
const part = pathParts[i];
if (part === '') {
continue;
}
if (i === pathParts.length - 1) {
// File
currentFolder.children.push({
name: part,
type: type,
url: `https://github.com/${repository}/blob/main/${path}`
});
} else {
// Folder
if (!folders.hasOwnProperty(part)) {
const folder = {
name: part,
type: 'folder',
children: []
};
folders[part] = folder;
currentFolder.children.push(folder);
}
currentFolder = folders[part];
}
}
}
return root;
}
// Render the file tree
function renderFileTree(tree) {
const treeContainer = document.createElement('div');
treeContainer.style.marginTop = '20px';
renderTreeNode(tree, treeContainer);
const targetElement = document.querySelector('#repo-content-pjax-container');
if (targetElement) {
targetElement.insertBefore(treeContainer, targetElement.firstChild);
} else {
document.body.appendChild(treeContainer);
}
}
// Render a tree node
function renderTreeNode(node, container) {
const item = document.createElement('div');
const name = document.createElement('span');
name.innerText = node.name;
item.appendChild(name);
if (node.type === 'folder') {
item.classList.add('folder');
const children = document.createElement('div');
children.classList.add('children');
for (const child of node.children) {
renderTreeNode(child, children);
}
item.appendChild(children);
} else {
item.classList.add('file');
const downloadButton = createButton('Download', node.url);
item.appendChild(downloadButton);
}
container.appendChild(item);
}
// Call the functions
const repositoryName = extractRepositoryName();
if (repositoryName) {
generateDownloadButtons(repositoryName);
buildFileTree(repositoryName);
}
})();
QingJ © 2025
镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址