1、安装Git插件
Myeclipse老版本可能需要安装Git插件(window->preference->Team下出现Git就说明安装成功),高版本中已经安装好了。我所使用的是MyEclipse2016,不需要安装Git插件,所以在这里就不在具体讲述安装Git插件的步骤。
2、生成MyEclipse的一个SSH的认证号
由于Github的代码是开源的,每个人都可以查看代码,但是只有自己能够修改代码。Github通过SSH Key识别出提交的代码是用户本人推送的,才能够针对相应的代码进行操作。即本地Git仓库和GitHub仓库之间的传输是通过SSH加密的,所以需要本地创建SSH Key并在GitHub服务器上设置SSH Key,从而创建本地和Guthub服务器的关系:window->preferences-->general-->Network Connections-->SSH2
2.1、General中的值为用户主目录下的.ssh文件和该目录下的id_rsa和id_rsa.pub文件(这两个就是SSH Key的秘钥对,id_rsa是私钥,不能泄露出去,id_rsa.pub是公钥,可以放心地告诉任何人)
data:image/s3,"s3://crabby-images/a9764/a9764abe310472b9df17ff69f2b6bfea0c848fe0" alt=""
2.2、本地创建SSH Key:点击Key Management 中的Generate RSA Key...生成SSH认证号,然后点击Save Pravite Key进行保存(注意:不要将我们之前的公钥和密钥给覆盖了,我们可以选择另外的目录进行保存),然后点击Apply
data:image/s3,"s3://crabby-images/32a75/32a75e78c55783c12f59a77a39ab7f46bc27051a" alt=""
3、在GitHub上设置SSH Key,从而创建本地和Guthub服务器的关系(将生成的公钥添加到Github中去)
3.1、拷贝公钥文件id_rsa.pub的内容:找到刚刚保存公有秘钥的路径(如下),可以用Notepad打开文件并复制内容
data:image/s3,"s3://crabby-images/783b2/783b24e887106cb0355dd876d4a721ad2e65fa29" alt=""
3.2、将从id_rsa.pub公有密钥文件中复制的内容添加到Github的ssh key 设定里:
(1)注册Github账号:打开Github主页https://github.com进行注册,按要求填写用户名、密码和邮箱,并进行邮箱验证
(2)打开github网站的“settings”中的SSH Keys或者直接页面访问https://github.com/settings/ssh
(3)点击右上角 Add SSH key
(4)输入title(任意填写,这里以gittest为例),然后将复制的公有密钥复制粘贴到key中
data:image/s3,"s3://crabby-images/9ff35/9ff355caeaabee63468b4d2a62d4ac94d815b070" alt=""
添加完成后结果
data:image/s3,"s3://crabby-images/4c001/4c00146d95b75a15b3e2b1b9b4083a87adc026d8" alt=""
注意:私有密钥和公有密钥是成对的两个文件,私有文件保存在自己的本机,公有密钥保存到另一端的服务器、网站 等。github就是一种网站。只有保存了私有密钥的机器才能访问远程的服务器等。使用该键的好处是不用使用密码,而是以密钥的方式验证用户。要想使本机能访问github。有三个步骤:(1) 创建私有密钥和公有密钥(2)将公有密钥放到github里。(3)测试是否设置成功(4)修改本地git配置文件并发布
4、在Github上创建自己的代码仓库
4.1、Github注册成功后,点击右上角的“+”号,选择New repository开创建代码仓库
(1)Resository name:填写自己定义的仓库名(必填项)
(2)Description:填写描述(选填项)
(3)Public:保持选中(如果选Private可以选择谁能看到谁能提交,public只能选谁能提交,private是要钱的)
(4)Initialize this repository with a README:决定是否生成一个README文件来初始化仓库(可选可不选)
(5)Create repository:点击生成代码仓库
data:image/s3,"s3://crabby-images/2e782/2e782d8511c9d46be9d6d0a10fd84510737a09d6" alt=""
4.2、获取代码仓库的地址:点击Create repository后生成http地址就是该代码仓库的地址,如下图所示
data:image/s3,"s3://crabby-images/ab2dd/ab2dd6da3ecce4b2becbba2a85e28c4488b1e407" alt=""
5、创建本地git仓库
5.1、在MyEclipse中创建项目(如gittest)
5.2、右键项目-->team-->share project来共享项目
data:image/s3,"s3://crabby-images/55ddf/55ddf6e6c91e7026afcdf1acd7459b521f6a221c" alt=""
点击Next,出现如下界面,进行Git代码库配置
data:image/s3,"s3://crabby-images/3568a/3568a5531efed6f58ae77fb1f6e8fd10da85a775" alt=""
点击Finish,我们的工程显示为NO-HEAD,即表示没有指针指向
data:image/s3,"s3://crabby-images/1d1a4/1d1a442a279b94b512992eb50074f4843f2d8057" alt=""
6、首次提交项目至远程
选中项目右键-->team-->commit
(1)Commit message:填写提交信息
(2)Status:选中需要提交的文件
(3)Commit and Push:提交到本地并推送至Github服务器
(4)Commit:提交到本地
data:image/s3,"s3://crabby-images/c4862/c4862587556a40ff5378c0d38cb40464f68672d8" alt=""
6.1、这里我们选择提交并推送按钮,会出现以下如下界面
data:image/s3,"s3://crabby-images/749e4/749e4e06be2e42e0a0fa6be1d789393bdfd70047" alt=""
(1)首先我们需要填写github中仓库地址(4.2中已获取),同时填写用户名、密码,选中记住
data:image/s3,"s3://crabby-images/9ad26/9ad26676bcdf27f730e36224182229f87a7400b0" alt=""
(2)然后点击Next
data:image/s3,"s3://crabby-images/2d3fa/2d3fa3e904af46712c01cae14068260312998ae1" alt=""
(3)然后会进行远程通信,如果网络不好可能会有点问题
data:image/s3,"s3://crabby-images/a6673/a667352441162b14c1356fc7d4228584ffdc90ab" alt=""
(4)远程连接成功后,会出现如下界面
data:image/s3,"s3://crabby-images/23d25/23d25c800c1fe67d2b5e01811431fa56bb7bab6a" alt=""
(5)点击Finish
data:image/s3,"s3://crabby-images/e7869/e78694f67d5111106aa79f655fb9d032b515539a" alt=""
(6)此时项目状态如下:即表示没有指针指向的“NO-HEAD”已经消失,项目显示在master分支上
data:image/s3,"s3://crabby-images/f30e0/f30e0f6ed1c8f95f48ea8abdb283d08628fc1e86" alt=""
6.2、查看提交信息
(1)查看本地提交信息:右键项目-->team-->Show in History来查看提交信息
data:image/s3,"s3://crabby-images/0bd9d/0bd9da51566cad64b0d9fe2278d7e834e278b5cf" alt=""
(2)查看Github服务器上的提价信息:访问https://github.com/sewenfengqing/development查看提交信息(提交所在分支、提交描述、提交时间等)
data:image/s3,"s3://crabby-images/f11f9/f11f9bd0a8d28d79136717f9d7b58193d641c1c6" alt=""
为什么在MyEclipse中的gittest已经通过项目右键-->team-->Commit多次,且通过项目右键-->team-->Show in History查看到了提交信息,问什么在Guithub中仅能查到第一次的提交信息,之后却查不到?(注意:通过项目右键-->team-->commit只是提交到本地,而通过项目右键-->team-->push to upstream或者commit中commit and push才会上传到Github服务器)
7、修改代码提交至本地Git
data:image/s3,"s3://crabby-images/ccddc/ccddcf71c6cec9a3b09a710b455cea6d4d21dec1" alt=""
此时仅在本地有提交信息,Github上没有
data:image/s3,"s3://crabby-images/e6b46/e6b464855fc26c74d26f94491b2913139887939c" alt=""
8、修改代码提交至远程仓库Github
直接项目右键-->team-->commit-->commit and push推送项目至服务器,出现如下问题
data:image/s3,"s3://crabby-images/a8ce7/a8ce7a8fb1ed41f3db94825175d79ae6900edf96" alt=""
为了使用远程推送,您必须指定至少一个URI和至少一个REF映射
data:image/s3,"s3://crabby-images/13c38/13c38795f270fa7011c1f4e375db7d8821229d57" alt=""
解决方案:
(1)创建分支:项目右键-->team-->Switch to-->New Branch
data:image/s3,"s3://crabby-images/0e6cc/0e6cc60a67783b28750d6ebefbf9467f8ee7fc67" alt=""
(2)项目显示就在bliy分支上
data:image/s3,"s3://crabby-images/c1d5e/c1d5e55b674a0a6426ad7ac7c2b328792b290273" alt=""
(3)提交新建的文件
1>右键文件-->team-->Add to Index;
data:image/s3,"s3://crabby-images/8d67e/8d67ec21321f6db5c553a9fd814f0829591d7cf4" alt=""
2>此时新建的文件前面会出现“+”号,右键文件-->team-->commit,选择commit;
3>而后我们再进行推送team-->Push branch liy
(后两步可以替换为:右键文件-->team-->commit-->commit and push)
data:image/s3,"s3://crabby-images/e4b3b/e4b3b28f090fd6e41ff13fc5f73e0b6fad40ef3c" alt=""
(4)重新提交修改代码并推送至服务器
文件右键-->team-->commit-->commit and push
data:image/s3,"s3://crabby-images/0e1da/0e1dadbad17475641da9e941a55ce7f45b55490a" alt=""
data:image/s3,"s3://crabby-images/393b8/393b8f0818b9b11027bc9e91091ee03d14d2a1fc" alt=""
(5)Giithub上显示提交信息
data:image/s3,"s3://crabby-images/be727/be727c91eab3e372013c61cdfdf3e6f555606100" alt=""
9、合并分支
(1)首先切换回主分支:team-->Switch to -->master
(2)之后:team-->Merge
data:image/s3,"s3://crabby-images/374f4/374f4a0515138ed08aee1c3f9048f19c35b216cb" alt=""
(3)选中liy分支,点击Merge
data:image/s3,"s3://crabby-images/ace04/ace0443412117d532e4d2dd958d5aeb6260088ce" alt=""
(4)点击ok之后再进行提交推送
10、通过使用egit插件来进行版本控制
10.1、从服务器克隆代码仓库至本地
项目右键-->import-->Git-->Projects from Git
data:image/s3,"s3://crabby-images/de904/de90416f425ccd23ee016615791e4d8493e9dc81" alt=""
点击Next
data:image/s3,"s3://crabby-images/feeb4/feeb4930769530df496b60416774e8299097ac3a" alt=""
点击Next
data:image/s3,"s3://crabby-images/01f6d/01f6d7bd57a1e45f27a9c7cd4d10bce50eae6207" alt=""
点击Next,仓库就从远程Clone(克隆)到本地
data:image/s3,"s3://crabby-images/cc715/cc715485dfad7a1ac69101c4108c5024b5a7ead5" alt=""
之后在myeclipse中导入该项目,更改代码后的提交方式请看上面的第六步。
10.2、提交修改的代码到Github服务器
(1)将改动的代码标记
项目右键-->team-->synchronize workspace
data:image/s3,"s3://crabby-images/19a3e/19a3e012e6e62a4919dc076870578e9d5788fc27" alt=""
点击Yes后
data:image/s3,"s3://crabby-images/ca579/ca5798bb5c140bc74f0217374648b8dc5bc550f0" alt=""
项目右键-->Add to Index ,修改的文件标记为“*”
data:image/s3,"s3://crabby-images/6dab6/6dab6b042c92ce1170fd591847d3ddb97395e97d" alt=""
(2)将工作空间的代码提交到本地仓库
项目右键-->team-->commit
(3)将远程仓库的代码pull(合并)到本地仓库
项目右键-->team-->pull (这一步可能需要解决代码冲突,合并代码 )
(4)将本地仓库代码push(推送)到远程仓库
项目右键-->team-->push to upstream
网友评论