Upload.php 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. <?php
  2. namespace app\api\controller;
  3. use app\common\controller\Api;
  4. use think\Db;
  5. /**
  6. * oss上传接口
  7. */
  8. class Upload extends Api
  9. {
  10. protected $noNeedLogin = ['gmt_iso8601','signedUrl','callBack'];
  11. protected $noNeedRight = ['*'];
  12. public function gmt_iso8601($time) {
  13. $expiration = date(DATE_ISO8601,$time);
  14. $pos = strpos($expiration, '+');
  15. $expiration = substr($expiration, 0, $pos);
  16. return $expiration."Z";
  17. }
  18. /**
  19. * 获取签名
  20. * @return array
  21. */
  22. public function signedUrl(){
  23. $config = config("oss");
  24. $id= $config["secretId"]; // 请填写您的AccessKeyId。
  25. $key= $config["secretKey"]; // 请填写您的AccessKeySecret。
  26. // $host的格式为 bucketname.endpoint,请替换为您的真实信息。(在阿里云中可配置)
  27. $host = $config["bucket"].".".$config["endPoint"];
  28. // $callbackUrl为上传回调服务器的URL,请将下面的IP和Port配置为您自己的真实URL信息。下面有callBack方法
  29. $callbackUrl = config('website_url').'/api/upload/callBack';
  30. $dir = 'images/'; // 用户上传文件时指定的前缀。
  31. $dir = 'uploads/'.date('Ymd').'/'; // 用户上传文件时指定的前缀。
  32. $callback_param = array('callbackUrl'=>$callbackUrl,
  33. 'callbackBody'=>'filename=${object}&size=${size}&mimeType=${mimeType}&height=${imageInfo.height}&width=${imageInfo.width}',
  34. 'callbackBodyType'=>"application/x-www-form-urlencoded");
  35. $callback_string = json_encode($callback_param);
  36. $base64_callback_body = base64_encode($callback_string);
  37. $now = time();
  38. $expire = 3000; //设置该policy超时时间是10s. 即这个policy过了这个有效时间,将不能访问。
  39. $end = $now + $expire;
  40. $expiration = $this->gmt_iso8601($end);
  41. //最大文件大小.用户可以自己设置
  42. $condition = array(0=>'content-length-range', 1=>0, 2=>1048576000);
  43. $conditions[] = $condition;
  44. // 表示用户上传的数据,必须是以$dir开始,不然上传会失败,这一步不是必须项,只是为了安全起见,防止用户通过policy上传到别人的目录。
  45. $start = array(0=>'starts-with', 1=>'$key', 2=>$dir);
  46. $conditions[] = $start;
  47. $arr = array('expiration'=>$expiration,'conditions'=>$conditions);
  48. $policy = json_encode($arr);
  49. $base64_policy = base64_encode($policy);
  50. $string_to_sign = $base64_policy;
  51. $signature = base64_encode(hash_hmac('sha1', $string_to_sign, $key, true));
  52. $response = [];
  53. $response['accessid'] = $id;
  54. // $response['host'] = $host;
  55. $response['policy'] = $base64_policy;
  56. $response['signature'] = $signature;
  57. // $response['expire'] = $end;
  58. // $response['callback'] = $base64_callback_body;
  59. // $response['dir'] = $dir; // 这个参数是设置用户上传文件时指定的前缀。
  60. $response['bucket'] = $config["url"];
  61. $response['fileurl'] = 'uploads/'.date('Ymd').'/';
  62. $this->success("获取成功!",$response);
  63. }
  64. //回调函数
  65. public function callBack(){
  66. header("Content-Type: application/json");
  67. $data = array("Status"=>"Ok",'data'=>$_POST);
  68. echo json_encode($data);
  69. }
  70. }