> 백엔드 개발 > PHP 튜토리얼 > 컬 업로드 파일 버전 차이 문제 분석

컬 업로드 파일 버전 차이 문제 분석

小云云
풀어 주다: 2023-03-20 18:16:01
원래의
1563명이 탐색했습니다.

=프론트엔드 게시물 양식이 파일을 업로드한 후 백엔드는 파일을 수신한 후 게시물을 이미지 서버로 전달합니다. 그래서 컬을 이용해서 업로드를 했고, '@파일경로'를 이용해서 업로드했습니다

코드는 다음과 같습니다

<?php
    if($_FILES[&#39;video&#39;][&#39;size&#39;]>0){        $data = array('video'=>$_FILES['video']['tmp_name']);         $ch = curl_init();         $url="test.php";
        // 设置URL和相应的选项
        curl_setopt($ch, CURLOPT_URL, $url);
        //启用时会将头文件的信息作为数据流输出。 
        curl_setopt($ch, CURLOPT_HEADER, 0);
        //将curl_exec()获取的信息以字符串返回,而不是直接输出
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
        curl_setopt($ch, CURLOPT_POST, 1);
        curl_setopt($ch, CURLOPT_POSTFIELDS, $data);         $res = curl_exec($ch);
        // 抓取URL并把它传递给浏览器
        curl_exec($ch);
        // 关闭cURL资源,并且释放系统资源
        curl_close($ch);

   }
로그인 후 복사
로그인 후 복사

테스트기의 PHP 버전은 5.2 인데, 코드가 깨지는 데는 문제가 없지만, 온라인에 올리면 됩니다. , $_FILES 변수는 값을 받을 수 없습니다. 그러면 $_POST['video']='@/tmp/phps12d63'; 을 받았습니다. 첫 번째 반응은 Content-Type이 정상적으로 전송되지 않는다는 것입니다. 업로드된 파일은 'multipart/form-data'여야 하며, 이 경우 'application/x-www-form-urlencoded'여야 합니다. 그런 다음 이미지 서버에서 $_SERVER['HTTP_CONTENT_TYPE'] 변수를 인쇄하고 'multipart/form-data'인지 확인합니다.
매뉴얼을 확인하여 CURLOPT_POSTFIELDS의 전달된 매개변수가 배열인 경우 Content-Type 헤더가 multipart/form-data로 설정된다는 것을 확인했습니다.
그런 다음 php5.5.0에 추가된 마법의 CURLOPT_SAFE_UPLOAD 매개변수가 있습니다. 기본값은 false이고 5.6.0의 기본값은 true입니다.

CURLOPT_SAFE_UPLOAD
TRUE는 CURLOPT_POSTFIELDS에 @ 접두사가 있는 파일 전송을 비활성화합니다. 이는 @를 필드에서 안전하게 사용할 수 있음을 의미합니다. 가능
업로드를 대체하는 CURLFile입니다.

그리고 CURLOPT_POSTFIELDS 매개변수 설명

CURLOPT_POSTFIELDS
모든 데이터는 HTTP 프로토콜의 "POST" 작업을 사용하여 전송됩니다. 파일을 보내려면 파일 이름 앞에 @를 붙이고 전체 경로를 사용하세요. 파일 형식은 파일 이름 뒤에 ';type=mimetype' 형식으로 지정할 수 있습니다. 이 매개변수는 'para1=val1¶2=val2&...'와 유사한 urlencoded 문자열일 수도 있고 필드 이름을 키로, 필드 데이터를 값으로 사용하는 배열을 사용할 수도 있습니다. 값이 배열이면 Content-Type 헤더가 multipart/form-data로 설정됩니다. PHP 5.2.0부터 @ 접두사를 사용하여 파일을 전달할 때 값은 배열이어야 합니다. PHP 5.5.0부터 @ 접두사는 더 이상 사용되지 않으며 CURLFile을 통해 파일을 보낼 수 있습니다. 보안 강화를 위해 @ 접두사가 포함된 파일 전송을 비활성화하려면 CURLOPT_SAFE_UPLOAD를 TRUE로 설정합니다.

버전을 확인해 보니 테스트 환경은 php5.3, 온라인 테스트 환경은 5.6인데, 이는 CURLOPT_SAFE_UPLOAD가 기본값이 true이고 @업로드가 비활성화되어 있으며 @는 일반 문자열이라는 뜻입니다. 5.5부터 파일 업로드 시 @ 접두사가 삭제되었습니다. 5.5보다 큰 버전은 CURLFile을 사용하여 업로드해야 합니다. 최종 호환 솔루션은 5.5보다 작은 경우 @ 접두사를 사용하고 5.5보다 큰 경우 CURLFile을 사용합니다. 5.5 미만의 버전에서는 @를 사용하여 업로드하고 추가 매개변수를 추가할 수 있습니다. filename = file name = mime type;

<?php
//curl_file_create是函数的别名CURLFile::__construct() if (!function_exists('curl_file_create')) {
    function curl_file_create($filename, $mimetype = '', $postname = '') {
        return "@$filename;filename="
            . ($postname ?: basename($filename))
            . ($mimetype ? ";type=$mimetype" : '');
    }
}
로그인 후 복사
로그인 후 복사

마지막 코드는

<?php
    if($_FILES[&#39;video&#39;][&#39;size&#39;]>0){        $data = array('video'=>$_FILES['video']['tmp_name']);         $ch = curl_init();         $url="test.php";
        // 设置URL和相应的选项
        curl_setopt($ch, CURLOPT_URL, $url);
        //启用时会将头文件的信息作为数据流输出。 
        curl_setopt($ch, CURLOPT_HEADER, 0);
        //将curl_exec()获取的信息以字符串返回,而不是直接输出
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
        curl_setopt($ch, CURLOPT_POST, 1);        $data['video']=curl_file_create($_FILES['video']['tmp_name'],'video/mp4',$_FILES['video']['name']);
        curl_setopt($ch, CURLOPT_POSTFIELDS, $data);         $res = curl_exec($ch);
        // 抓取URL并把它传递给浏览器
        curl_exec($ch);
        // 关闭cURL资源,并且释放系统资源
        curl_close($ch);

   }
로그인 후 복사
로그인 후 복사

입니다. 요약하자면, 문제가 발생하면 먼저 침착하게 분석한 후 매뉴얼을 주의 깊게 읽어보세요.

금요일에 프런트 엔드 게시물 양식이 파일을 업로드한 후 백엔드에서 파일을 받은 후 게시물을 이미지 서버로 전달하는 데 문제가 발생했습니다. 그래서 컬을 이용해서 업로드를 했고, '@file path'를 이용해 업로드를 했습니다
코드는 다음과 같습니다

<?php
    if($_FILES[&#39;video&#39;][&#39;size&#39;]>0){        $data = array('video'=>$_FILES['video']['tmp_name']);         $ch = curl_init();         $url="test.php";
        // 设置URL和相应的选项
        curl_setopt($ch, CURLOPT_URL, $url);
        //启用时会将头文件的信息作为数据流输出。 
        curl_setopt($ch, CURLOPT_HEADER, 0);
        //将curl_exec()获取的信息以字符串返回,而不是直接输出
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
        curl_setopt($ch, CURLOPT_POST, 1);
        curl_setopt($ch, CURLOPT_POSTFIELDS, $data);         $res = curl_exec($ch);
        // 抓取URL并把它传递给浏览器
        curl_exec($ch);
        // 关闭cURL资源,并且释放系统资源
        curl_close($ch);

   }
로그인 후 복사
로그인 후 복사

테스트 머신의 PHP 버전은 5.2 인데, 코드가 깨지는 데에는 문제가 없지만, 온라인에 올려놓으면 $_FILES 변수는 값을 받을 수 없습니다. 그런 다음 $_POST['video']='@/tmp/phps12d63'; 을 받았습니다. 첫 번째 반응은 Content-Type이 정상적으로 전송되지 않는다는 것입니다. 업로드된 파일은 'multipart/form-data'여야 하며, 이 경우 'application/x-www-form-urlencoded'여야 합니다. 그런 다음 이미지 서버에서 $_SERVER['HTTP_CONTENT_TYPE'] 변수를 인쇄하고 'multipart/form-data'인지 확인합니다.
매뉴얼을 확인하여 CURLOPT_POSTFIELDS의 전달된 매개변수가 배열인 경우 Content-Type 헤더가 multipart/form-data로 설정된다는 것을 확인했습니다.
그런 다음 php5.5.0에 추가된 마법의 CURLOPT_SAFE_UPLOAD 매개변수가 있습니다. 기본값은 false이고 5.6.0의 기본값은 true입니다.

CURLOPT_SAFE_UPLOAD
TRUE는 CURLOPT_POSTFIELDS에 @ 접두사가 있는 파일 전송을 비활성화합니다. 이는 @를 필드에서 안전하게 사용할 수 있음을 의미합니다. 가능
업로드를 대체하는 CURLFile입니다.

그리고 CURLOPT_POSTFIELDS 매개변수 설명

CURLOPT_POSTFIELDS
모든 데이터는 HTTP 프로토콜의 "POST" 작업을 사용하여 전송됩니다. 파일을 보내려면 파일 이름 앞에 @를 붙이고 전체 경로를 사용하세요. 파일 형식은 파일 이름 뒤에 ';type=mimetype' 형식으로 지정할 수 있습니다. 이 매개변수는 'para1=val1¶2=val2&...'와 유사한 urlencoded 문자열일 수도 있고 필드 이름을 키로, 필드 데이터를 값으로 사용하는 배열을 사용할 수도 있습니다. 값이 배열이면 Content-Type 헤더가 multipart/form-data로 설정됩니다. PHP 5.2.0부터 @ 접두사를 사용하여 파일을 전달할 때 값은 배열이어야 합니다. PHP 5.5.0부터 @ 접두사는 더 이상 사용되지 않으며 CURLFile을 통해 파일을 보낼 수 있습니다. 보안 강화를 위해 @ 접두사가 포함된 파일 전송을 비활성화하려면 CURLOPT_SAFE_UPLOAD를 TRUE로 설정합니다.

查看版本,果然测试环境是php5.3,而线上测试环境是5.6,也是就是说CURLOPT_SAFE_UPLOAD默认为true,禁用了@ 上传,@就是普通字符串了。而从5.5开始@前缀上传文件已经被废弃。大于5.5版本需使用CURLFile 上传。最后兼容方案小于5.5使用@前缀,大于5.5使用CURLFile,在小于5.5的版本是用@上传还可以添加额外的参数;filename=文件名;type=mime类型

<?php
//curl_file_create是函数的别名CURLFile::__construct() if (!function_exists('curl_file_create')) {
    function curl_file_create($filename, $mimetype = '', $postname = '') {
        return "@$filename;filename="
            . ($postname ?: basename($filename))
            . ($mimetype ? ";type=$mimetype" : '');
    }
}
로그인 후 복사
로그인 후 복사

最后代码为

<?php
    if($_FILES[&#39;video&#39;][&#39;size&#39;]>0){        $data = array('video'=>$_FILES['video']['tmp_name']);         $ch = curl_init();         $url="test.php";
        // 设置URL和相应的选项
        curl_setopt($ch, CURLOPT_URL, $url);
        //启用时会将头文件的信息作为数据流输出。 
        curl_setopt($ch, CURLOPT_HEADER, 0);
        //将curl_exec()获取的信息以字符串返回,而不是直接输出
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
        curl_setopt($ch, CURLOPT_POST, 1);        $data['video']=curl_file_create($_FILES['video']['tmp_name'],'video/mp4',$_FILES['video']['name']);
        curl_setopt($ch, CURLOPT_POSTFIELDS, $data);         $res = curl_exec($ch);
        // 抓取URL并把它传递给浏览器
        curl_exec($ch);
        // 关闭cURL资源,并且释放系统资源
        curl_close($ch);

   }
로그인 후 복사
로그인 후 복사

相关推荐:

php通过CURL上传文件

php curl上传文件的简单例子

post - php curl上传文件如何像表单一样指定其name值

위 내용은 컬 업로드 파일 버전 차이 문제 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿