php 上传本地文件到服务器,并触发OA系统中的流程

a.php  上传本地文件到服务器

<?php
    //php使用curl模拟form表单提交数据
    /*
    *    $post_data  提交的数据数组
    *      //要上传的本地文件地址"@F:/xampp/php/php.ini"上传时候,上传路径前面要有@符号
    *        eg.  $furl = "@H:/htdocs/ssd.jpg";
               $furl1 = "@H:/htdocs/jiyiji.php";
               $post_data = array (
                   "name"=>'cqs',
                   "upload" => $furl,
                   "upload2"=>$furl1
               );
    *      
    *    $sumbit_url  提交的url地址
    *      //CURLOPT_URL 是指提交到哪里?相当于表单里的“action”指定的路径
             eg.$sumbit_url = "http://127.0.0.1/b.php";
    *      
    *    $http_url  访问来源地址
    *     //伪造网页来源地址,伪造来自百度的表单提交
    *      eg.$http_url="http://www.baidu.com";
    * 
    */
    
    
    function curl_form($post_data,$sumbit_url,$http_url){
        
        //初始化
        $ch = curl_init();
        //设置变量
        curl_setopt($ch, CURLOPT_URL, $sumbit_url);
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, 0);//执行结果是否被返回,0是返回,1是不返回
        curl_setopt($ch, CURLOPT_HEADER, 0);//参数设置,是否显示头部信息,1为显示,0为不显示
        curl_setopt($ch, CURLOPT_REFERER, $http_url); 
        //表单数据,是正规的表单设置值为非0
        curl_setopt($ch, CURLOPT_POST, 1);
        curl_setopt($ch, CURLOPT_TIMEOUT, 100);//设置curl执行超时时间最大是多少
        //使用数组提供post数据时,CURL组件大概是为了兼容@filename这种上传文件的写法,
        //默认把content_type设为了multipart/form-data。虽然对于大多数web服务器并
        //没有影响,但是还是有少部分服务器不兼容。本文得出的结论是,在没有需要上传文件的
        //情况下,尽量对post提交的数据进行http_build_query,然后发送出去,能实现更好的兼容性,更小的请求数据包。
        curl_setopt($ch, CURLOPT_POSTFIELDS, $post_data);
        //执行并获取结果
        $output = curl_exec($ch);
        if($outopt === FALSE)
        {
            echo "<br/>","cUrl Error:".curl_error($ch);
        }
        //    释放cURL句柄
        curl_close($ch); 
		
		//echo $output;
		print_r($output);
    }
    
    
    $furl = "@d:\MYOA\副本.doc";
               $furl1 = "@H:/htdocs/jiyiji.php";
               $post_data = array (
                   "name"=>'测试副本',
                   "file" => $furl
               );
    $sumbit_url = "http://127.0.0.1/general/dianbao/b.php"; 
    $http_url="http://www.baidu.com";
    curl_form($post_data,$sumbit_url,$http_url);
?>

b.php  用来接收文件和处理文件的

 

<?php

include_once("inc/conn.php");
include_once("inc/utility_file.php");
include_once("inc/check_type.php");
include_once("inc/utility_sms1.php");  
include_once("inc/utility_sms2.php");  
include_once("inc/utility_all.php");  
include_once("inc/utility_org.php");  
include_once("inc/utility_flow.php");  
include_once("inc/workflow/inc/workflow.inc.php");  
$HTML_PAGE_TITLE = _("新建流程");
include_once("inc/header.inc.php");


    echo "<pre>";
    var_dump($_REQUEST);
    var_dump($_FILES); 
	
$name=$_REQUEST["name"]."文件";
/*
$ATTACHMENT_ID.=copy_sel_attach($ATTACH_NAME,$ATTACH_DIR,$DISK_ID);
$ATTACHMENT_NAME.=$ATTACH_NAME;

echo $ATTACHMENT_ID."<br>";
echo  $ATTACHMENT_NAME."<br>";


 $START_TIME = date("Y-m-d H:i:s");  
  $user="admin";
  $dianbaodengji="1111";
		$fasongshiian= $START_TIME;
		$dianbaohao="44444";
		$fabaoren="5555";
   // $run_id= new_flow(143,$user,$user,0,0,0,1,$START_TIME);//1  是事务提醒  相同是主办人  不相同是经办人   
	 $run_id= new_flow(143,$user,$user,0,0,0,0,$START_TIME);//1 
	$query1="UPDATE `TD_OA`.`flow_data_143` SET `run_name`='$biaoti', `data_13`='$dianbaodengji', `data_11`='$fasongshiian', `data_14`='$dianbaohao', `data_15`='$fabaoren', `data_17`='$biaoti', `data_2`=' $ATTACHMENT_NAME', `data_2_key`='$ATTACHMENT_ID' WHERE (`run_id`='$run_id')";
	exequery(TD::conn(),$query1);
    echo "流水号:".$run_id."<br>";  
	$query2="update flow_run set run_name='$biaoti' where run_id='$run_id'";
	exequery(TD::conn(),$query2);
	)*/
	 if($YM=="")
    $YM=date('ym');
 	
 $PATH="E:/MYOA/attach/workflow";
   if(!file_exists($PATH) || !is_dir($PATH))
       mkdir($PATH, 0700);
   $PATH=$PATH."/".$YM;
   if(!file_exists($PATH) || !is_dir($PATH))
       mkdir($PATH, 0700);  
	   
	   $attachemnt_id="";
	 $attachment_name="";
	 
	
    $START_TIME = date("Y-m-d H:i:s");
    $run_id= new_flow(143,"admin","admin",0,0,0,1,$START_TIME);//1  是事务提醒  相同是主办人  不相同是经办人 
    echo "流水号:".$run_id."<br>";
	
	
    foreach($_FILES as $k=>$v)
    {    
        $filename=$v['name'];//文件名
		echo $file_name;
		$myfile = fopen("newfile.txt", "w") or die("Unable to open file!");

fwrite($myfile, $file_name);

fclose($myfile);
		
        $extname=substr($filename,strrpos($filename,'.')+1);//获取后缀名
        //设置上传路径
        $savePath='D:/MYOA/webroot/general/'.date("Ymd",time()).'/';
        if(!file_exists($savePath)) mkdir($savePath); 
        //以时间来命名上传的文件
       // $file_name = md5(strval(rand()).time()) . "." . $extname; 
	   $file_name = $name.".".$extname; 
        $newfilename=$savePath . $file_name;//新文件地址名称
        //是否上传成功
        if (! copy ( $v[tmp_name], $newfilename ) ) 
        {
            echo '上传失败';
            exit;
        }
		
		
		$ATTACH_ID=mt_rand();
	$ATTACH_NAME=  $file_name ;
	$file1= $newfilename;
	$PATH1=$PATH."/".$ATTACH_ID.".".$ATTACH_NAME;
	echo @copy($file1,$PATH1)?'成功':'失败';
	//echo @rename($file1,$PATH1)?'成功':'失败';//2677@1505_1668115426
	//unlink($del_name)?'成功':'失败';
	  
  
  
	
	   
	   $query="INSERT INTO `TD_OA`.`attachment` (`POSITION`, `MODULE`, `YM`, `ATTACH_ID`, `ATTACH_FILE`, `ATTACH_NAME`, `ATTACH_SIGN`, `DEL_FLAG`) VALUES ('2', '2', '$YM', '$ATTACH_ID', '$ATTACH_NAME', '$ATTACH_NAME', '0', '0')";
	   $cursor=exequery(TD::conn(),$query);
	   $AID=mysql_insert_id();
	   echo $AID."<br>";
	   $ATTACHMENT_ID=$AID."@".$YM."_".$ATTACH_ID;
	   echo $ATTACHMENT_ID."<br>";
	   
	   
	   //插入公共附件  单个的
	   
	   $query2="INSERT INTO `TD_OA`.`flow_run_attach` ( `RUN_ID`, `ATTACHMENT_ID`, `ATTACHMENT_NAME`, `FLOW_PRCS`, `UPLOAD_USER`, `UPLOAD_TIME`) VALUES ( '$run_id', '$ATTACHMENT_ID', '$ATTACH_NAME', '1', 'admin', '$CUR_DATE')";
	   exequery(TD::conn(),$query2);
	   
	   //更新flow_run  多个附件连在一起的
	   $attachemnt_id.=$ATTACHMENT_ID.",";
	   $attachment_name.=$ATTACH_NAME."*";
	   }  //end foreach
	   
	   if($attachemnt_id!=""){
	   $query3="update flow_run set ATTACHMENT_ID='$attachemnt_id',ATTACHMENT_NAME='$attachment_name' where run_id='$run_id'";
	   exequery(TD::conn(),$query3);
	   }

        
?>

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

hai7425

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值