ajax单按钮无刷新传图并用curl远程传图

JavaScript

 <script>
window.onload = function (){
	$("#btn").click(function(){
		$('#upload').click();  //通过按钮触发input file的click事件
	});
	$('#upload').change(function(){
		uploadPic();
	});
};
		
function uploadPic(){
	var pic = $('#upload')[0].files[0];
	var fd = new FormData();
	fd.append('upfile', pic);
	$.ajax({
		type: 'POST',
		url: 'upcode.php',
		data: fd,
		cache: false,
		contentType: false,
		processData: false,
		success:function(data){
			alert(data);
			return;
		}
	})
}
 </script>

HTML

<button style="height: 36px" id="btn">选择文件</button>
	<input type="file" name="upload" id="upload" style="display: none;" />

upcode.php

$file = $_FILES["upfile"];
$file = $file['tmp_name'];

$src = upload_curl_pic($file);
echo $src;

function upload_curl_pic($file){
	$file = realpath($file); //要上传的文件  
	$fields['upfile'] = '@'.$file; // 前面加@符表示上传图片 
	$ch =curl_init();
	curl_setopt($ch,CURLOPT_URL,'http://upload.xxx.com/upload.php');
	curl_setopt($ch,CURLOPT_POST,true);
	curl_setopt($ch, CURLOPT_POSTFIELDS, $fields);
	curl_setopt($ch,CURLOPT_RETURNTRANSFER,true);
	$content = curl_exec($ch);
	echo $content;
}

upload.php

print_r($_FILES['upfile']);
exit;
此页面接收即可。


注意:php只能解析所在服务器的本机文件地址,所以直接传送文件地址是错误的。需要在第一页的JavaScript的里面传送文件流,然后在第二页使用curl传送临时文件到远程地址,由远程地址接收。因为upcode.php并未保存文件,传送的是临时文件,所以在upload.php中是无法识别文件类型的,所以所有判断需要在upcode里进行判断后再进行传输。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值