SVN權(quán)限控制手冊(cè)新手必備
本節(jié)和大家一起學(xué)習(xí)一下SVN權(quán)限控制,只有掌握了對(duì)SVN權(quán)限的管理才能更好的使用SVN,讓我們一起來(lái)學(xué)習(xí)SVN權(quán)限控制吧。
SVN權(quán)限控制手冊(cè)
在文章《Subversion詳細(xì)說(shuō)明》中,我們?cè)?jīng)建立了一個(gè)版本控制倉(cāng)庫(kù),現(xiàn)在打開這個(gè)版本控制倉(cāng)庫(kù),讓我們來(lái)看看這個(gè)目錄結(jié)構(gòu),我們會(huì)在目錄結(jié)構(gòu)中找到一個(gè)叫做conf的文件夾,打開這個(gè)文件夾,你會(huì)看到三個(gè)文件,分別叫做authz,passwd,svnserve.conf。
下面SVN權(quán)限控制就來(lái)介紹一下這三個(gè)文件的作用格式什么。
首先,我們介紹passwd這個(gè)文件。
用你習(xí)慣的文本編輯器打開這個(gè)文件,你會(huì)看到一些使用“#”注釋掉的說(shuō)明,其中關(guān)鍵的就是在[users]下面,有
#harry=harryssecret
#sally=sallyssecret
樣的樣板代碼,意思就是有兩個(gè)用戶,其中一個(gè)的用戶名叫“harry”,密碼為“harryssecret”,而另一個(gè)用戶名為“sally”,密碼為“sallyssecret”。我們接下來(lái)為我們的測(cè)試下面添加一些用戶,這樣方便我們下面的說(shuō)明。比如,我要添加三個(gè)用戶,一個(gè)叫做“nicholas”,密碼為“nicholas”,第二個(gè)用戶名為“friend”,密碼為“friend”,第三個(gè)為“stranger”,密碼為“strangers”。
代碼如下:
nicholas=nicholas
friend=friend
stranger=stranger
這樣,我們就添加好了三個(gè)認(rèn)證用戶。
###Thisfileisanexamplepasswordfileforsvnserve.
###Itsformatissimilartothatofsvnserve.conf.Asshowninthe
###examplebelowitcontainsonesectionlabelled[users].
###Thenameandpasswordforeachuserfollow,oneaccountperline.
[users]
#harry=harryssecret
#sally=sallyssecret
nicholas=nicholas
friend=friend
stranger=stranger
下面,SVN權(quán)限控制來(lái)介紹authz這個(gè)文件,這個(gè)文件是控制權(quán)限的關(guān)鍵。
同樣打開這個(gè)文件,你會(huì)看到一些注釋掉的語(yǔ)句,
#[groups]
#[/foo/bar]
#[repository:/baz/fuz]
下面,我們介紹一下用戶組的概念。所謂用戶組,顧名思義,就是一個(gè)成員組,一般情況下,在同一個(gè)成員組的人員享有同樣的權(quán)力,比如讀,寫權(quán)。Subversion為我們提供了一個(gè)很好的用戶組應(yīng)用。
在之前,我們一共建立三個(gè)用戶,nicholas,friend和stranger,我們現(xiàn)在設(shè)想一下我們的組情況,假設(shè)我們希望nicholas和friend在開發(fā)組中,這兩個(gè)用戶具有讀和寫的權(quán)力,而用戶stranger在測(cè)試組中,只具備讀的權(quán)力。那么我們?cè)撊绾蝸?lái)控制這個(gè)權(quán)限呢?看看下面的代碼:
我們先在[groups]標(biāo)記下面,輸入組的名稱:
dev_group=nicholas,friend
test_group=stranger
到目前為止,我們已經(jīng)為三個(gè)用戶分好了用戶組,其中nicholas和friend在dev_group中,而stranger則在test_group中。
下面,SVN權(quán)限控制手冊(cè)介紹一下如何為兩個(gè)組來(lái)分配權(quán)限。
首先我們要為這兩個(gè)組所能訪問(wèn)的工程做一個(gè)規(guī)定,正如在之前的文章《Eclipse中使用Subversion進(jìn)行版本控制》中,曾經(jīng)向版本參考提交了一個(gè)名為“TestSVNProj”的項(xiàng)目,下面我就假設(shè)剛剛建立的兩個(gè)用戶組都需要最這個(gè)工程進(jìn)行操作。
我們?cè)赼uthz文件中,寫下[TestSVNProj],這個(gè)是指定我們下面將對(duì)TestSVNProj項(xiàng)目進(jìn)行定義。
我們使用如下代碼:
@dev_group=rw
@test_group=r
這就定義了,對(duì)TestSVNProj項(xiàng)目,dev_group用戶組可以進(jìn)行讀,寫操作,而test_group用戶組則只具備讀的權(quán)限。
為了阻止其他用戶組對(duì)這個(gè)文件有讀的權(quán)力,我們可以再添加一句:
*=
這個(gè)語(yǔ)句就是指定其他的用戶組的權(quán)力為空,也就是沒(méi)有權(quán)力。
***,我們?cè)趤?lái)說(shuō)說(shuō)這個(gè)svnserve.conf文件,打開這個(gè)文件,我們就可以看出這個(gè)是Subversion權(quán)限配置的主文件,類似于讀取相關(guān)信息的樞紐。
為了讓我們剛剛配置的兩個(gè)文件(passwd和authz)起作用,我們需要去掉password-db=passwd和authz-db=authz前面的注釋符“#”,讓Subversion知道要從上面兩個(gè)文件中讀取相關(guān)信息。
當(dāng)然,你也可以指定其他的認(rèn)證文件,寫法如下:
password-db=..\..\passwd
authz-db=..\..\authz
以此類推。
在實(shí)戰(zhàn)過(guò)程中,處于安全的考慮,我們往往要限制對(duì)匿名用戶的訪問(wèn)權(quán)限,所以我們可以將anon-access=read前面的“#”去掉,并將read參數(shù)修改為none,表明禁止匿名用戶對(duì)版本控制庫(kù)的訪問(wèn)。至此,SVN權(quán)限控制學(xué)習(xí)結(jié)束,你可以控制你的項(xiàng)目,對(duì)其進(jìn)行訪問(wèn)權(quán)限的控制了。
【編輯推薦】
- 多項(xiàng)目中SVN權(quán)限管理精辟解析
- Apache+SVN權(quán)限管理實(shí)例剖析
- SVN版本庫(kù)自動(dòng)備份如何實(shí)現(xiàn)?
- 如何實(shí)現(xiàn)SVN倉(cāng)庫(kù)目錄規(guī)范化管理?
- 經(jīng)驗(yàn)總結(jié):TortoiseSVN客戶端使用心得