`

利用php内置的svn函数实现的根据svn版本号导出相关文件的功能

 
阅读更多
<?php

$revision_array = array(3099, 3339, 2573,3351); /* svn的版本号 */
$svnPeer = new svnPeer();
$filelist = $svnPeer->_get_file_list($revision_array);
if (!empty($filelist))
{
	$lbv_export = $svnPeer->_svn_export_list($filelist, 'trunk889');
	if (true === $lbv_export)
	{
		echo '导出成功';
	}
	else
	{
		echo '导出失败';
	}
}
else
{
	echo '获取文件列表失败';
}


/**
 * php操作svn类,全部利用php内置的svn函数
 *
 * @author wengxianhu
 * @date 2013-08-05
 */
class svnPeer
{
    /* svn用户名 */
    public $svn_user = 'wengxianhu';
    /* svn密码 */
    public $svn_password = 'wxh025';
    /* 来源路径 */
    public $source_path = '/var/www/trunk/';
    /* 目标路径 */
    public $dest_path = '/var/www/';

    /**
     * 构造函数
     *
     * @author wengxianhu
     * @date 2013-08-05
     * @return void
     */
    public function __construct ()
    {
        $this->_svn_connect();
    }
	
    /**
     * 配置SVN使用默认的用户名和密码
     *
     * @author wengxianhu
     * @date 2013-08-05
     * @return void
     */
    public function _svn_connect ()
    {
        svn_auth_set_parameter(SVN_AUTH_PARAM_DEFAULT_USERNAME, $this->svn_user);
        svn_auth_set_parameter(SVN_AUTH_PARAM_DEFAULT_PASSWORD, $this->svn_password);
    }	
	
    /**
     * 根据svn版本号获取所有的文件路径
     *
     * @author wengxianhu
     * @date 2013-08-05
     * @param array $revision_array 版本号列表
     * @return array
     */
	public function _get_file_list ($revision_array = array())
	{
		if (!empty($revision_array))
		{
			$filelist = array();
			$log_list = array();
			rsort($revision_array, SORT_NUMERIC);
			foreach ($revision_array as $_k=>$_v)
			{
				$log_list = @svn_log($this->source_path, $_v, $_v);
				if (false === $log_list)
				{
					return false;
				}
				else
				{
					$log_list = current($log_list);
					foreach ($log_list['paths'] as $s_k=>$s_v)
					{
						$s_v['path'] = preg_replace('/^\/[^\/]+\/(.*)$/i', '$1', $s_v['path']);
						$filetmp = $s_v['path'];
						if (is_file($this->source_path . $s_v['path']))
						{
							if (false === $this->multidimensional_search($filelist, array('filepath'=>$s_v['path'])))
							{
								$filelist[] = array(
									'revision_no'		=> $log_list['rev'],
									'filepath'			=> $s_v['path']
								);
							}
						}
					}
				}
			}
			return $filelist;
		}
	}
	
    /**
     * 对多维数组进行搜索
     *
     * @author wengxianhu
     * @date 2013-08-05
     * @param array $parents 被搜索数组
     * @param array $searched 搜索数组
     * @return boolean
     */
	public function multidimensional_search ($parents = array(), $searched = array()) 
	{ 
		if (empty($searched) || empty($parents)) 
		{ 
			return false; 
		} 

		foreach ($parents as $key => $value) 
		{ 
			$exists = true; 
			foreach ($searched as $skey => $svalue) { 
				$exists = ($exists && IsSet($parents[$key][$skey]) && $parents[$key][$skey] == $svalue); 
			} 
			if ($exists)
			{
				return $key;
			} 
		} 

		return false; 
	} 
	
    /**
     * 根据svn版本号导出相应的文件
     *
     * @author wengxianhu
     * @date 2013-08-05
     * @param array $file_array 文件路径名
     * @param string $package_name 包名
     * @return boolean 成功为true,失败为false
     */
    public function _svn_export_list ($file_array = array(), $package_name = '')
    {
		$info = true;
		$this->dest_path = $this->dest_path . $package_name; 
		if (file_exists($this->dest_path))
		{
			$this->delDirAndFile($this->dest_path);
		}
		foreach ($file_array as $_k=>$_v)
		{
			$source_files = $this->source_path . $_v['filepath'];
			$dest_files = $this->dest_path . '/' . $_v['filepath'];
			$revision_no = (int)$_v['revision_no'];
			$this->_mkdirm(dirname($dest_files));
			$lbv_export = @svn_export($source_files, $dest_files, false, $revision_no);
			if (false === $lbv_export)
			{
				$info = false;
				break;
			}
		}
		return $info;
    }
	
    /**
     * 创建文件夹
     *
     * @author wengxianhu
     * @date 2013-08-05
     * string $path 文件路径(不包括文件名)
     * return void
     */
    public function _mkdirm ($path)
    {
        if (!file_exists($path))
        {
            $this->_mkdirm(dirname($path));
            mkdir($path, 0755);
        }
    }	
	
    /**
     * 循环删除目录和文件函数
     *
     * @author wengxianhu
     * @date 2013-08-15
     * @param string $dirName 目录路径
     * return array
     */
    public function delDirAndFile($dirName)
    {
        if ( $handle = opendir( "$dirName" ) ) 
        {
            while ( false !== ( $item = readdir( $handle ) ) ) 
            {
               if ( $item != "." && $item != ".." ) 
               {
                   if ( is_dir( "$dirName/$item" ) ) 
                   {
                        $this->delDirAndFile( "$dirName/$item" );
                   }
                   else
                   {
                        unlink( "$dirName/$item" );
                   }
               }
           }
           closedir( $handle );
           rmdir( $dirName );
        }
    }	
	
}

分享到:
评论

相关推荐

    PHP封装的svn类使用内置svn函数实现根据svn版本号导出相关文件示例

    标题中提到的“PHP封装的svn类使用内置svn函数实现根据svn版本号导出相关文件示例”,说明了本文将围绕使用PHP语言编写的svn版本控制类库来实现通过特定的svn版本号,导出与之关联的所有文件。标题直接指出该类库...

    sqlite-tools-win32-x86-3240000.zip

    2. **sqlite3.def**:这个文件是SQLite动态链接库(DLL)的定义文件,用于导出SQLite库中的函数,供其他程序调用。在Windows环境中,如果需要将SQLite集成到其他应用程序中,可以使用这个文件来生成相应的DLL。 3. ...

    SQL Server 数据库脚本导出器2.0.rar

    在实际应用中,配合18549这样的文件名,可能表示这是软件的版本号或者序列号,用户在安装或激活软件时可能需要用到。当然,具体含义需要根据实际情况来解读。 总之,SQL Server 数据库脚本导出器2.0是SQL Server...

    PLSQL Developer 8.0.3.1510.zip

    标题中的"PLSQL Developer 8.0.3.1510.zip"表明这是一个版本号为8.0.3.1510的PLSQL Developer安装包,通常以ZIP格式压缩,方便用户下载和安装。 PL/SQL是Oracle数据库系统中的编程语言,结合了SQL(结构化查询语言...

    plsqldev703.1096.rar

    PL/SQL Developer是一款由Allround Automations公司开发的专业Oracle数据库管理与开发工具,版本号7.0.3.1096代表着它在当时的技术成熟度和功能完善度。此软件为数据库管理员和开发人员提供了一个集成环境,方便编写...

    plsql客户端操作文件

    6. **版本控制集成**:如果与版本控制系统(如Git或SVN)集成,PL/SQL Developer可以跟踪和管理数据库对象的版本,便于团队协作和代码管理。 7. **作业调度**:用户可以创建定时任务(也称为作业),安排SQL脚本或...

    vim_dev_V1.1

    Linux下内核开发VIM环境基本配置 一、linux-vim C开发环境主要由下列文件组成: ...3、使用":VCSLog"查看当前文件变动,使用“:VCSDiff 上一个版本号”执行版本变动 4、其它命令见doc/vcscommand.txt

    PLSQL14版本、oracle连接工具

    7. 版本控制集成:与常见的版本控制系统如Git、SVN等无缝对接,管理代码版本。 8. 自动备份和恢复功能:保护你的工作不被意外丢失。 "plsqldev1400x64.msi"是PLSQL Developer 14.0.0的安装程序文件,适用于64位操作...

    PL.SQL.Developer.v8.0.0.1480

    版本号v8.0.0.1480代表着该软件的一个特定更新,可能包含性能优化、新功能或修复了已知问题。 PL/SQL是Oracle数据库系统中的过程化语言,全称为Procedural Language/SQL,它是SQL的扩展,增加了编程元素如流程控制...

    plSqldeveloper工具

    6. **版本控制集成**:可与Git、SVN等版本控制系统集成,实现代码的版本管理和协同开发。 7. **报表和脚本执行**:可以创建自定义的报表,并批量执行SQL脚本,简化日常维护工作。 8. **导入导出功能**:方便地导入...

    plsqldev703.zip

    这个版本可能发布于2000年代中期,因为早期版本的命名方式通常会包含具体的版本号。 在描述中,"plsqldev703.zip"并未提供额外信息,但我们可以根据一般软件压缩包的理解,推测该文件包含了PL/SQL Developer的安装...

    sqldeveloper-19.2.1.247.2212-x64.zip

    - 版本控制集成:与SVN、Git等版本控制系统无缝对接,实现数据库对象的版本控制。 - 多语言支持:提供多种语言界面,满足国际化需求。 总结,SQL Developer 19.2.1.247.2212作为Oracle数据库的强大辅助工具,其丰富...

    PlsqlDeveloper13工具和instantclient_19_5安装文件.zip

    6. **数据导入导出**:提供数据导入导出工具,支持从文件(如CSV、Excel)导入数据到表,或者将表数据导出到文件。 7. **调试器**:PL/SQL Developer的调试功能可以帮助开发者定位和修复代码错误,包括设置断点、...

    PLSQL Developer

    描述中提到的是2017年6月7日的版本,这可能指的是PLSQL Developer的一个特定更新或版本号。通常,软件的更新会包含错误修复、性能提升和新功能的添加。对于 PLSQL Developer 来说,2017年的这个版本可能已经包含了对...

    PLSQL+Developer10

    描述中的"LSQL+Developer10.0.5"可能是版本号的详细表示,暗示这是10.0.5.1710版的一个更新或补丁。 PL/SQL是Oracle数据库的编程语言,结合了SQL(结构化查询语言)的功能和过程式编程语言的特性。它允许开发者创建...

    PLSQL Developer 8.0.3.1510.rar

    8.0.3.1510是该软件的一个具体版本号,通常意味着它包含了一系列的更新和改进,以提升性能和用户体验。 在PLSQL Developer中,你可以进行以下主要的数据库管理活动: 1. **SQL编辑与执行**:软件内置了强大的SQL...

    plsql 客户端

    7. **导入导出功能**:可以将数据库对象或数据导出为文件,或者从文件导入到数据库。 使用PLSQL Developer进行开发时,有以下几点需要注意: - **连接配置**:正确设置Oracle服务器的连接参数,包括服务名、主机名...

    plsqldeveloperxx

    "plsqldev1105_x64.exe" 很可能是 PL/SQL Developer 的一个特定版本号(11.0.5),这表明它是64位版本的安装程序。 【标签】"plsqld" 是 PL/SQL Developer 的简写,用来标识该文件或话题与 PL/SQL 开发工具有关。 ...

    sqldeveloper-19.2.1.247.2212-no-jre.zip

    "sqldeveloper-19.2.1.247.2212-no-jre.zip" 文件是 SQL Developer 的一个特定版本,该版本号表示它是在 2019 年发布,版本号为 19.2.1,构建号为 247,补丁号为 2212,且"no-jre"意味着这个压缩包不包含Java运行...

Global site tag (gtag.js) - Google Analytics