一. oss如果是商品图片等公共文件,要设置成公共读,其他情况设置成私有
二.
python flask框架上传文件到oss
class UploadAtt(Resource): @jwt_required def post(self): file = request.files.get('file', None) parmat = request.form.get('param', None) if not file or file.filename == '': return func.resp(status=400, mess='文件不存在') filename = secure_filename(file.filename) if not func.allowed_file(filename): return func.resp(status=400, mess='文件格式不允许') # file.save(os.path.join(current_app.config['UPLOAD_FOLDER'], filename)) filename = func.gen_upload_filename(filename, parmat) if not filename: return func.resp(status=400, mess='参数错误') oss = FlaskOSS(current_app) oss.put_file(filename, file.read()) ret = {'filepath': func.get_oss_url_by_file(filename), 'filename': filename} return func.resp(ret, status=200, mess='File successfully uploaded')
python flask框架,授权预览或下载私有文件, 图片文件使用自定义域名可以预览,其他文件默认下载
def get_oss_url_by_file(filename, expire=600): if not filename: return None if filename[0:1] == '/': filename = filename[1:] # 阿里云主账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM账号进行API访问或日常运维,请登录 https://ram.console.aliyun.com 创建RAM账号。 auth = oss2.Auth(current_app.config['OSS_ACCESS_KEY_ID'], current_app.config['OSS_SECRET_ACCESS_KEY']) # Endpoint以杭州为例,其它Region请按实际情况填写。 bucket = oss2.Bucket(auth, current_app.config['OSS_ENDPOINT_CNAME'], current_app.config['OSS_BUCKET_NAME'], True) # 设置此签名URL在60秒内有效。 return bucket.sign_url('GET', filename, expire)
python flask框架下载文件到本地, 本地目录我使用的当前文件夹下/download,要新建这个文件夹
# 下载文件 class OrderAtt(Resource): def get(self): filename = request.args.get('filepath', None) filetitle = request.args.get('filetitle', None) if not all([filename, filetitle]): return func.resp(status=400, mess="参数不能为空") if filename[0:1] == '/': filename = filename[1:] # 阿里云主账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM账号进行API访问或日常运维,请登录 https://ram.console.aliyun.com 创建RAM账号。 auth = oss2.Auth(current_app.config['OSS_ACCESS_KEY_ID'], current_app.config['OSS_SECRET_ACCESS_KEY']) # Endpoint以杭州为例,其它Region请按实际情况填写。 bucket = oss2.Bucket(auth, current_app.config['OSS_ENDPOINT_CNAME'], current_app.config['OSS_BUCKET_NAME'], True) # 下载OSS文件到本地文件。如果指定的本地文件存在会覆盖,不存在则新建。 # <yourLocalFile>由本地文件路径加文件名包括后缀组成,例如/users/local/myfile.txt。 # <yourObjectName>表示下载的OSS文件的完整名称,即包含文件后缀在内的完整路径,例如abc/efg/123.jpg。 directory = os.getcwd()+'/download/' # 假设在当前目录 localfile = directory + filetitle bucket.get_object_to_file(filename, localfile) return func.resp()
python flask框架删除文件
@jwt_required def delete(self): filename = request.args.get('filename', None) if not filename: return func.resp(status=400, mess='参数错误') oss = FlaskOSS(current_app) oss.del_file(filename) return func.resp()
三. php thinkphp上传 预览,
function getossurl($object){ if(!$object){ return null; } Vendor('aliyun-oss.autoload'); if(substr($object,0,1)=='/'){ $object = substr($object,1); } // 阿里云主账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM账号进行API访问或日常运维,请登录RAM控制台创建RAM账号。 $accessKeyId = C("OSS_ACCESS_KEY_ID"); $accessKeySecret = C("OSS_SECRET_ACCESS_KEY"); // Endpoint以杭州为例,其它Region请按实际情况填写。 $endpoint = C("OSS_ENDPOINT_CNAME"); $bucket= C("OSS_BUCKET_NAME"); // 设置URL的有效时长为3600s。 $timeout = 3600; try { $ossClient = new OSSOssClient($accessKeyId, $accessKeySecret, $endpoint, True); // 生成GetObject的签名URL。 $signedUrl = $ossClient->signUrl($bucket, $object, $timeout); } catch (OSSCoreOssException $e) { // printf(__FUNCTION__ . ": FAILED "); // printf($e->getMessage() . " "); return null; } return $signedUrl; } function upload2oss($filePath,$object){ if(!$filePath){ return false; } Vendor('aliyun-oss.autoload'); if(substr($object,0,1)=='/'){ $object = substr($object,1); } // 阿里云主账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM账号进行API访问或日常运维,请登录RAM控制台创建RAM账号。 $accessKeyId = C("OSS_ACCESS_KEY_ID"); $accessKeySecret = C("OSS_SECRET_ACCESS_KEY"); // Endpoint以杭州为例,其它Region请按实际情况填写。 $endpoint = C("OSS_ENDPOINT"); $bucket= C("OSS_BUCKET_NAME"); try{ $ossClient = new OSSOssClient($accessKeyId, $accessKeySecret, $endpoint); $ossClient->uploadFile($bucket, $object, $filePath); } catch(OSSCoreOssException $e) { // printf(__FUNCTION__ . ": FAILED "); // printf($e->getMessage() . " "); return false; } // print(__FUNCTION__ . ": OK" . " "); return true; }
问题:oss优化,app和pc都是ajax直接上传到oss,如果上传文件后返回或删除文件或没有提交,对应的文件也应该删除.
处理方式, 1先上传到oss tmp文件夹,并定时清理, 如果post请求成功,再拷贝到对应文件夹,这样就节省服务器资源和oss费用 或者 先上传到服务器的 tmp文件夹,并定时清理, 如果post请求成功,再上传到oss中
2.tmp文件定时清理时间大于保持登录的时间.refreshtoken或cookie或session到期时间. 这样用户添加后,到期必须重新登录,就不用判断文件是否存在.
cookie不设置到期时间或设置0,都是浏览器关闭就销毁
cookie设置到期时间,默认保存在内存中或硬盘中,也可以保存到数据库,到期时间之前关闭浏览器不会销毁,重新打开还是已经登录状态.
session基于cookie,浏览器关闭sessionid就销毁了,所以找不到对应的session了.