方法一:
利用svnkit的api进行获取,代码如下:
public String getMergeInfo1(String svnURL) {
Properties properties = System.getProperties();
properties.setProperty("svnkit.http.methods", "Basic,Digest,NTLM");
SVNRepository repository = null;
try {
repository = SVNRepositoryFactory.create(SVNURL.parseURIEncoded(svnURL));
ISVNAuthenticationManager authManager = SVNWCUtil.createDefaultAuthenticationManager("username", "password");
repository.setAuthenticationManager(authManager);
long latestRevision = repository.getLatestRevision();
Map<String, SVNMergeInfo> mergeInfo = repository.getMergeInfo(new String[] { "" }, latestRevision, SVNMergeInfoInheritance.EXPLICIT, false);
return mergeInfo.toString();
} catch (SVNException e) {
e.printStackTrace();
}
return "";
}
方法二:
利用svn命令的方式进行获取,这种方式在以startup.bat启动tomcat能正常运行,但以服务的形式启动tomcat时需要设置启动账号,否则取不到内容,代码如下:
public String getMergeInfo2(String svnURL) {
StringBuilder sb = new StringBuilder();
Process exec = null;
BufferedReader br = null;
try {
exec = Runtime.getRuntime().exec("svn pg svn:mergeinfo " + svnURL);
InputStream inputStream = exec.getInputStream();
br = new BufferedReader(new InputStreamReader(inputStream));
String str = null;
while ((str = br.readLine()) != null) {
sb.append(str);
sb.append("\r\n");
}
} catch (IOException e) {
e.printStackTrace();
} finally {
if (br != null) {
try {
br.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
return sb.toString();
}
分享到:
相关推荐
- `svn:mergeinfo`:记录了哪些范围的修订被合并到当前工作副本。 标签“源码 工具”表明这个话题与源代码管理和工具使用有关,SVN作为一个源码版本控制系统,正是用于此类目的。 在提供的压缩包文件名称...
7. **最佳实践**:使用SVN时,建议定期更新工作副本以获取最新变更,确保团队成员间的代码同步。在提交更改前,应先进行本地的代码审查和测试,以避免错误的提交。合理规划分支策略,例如为长期开发特性创建独立的...
2. **检出**:使用 `svn checkout` 从仓库获取工作副本。 3. **修改**:在本地工作副本中进行文件编辑。 4. **添加**:新文件或目录使用 `svn add` 添加到版本控制。 5. **删除**:使用 `svn delete` 删除不再需要的...
- **获取更新**:`git fetch` 获取远程仓库的最新改动。 - **查看状态**:`git status` 检查本地文件的改动。 - **暂存更改**:`git add` 把改动添加到暂存区。 - **提交更改**:`git commit` 提交暂存区的改动...
而在SVN中,分支只是版本库中的另一个目录,合并分支需要手动检查svn:mergeinfo属性。 `.git`目录是Git仓库在本地的表示,包含了所有中心仓库的内容,如标签、分支和历史记录。Git的分支管理非常灵活,可以在同一...