- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我正在使用 git 来管理一个小项目。我一直在通过 SSH 执行所有事务(克隆、推送、 pull 等),但最近运行了 git-update-server-info,因为我想尝试通过 http 运行 git-clone。效果很好。凉爽的。现在我意识到任何人都可以在没有任何凭据的情况下通过 http 克隆我的存储库。我隐约知道通过 gitosis 设置 http 身份验证,但这真的不是我想要的。我宁愿完全禁用 http 克隆。
有没有办法让 git 只允许通过 ssh 进行交易?或者我可以撤消我在运行 git-update-server-info 时所做的操作以首先启用通过 http 的克隆吗?
最佳答案
要使 git 存储库通过 HTTP 传输可用,它需要由(任何)网络服务器“导出”。如果您的存储库(更准确地说是它的 .git
目录)在 Web 浏览器中从外部可见,则可以通过 HTTP 协议(protocol)匿名克隆或获取它。 git update-server-info
用于生成额外的辅助帮助信息(.git/objects/info/packs
和 .git/info/refs
)以供克隆(或获取)了解可用的内容.
所以您需要做的是删除这两个文件(.git/objects/info/packs
和.git/info/refs
) ,或者只是让它无法通过网络访问您的存储库,可能是通过更改权限以网络服务器运行的用户(通常是'nobody'或'www',或'apache') 无权访问 .git
存储库。或者配置网络服务器,使其不会导出(使其可见)您的存储库。
HTTP 协议(protocol)(目前)是所谓的“哑”协议(protocol),这意味着它按原样提供文件,访问控制由 [哑] 服务器完成,在本例中由您使用的 Web 服务器(或文件系统)完成.
我猜你的存储库不是由网络服务器导出的,所以你不必担心:你的存储库无法通过 HTTP 访问。
请注意,Git 存储库通常具有匿名、未经身份验证的只读访问权限,并且仅在写入存储库时需要身份验证,即推送(至少对于开源项目而言)
关于git - 我可以通过 http "disable"git-clone 吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1348568/
我使用 jQuery 禁用选择下拉列表中的选项。我需要知道使用之间的区别 prop('disabled','disabled') 和 prop('disabled',true) 两者几乎都适用于所有浏
.attr('disabled', 'disabled') 和 .attr('disabled', true) 在我的代码中都有效,但我只是想知道:两者中哪一个更有效和/或哪一个更常用?真的有区别吗?
我的 asp.net mvc View 中有以下脚本:- function disableform(id) { $('#' + id).prop("disabled", true); } 但是
我已经在 Oracle VM Ware 中为我的 ubuntu 可信操作系统安装了 visual studio 代码和依赖项。我用这些命令运行代码。 ssh -X myserver code 但是当我
我有这个函数可以切换输入字段的禁用属性: $('.someElement').click(function(){ if (someCondition) { console.log
自从前几天我升级了 angularjs 后,我一直收到警告。每当我打开 ui.bootstrap 模式时,它都会发生。 这是我在 chrome-beta 44 中收到的警告: angular.js:1
我想限制用户在单击特定按钮时在文本框中输入值,否则设置禁用 false。如果我设置 $("#txtquery").attr("disabled","disabled"); 它将文本框设置为空白。如果切
How do I make a Spinner's "disabled" state look disabled? 可能重复. 我尝试了帖子中提到的解决方案,即 ((Spinner) spinner)
这段代码: $tds = $(this).closest('tr').find(td input,select); $tds.attr('disabled','disabled'); 使我的表格行不
使用 jQM 1.4.0我试图覆盖灰色样式(): input[type="text"]:disabled { opacity: 1.0 !important; color: black
不知道为什么这不起作用。 当人们单击我的应用程序的“编辑”按钮时,禁用的文本字段将变为可编辑: $("#bewerken").click(function(e) { $("input[d
我对以下差异有些困惑: swiftlint:disable:next swiftlint:disable:this 最佳答案 它们都用于禁用单行的快速规则。您还可以为单行启用规则。来自 SwiftLi
我看到一些代码 # pylint: disable=W0123 还有一些 # pylint: disable-msg=W0123 它们只是同义词吗? 最佳答案 从 pylint 0.21.0 开始不推
默认情况下,在桌面上,flutter 中的 btns 在禁用时会更改鼠标光标: 我们想禁用此行为,或替换为不同的光标。 最佳答案 要覆盖 ElevatedButton、TextButton 或 Out
我一直在学习很多关于标准 asp.net 验证器的知识,我的最新发现是关于如何禁用验证器客户端,这非常酷。 现在,如果我的初始帖子启用了验证器,但在客户端,我禁用它,服务器端是否识别客户端更改并保留它
默认情况下,在桌面上,flutter 中的 btns 在禁用时会更改鼠标光标: 我们想禁用此行为,或替换为不同的光标。 最佳答案 要覆盖 ElevatedButton、TextButton 或 Out
这个问题在这里已经有了答案: Should I use CSS :disabled pseudo-class or [disabled] attribute selector or is it a
我有一个 python 脚本,它发送包含文本、html 和 ics 附件的多部分电子邮件。这个想法是,现代电子邮件客户端将呈现 HTML 部分并提供将事件添加到用户日历中的功能。 代码如下: impo
我有一个最初被禁用的按钮: Lorem ipsum 对于此按钮,button.getAttribute('disabled') 返回 "disabled"。但是,当我使用 JavaScript 启用此
在我的一些测试中,我必须确认在设置某些标志时某些 select2 下拉菜单被禁用。为了证实这一点,我发现以下策略似乎有效: Assert.True(element.GetAttribute("disa
我是一名优秀的程序员,十分优秀!