git 代码协同之回车问题 CRLF LF

http://blog.csdn.net/guodengh/article/details/8630888

格式化

格式化是许多开发人员在协作时,特别是在跨平台情况下,遇到的令人头疼的细小问题。 由于编辑器的不同或者Windows程序员在跨平台项目中的文件行尾加入了回车换行符, 一些细微的空格变化会不经意地进入大家合作的工作或提交的补丁中。不用怕,Git的一些配置选项会帮助你解决这些问题。

core.autocrlf

查看当前git的配置:$ git config -list   简写-l

假如你正在Windows上写程序,又或者你正在和其他人合作,他们在Windows上编程,而你却在其他系统上,在这些情况下,你可能会遇到行尾 结束符问题。 这是因为Windows使用回车和换行两个字符来结束一行,而Mac和Linux只使用换行一个字符。 虽然这是小问题,但它会极大地扰乱跨平台协作。

Git可以在你提交时自动地把行结束符CRLF转换成LF,而在签出代码时把LF转换成CRLF。用core.autocrlf来打开此项功能, 如果是在Windows系统上,把它设置成true,这样当签出代码时,LF会被转换成CRLF:

$ git config --global core.autocrlf true

Linux或Mac系统使用LF作为行结束符,因此你不想Git在签出文件时进行自动的转换;当一个以CRLF为行结束符的文件不小心被引入时你肯定想进行修正, 把core.autocrlf设置成input来告诉Git在提交时把CRLF转换成LF,签出时不转换:

$ git config --global core.autocrlf input

这样会在Windows系统上的签出文件中保留CRLF,会在Mac和Linux系统上,包括仓库中保留LF。

如果你是Windows程序员,且正在开发仅运行在Windows上的项目,可以设置false取消此功能,把回车符记录在库中:

$ git config --global core.autocrlf false

----------------------------------------------------------------------

比如我遇到的问题是“please remove carriage return's from...”,意思是消除回车,估计就是因为跨平台的原因,按上面把autocrlf设置为false就好了

----------------------------------------------------------------------

2015/12/3  再次编辑,对此问题的进一步解释

CRLF -- Carriage-Return Line-Feed 回车换行

这两个ACSII字符不会在屏幕有任何输出,但在Windows中广泛使用来标识一行的结束。而在Linux/UNIX系统中只有换行符。
  CR和LF组合在一起即CRLF命令,它表示键盘上的Enter键(可以用来模拟回车键)。
  CRLF注入就是说黑客能够将CRLF命令注入到系统中。它不是系统或服务器软件的漏洞,而是网站应用开发时,有些开发者没有意识到此类攻击存在的可能而造成的。
  就算黑客发现网站存在CRLF注入,他们仍然受到应用结构和这个缺陷的严重程度的限制。
  对有些站点它将非常严重,而有些站点它只是很小的bug。
  HTTP Header CRLF Injection
  许多网络协议,包括HTTP也使用CRLF来表示每一行的结束。这就意味着用户可以通过CRLF注入自定义HTTP header,导致用户可以不经过应用层直接与Server对话。
  HTTP header的定义就是基于这样的Key: Value的结构,用CRLF命令表示一行的结尾。
<strong>现在的git在安装时会询问换行风格</strong>
git 代码协同之回车问题 CRLF LF_第1张图片

你可能感兴趣的:(git 代码协同之回车问题 CRLF LF)