git、、

有学弟想快速上手git,我就发个文章吧。

git区域划分:

  • 缓冲区:英文叫 stage 或 index。一般存放在 .git 目录下的 index 文件(.git/index)中。
  • 版本库:工作区有一个隐藏目录 .git,就是 Git 的版本库。

本地、缓冲区、版本库

1作用

分布式的代码版本管理工具/团队协作工具

张三->一段程序A.java

李四->一段程序B.java

在两个不同的文件,最传统的手工人工合并

帮助我们进行代码合作,方便进行团队协作的版本管理工具

像图片一样,不同的版本就是不同的分支。

github.com -全球范围内,微软收购了

gitlab.com

gitee.com--github.com国内版

2安装与使用

第一步安装git客户端

git官网Git - Downloads

也可以用yum安装 yum -y install git

查看版本 yum — version

brew install git

第二部设置本地名字和邮箱

Git 全局设置:

机器标识

git config --global user.name "用户名" git config --global user.email "你的邮箱"

第三步生成ssh key

ssh-keygen -t rsa -C "你的邮箱"

第一个回车,默认路径

第二个使用秘钥的密码也可以为空

第三次再次输入相同密码也可为空

我这个是重写过的所以有overwrite

然后根据路径

找到pub公钥

第四步在giteessh公钥添加公钥

使用

`公钥可以给别人

`私钥不要给任何人,只自己使用.

他俩钥匙都能解开对方的加密

自己通过私钥加密的链接能用公钥解开,此时就能认定我就是私钥的主人.

补充:

`加密证书

`电子签章

对称加密与非对称加密

“对称加密”很好理解,就是指加密和解密时使用的密钥都是同一个,是“对称”的。只要保证了密钥的安全,那整个通信过程就可以说具有了机密性。

举个例子,你想要登录某网站,只要事先和它约定好使用一个对称密码,通信过程中传输的全是用密钥加密后的密文,只有你和网站才能解密。黑客即使能够窃听,看到的也只是乱码,因为没有密钥无法解出明文,所以就实现了机密性。

1、DES

数据加密标准(DES)算法 采用的 56 位密钥,每次计算加密 64 位的数据。目前已经被证明可以被暴力破解。所谓暴力破解,就是遍历所有可能的密钥解析数据的方法。举个例子,已知张三和李四传输的是中文,加密算法是 DES,那么拿出一小段数据进行暴力破解,尝试所有的密钥,如果能成功解析出中文词语(词语在词库中可以查到),那么说明破解成功。

2、AES(推荐)

为了应对暴力破解等问题,很多团队选择对称加密算法时开始使用高级加密标准(AES),这个加密法用 128 位密钥,并设计了更难破解的算法。推荐在项目中使用

3、其他

RC4、DES、3DES、AES、ChaCha20 ,但前三种算法都被认为是不安全的,通常都禁止使用,目前常用的只有 AES 和 ChaCha20。

对称加密看上去好像完美地实现了机密性,但其中有一个很大的问题:如何把密钥安全地传递给对方,术语叫“密钥交换”。如果你和网站约定的密钥在传递途中被黑客窃取,那就没有安全性可言了。所以需要一种新的可以保证安全传递秘钥的算法。

非对称加密

非对称加密也叫公钥加密算法。它有两个密钥,一个叫“公钥”(public key),一个叫“私钥”(private key)。两个密钥是不同的,“不对称”,公钥可以公开给任何人使用,而私钥必须严格保密。

公钥和私钥有个特别的“单向”性,虽然都可以用来加密解密,但公钥加密后只能用私钥解密,反过来,私钥加密后也只能用公钥解密。

非对称加密可以解决“密钥交换”的问题。网站秘密保管私钥,在网上任意分发公钥,你想要登录网站只要用公钥加密就行了,密文只能由私钥持有者才能解密。而黑客因为没有私钥,所以就无法破解密文

1、RAS

RSA 几乎可以说是非对称加密的代名词,它的安全性基于“整数分解”的数学难题,使用两个超大素数的乘积作为生成密钥的材料,想要从公钥推算出私钥是非常困难的。

10 年前 RSA 密钥的推荐长度是 1024,但随着计算机运算能力的提高,现在 1024 已经不安全,普遍认为至少要 2048 位。

2、其他

DH、DSA、ECC 等。

HTTPS 协议的握手和交换密钥过程需要非对称加密算法;

应用

HTTPS 协议的握手和交换密钥过程需要非对称加密算法

比如利用证书实现 git 账号的免密操作也是基于非对称加密算法

文件提交

三个区域

第五步相关代码

其实不用代码,直接用idea的git很方便。

创建 git 仓库:

mkdir t-mall
cd t-mall
git init //初始化本地仓库
touch README.md
git add README.md//将本地文件加载到缓冲区
git commit -m "first commit"//将缓冲区文件加载到本地仓库
git remote add origin https://gitee.com/dukai01/ant-mall.git//添加一个新的远程仓库
git push -u origin "master"//推送缓冲区的文件到远程仓库主分支

用SSH不用密码

而HTTP需要密码

如果用了HTTP还想换SSH

remote rm origin

然后再重新进行操作

此时就已经创建完git仓库并且上传文件了

使用创建好的仓库

git clone +仓库//拷贝一份远程仓库

然后git add.

git status查看追踪情况

git commit -m

然后git push

同步线上仓库文件到本地

git fetch和git pull

同名且文件内容相同会报错

分支管理

创建分支命令:

git branch (branchname)

没有参数的时候就会展示你在本地的分支

删除分支命令:

git branch -d (branchname)

切换分支命令:

git checkout (branchname)

当你切换分支的时候,Git 会用该分支的最后提交的快照替换你的工作目录的内容, 所以多个分支不需要多个目录。

合并分支命令:

git merge 

为什么 GitHub 需要 SSH Key 呢?

因为 GitHub 需要识别出你推送的提交确实是你推送的,而不是别人冒充的。Git 支持SSH 协议,所以, GitHub 只要知道了你的公钥,当你推送的时候,它就能知道这是你,从而允许你推送(这是非对称加密的功能:私钥对数据进行加密,公钥对加密后的数据进行签名验证,可以确定是否是匹配的私钥加密后的数据)。

当然, GitHub 允许你添加多个 Key。假定你有若干电脑,你一会儿在公司提交,一会儿在家里提交,只要把每台电脑的 Key 都添加到 GitHub,就可以在每台电脑上往 GitHub 推送了。

  • 31
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值