PHP上传文件到阿里云OSS,nginx代理访问

1. 阿里云OSS创建存储空间Bucket(读写权限为:公共读)

2. 拿到相关配置

accessKeyId:*********
accessKeySecret:*********
endpoint:********
bucket:********

3.创建 oss.php 上传类 (基于thinkPHP5)

复制代码
<?php
namespace app\controller;
use OSS\OssClient;
class Oss {
    private static $_instance;

    private function __construct() {
    }

    private function __clone() {
    }
    /**
     * 获取一个OssClient实例
     * @return null|OssClient
     */
    public static function getInstance() {
        if (!(self::$_instance instanceof OssClient)) {
            try {
                self::$_instance = new OssClient(env('oss.access_key_id'), env('oss.access_key_secret'), env('oss.endpoint'), false);
            } catch (OssException $e) {
                printf(__FUNCTION__ . "creating OssClient instance: FAILED\n");
                printf($e->getMessage() . "\n");
                return null;
            }
        }
        return self::$_instance;
    }
    /**
     * 获取bucket
     * @return string
     */
    public static function getBucketName()
    {
        return env('oss.bucket');
    }
}
复制代码

3.上传调用

复制代码
   use app\controller\Oss;
  .
  .
  .
  
  public function addShopImg(){ $this->checkParams('shop_id'); $file = $this->request->file('image'); if ($file && ($file->getError() == '') && $file->checkImg() && $file->checkSize(5*1024*1024)) { $info = $file->move(APP_PATH . '../public/upload/shops/'); //上传图片至阿里云oss $fileName = 'biz_oss/upload/shops/' . $info->getFilename(); $ossClient = Oss::getInstance(); $bucket = Oss::getBucketName(); $ossClient->uploadFile($bucket, $fileName, $info->getPathname()); $data['shop_img'] = '/upload/shops/'.$info->getFilename(); $data['shop_id'] = $this->params['shop_id']; $re = db('shopImg')->insert($data); if($re){ Api::output(); }else{ Api::fail(2, '上传失败'); } } else { Api::fail(1, '图片不合规'); } }
复制代码

 

4.访问 oss域名地址 不可在浏览器直接访问  可用nginx 代理

配置中加入:

location ^~ /biz_oss {
  proxy_pass http://xxxxxx.oss-cn-shenzhen-internal.aliyuncs.com;
}

重启nginx 

nginx配置的域名(server_name)后接上 /biz_oss  如:kwdst.3ce.com/biz_oss  即可指向oss上资源存储的空间

如下  $oss_url = kwdst.3ce.com/biz_oss

<div style="text-align:center; width:100%; height:100%;">
    <img src="{$oss_url}{$img.shop_img}" style="vertical-align:middle;"  />
</div>

 如此浏览器中html 即可访问加载 oss上图片资源。

 

posted @   $wanggang  阅读(1756)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!
点击右上角即可分享
微信分享提示