`

获取Svn mergeInfo总结

    博客分类:
  • SVN
阅读更多
方法一:
利用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属性配置:必须输入日志/日志模版

    - `svn:mergeinfo`:记录了哪些范围的修订被合并到当前工作副本。 标签“源码 工具”表明这个话题与源代码管理和工具使用有关,SVN作为一个源码版本控制系统,正是用于此类目的。 在提供的压缩包文件名称...

    svn1.7-cli.zip

    7. **最佳实践**:使用SVN时,建议定期更新工作副本以获取最新变更,确保团队成员间的代码同步。在提交更改前,应先进行本地的代码审查和测试,以避免错误的提交。合理规划分支策略,例如为长期开发特性创建独立的...

    svn config

    2. **检出**:使用 `svn checkout` 从仓库获取工作副本。 3. **修改**:在本地工作副本中进行文件编辑。 4. **添加**:新文件或目录使用 `svn add` 添加到版本控制。 5. **删除**:使用 `svn delete` 删除不再需要的...

    Git&SVN学习1

    - **获取更新**:`git fetch` 获取远程仓库的最新改动。 - **查看状态**:`git status` 检查本地文件的改动。 - **暂存更改**:`git add` 把改动添加到暂存区。 - **提交更改**:`git commit` 提交暂存区的改动...

    git学习总结电脑资料.doc

    而在SVN中,分支只是版本库中的另一个目录,合并分支需要手动检查svn:mergeinfo属性。 `.git`目录是Git仓库在本地的表示,包含了所有中心仓库的内容,如标签、分支和历史记录。Git的分支管理非常灵活,可以在同一...

Global site tag (gtag.js) - Google Analytics