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);
}
?>