## 7.14 凭证储存
如果使用的是 SSH 方式连接远端,并且设置了一个没有口令的密钥,这样就可以在不输入用户名和密码的情况下安全地传输数据。 然而,对于 HTTP 协议来说,每一个连接都是需要用户名和密码的。Git 提供了一个凭证系统来处理这个事情,它有一下选项:
* 默认所有都不缓存。 每一次连接都会询问用户名和密码。
* `cache` :将凭证存放在内存中一段时间。 密码永远不会被存储在磁盘中,并且在15分钟后从内存中清除。
* `store`:模式会将凭证用明文的形式存放在磁盘中,并且永不过期,这意味着除非你修改了在 Git 服务器上的密码,否则永远不需要再次输入你的凭证信息。
* `osxkeychain` :对于 Mac,它会将凭证缓存到系统用户的钥匙串中。 这种方式将凭证存放在磁盘中,并且永不过期,但是是被加密的。
* `winstore` :对于Window,与 `osxkeychain` 十分类似,但是是使用 Windows Credential Store 来控制敏感信息。
设置 Git 的配置来选择上述的一种方式:
```
$ git config --global credential.helper cache
```
`store` 模式可以接受一个`--file <path>`参数,可以自定义存放密码的文件路径(默认是`~/.git-credentials` )。`cache` 模式有`--timeout <seconds>`参数,可以设置后台进程的存活时间(默认是 “900”,也就是 15 分钟)。
**底层实现**
凭证系统实际调用的程序和 Git 本身是分开的,具体是哪一个以及如何调用与`credential.helper`配置的值有关。
**自定义凭证缓存**
因为凭证系统实际调用的程序和 Git 本身是分开的,所以 Git 凭证辅助工具可以是任意程序。而自定义凭证缓存扩展只要是一个 Git 能够执行最终的程序即可,任何语言都是可以的。这个辅助工具需要放到`PATH`路径下并且给予执行权限。
- 介绍
- 第一章 起步
- 1.1 关于版本控制
- 1.2 Git 简史
- 1.3 Git 基础
- 1.4 命令行
- 1.5 安装 Git
- 1.6 初次运行 Git 前的配置
- 1.7 获得帮助
- 第二章 基础
- 2.1 获取仓库
- 2.2 记录每次更新到仓库
- 2.3 查看提交历史
- 2.4 撤销操作
- 2.5 远程仓库的使用
- 2.6 打标签
- 2.7 Git 别名
- 第三章 分支
- 3.1 分支简介
- 3.2 分支的新建与合并
- 3.3 分支管理
- 3.4 分支开发工作流
- 3.5 远程分支
- 3.6 变基
- 第四章 服务器上的 Git
- 4.1 协议
- 4.2 在服务器上搭建 Git
- 4.3 生成 SSH 公钥
- 4.4 配置服务器
- 4.5 Git 守护进程
- 4.6 Smart HTTP
- 4.7 GitWeb
- 4.8 GitLab
- 4.9 第三方托管的选择
- 第五章 分布式 Git
- 5.1 分布式工作流程
- 5.2 向一个项目贡献
- 5.3 维护项目
- 第六章 GitHub
- 6.1 账户的创建和配置
- 6.2 对项目做出贡献
- 6.3 维护项目
- 6.4 管理组织
- 6.5 脚本 GitHub
- 第七章 Git 工具
- 7.1 选择修订版本
- 7.2 交互式暂存
- 7.3 储藏与清理
- 7.4 签署工作
- 7.5 搜索
- 7.6 重写历史
- 7.7 重置揭密
- 7.8 高级合并
- 7.9 Rerere
- 7.10 使用Git调试
- 7.11 子模板
- 7.12 打包
- 7.13 替换
- 7.14 凭证存储
- 第八章 自定义 Git
- 8.1 配置 Git
- 8.2 Git 属性
- 8.3 Git 钩子
- 8.4 使用强制策略的一个例子
- 第九章 Git 与其他系统
- 9.1 作为客户端的 Git
- 9.2 迁移到 Git
- 第十章 Git 内部原理
- 10.1 底层命令和高层命令
- 10.2 Git 对象
- 10.3 Git 引用
- 10.4 包文件
- 10.5 引用规格
- 10.6 传输协议
- 10.7 维护与数据恢复
- 10.8 环境变量
