python 图片上传接口开发 并生成可以访问的图片url

版本:python3.7

功能,开发一个用户访问的页面,支持图片上传,并将其保存在服务器。

 

项目结构:

 

app.py文件内容如下:

from flask import Flask, Response, request, render_template
from werkzeug.utils import secure_filename
import os

app = Flask(__name__)


# 设置图片保存文件夹
UPLOAD_FOLDER = 'photo'
app.config['UPLOAD_FOLDER'] = UPLOAD_FOLDER

# 设置允许上传的文件格式
ALLOW_EXTENSIONS = ['png', 'jpg', 'jpeg']


# 判断文件后缀是否在列表中
def allowed_file(filename):
    return '.' in filename and filename.rsplit('.', 1)[-1] in ALLOW_EXTENSIONS


# 上传图片
@app.route("/photo/upload", methods=['POST', "GET"])
def uploads():
    if request.method == 'POST':
        # 获取post过来的文件名称,从name=file参数中获取
        file = request.files['file']
        if file and allowed_file(file.filename):
            print(file.filename)
            # secure_filename方法会去掉文件名中的中文
            file_name = secure_filename(file.filename)
            # 保存图片
            file.save(os.path.join(app.config['UPLOAD_FOLDER'], file_name))
            return "success"
        else:
            return "格式错误,请上传jpg格式文件"
    return render_template('index.html')


# 查看图片
@app.route("/photo/<imageId>.jpg")
def get_frame(imageId):
    # 图片上传保存的路径
    with open(r'C:/Users/Administration/Desktop/photo_ceshi/photo/{}.jpg'.format(imageId), 'rb') as f:
        image = f.read()
        resp = Response(image, mimetype="image/jpg")
        return resp


if __name__ == "__main__":
    app.run(host='0.0.0.0', port=5000, debug=True)

 

index.html内容如下:

<!DOCTYPE html>
<html lang="zh-cmn-Hans">
<head>
    <meta charset="UTF-8">
    <title>Upload</title>
</head>
<h1>请上传图片文件</h1>
<form action="" method=post enctype=multipart/form-data>
<p><input type=file name=file>
<input type=submit value=Upload>
</form>

 

启动app.py文件后,我们先访问 http://127.0.0.1:8002/photo/upload

1、页面如下:

2、我们先上传一张 1001.jpg,提交后界面如下:

 

3、然后我们尝试通过图片url来访问这张图片:

搞定收工!

  • 7
    点赞
  • 40
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
通用接口实现类LinkJOS 扩展于:public class LinkJOS extends LinkOAuth2(LinkOAuth2 extends JspEasy) 构造函数 LinkJOS(HttpServletRequest request,HttpServletResponse response) 京东JOS接口访问函数 public String link2(String link,String method,Bag sys,Bag apps,String appSecret,String file,String FileField) 作用:访问京东JOS平台的所有接口 参数: String link,京东JOS平台接口访问地址,目前固定为:https://api.jd.com/routerjson String method,向京东JOS平台提交数据时的方法,需要应用级别参数时建议用POST方法,不需要时用GET(参见后边的实例) Bag sys,系统级别参数书包(一般只需在接口参数文件中放入接口方法即可,参见后边的实例) Bag apps,应用级别参数书包(在接口参数文件中放入必须的应用级别参数,若不需要应用级别参数时直接用new Bag(-1)构造一个空书包即可,参见后边的实例) String appSecret,应用证书中的App Secret,前边已经设置,固定用"@{pPage:app_secret}"即可 String file,调用上传文件接口上传文件(如图片)到京东JOS平台时的文件全名(含相对路径,如:images/logo.png),不是调用上传文件接口时为空字符串即可(参见后边的实例) String FileField,调用上传文件接口上传文件(如图片)到京东JOS平台时的字段名,配合前边的参数,不是调用上传文件接口时为空字符串即可(参见后边的实例) 返回为京东JOS平台接口对应的JSON格式的字符串 JSON文本解析方法 public void parseJson(String json) 作用:解析京东JOS平台接口返回的JSON格式的字符串,并根据内容生成N个对应的书包 参数:String json,京东JOS平台接口返回的JSON格式的字符串 根据JSON文本的内容在系统中生成N个书包,根书包名称为j0,下一层的josn文本内容生成的书包名称用上一层的Key放在上一层的书名中,下边用实例说明寻找对应书包的方法: 如店铺信息查询接口jingdong.vender.shop.query返回的json文本为 { "jingdong_vender_shop_query_responce": { "shop_jos_result": { "open_time": "", "shop_id": "", "category_main_name": "", "category_main": "", "vender_id": "", "brief": "", "logo_url": "", "shop_name": "" } } } 找出店铺信息书包名的方法如下 @{j0:jingdong_vender_shop_query_responce} @{@{pPage:bag}:shop_jos_result} 这时候的@{pPage:bag}即为需要的店铺信息书包名 具体用法请阅读下载包中的《京东卖家如何快速开发网店工具软件》
### 更新说明: - 本次版本更新,在原有框架基础上进行了优化: - 支持多sheet编写测试用例,一个sheet编写一个业务流程 - 根据sheet名称,自动生成测试用例集合 - 优化之前响应参数错误,jsonpath取值失败的问题,抛出keyError,优化提示 - sheet之间关联数据保持隔离性,每个sheet拥有唯一id识别 - 后续继续开发: 1.setupSheet的设计,在所有sheet执行前执行,主要用于获取token,解决登入问题 2.尝试多sheet并发执行 ## 项目说明 - 本框架是为了快速实现**http/https**协议而设计的一套数据驱动自动化接口框架,基于**EXCEL+requests+unittest+ddt**设计,**pytest**作为执行器,本框架无需你使用代码编写用例,那你可能 会担心万一有接口之间相互依赖,或者说需要登入的token等之类的接口,该如何编写用例,在这里告诉你们笨框架已经完美解决此问题,所有的一切将在EXCEL中进行!!本框架实现了在EXCEL中 进行**接口用例编写,接口关联,接口断言**,还有很重要的一点,实现了类似**jmeter函数助手**的功能,譬如生成UUID,随机定长字符串,格式化日期,正则表达式等,只需要你在EXCCEL中使用特殊的写法就能够使用这些函数啦~~是不是很期待!! ## 技术栈 - requests - unittest - pytest - pytest-html - xlrd - logging - 函数助手 ## 环境部署 - 解压压缩包,使用pycharm打开项目文件 - 进入**File - Settings - Project - Project Interpreter**,选择项目中的 **ApiTestFrameWork/venv** 作为虚拟环境,若无法使用,可以尝试新增虚拟环境后,在控制台cd到**venv/Scripts**下,使用命令**pip install -r requirements.txt**文件所在的绝对路径(在项目根目录),一条命令安装好所有依赖环境,你要做的就是慢慢等它装好 - 验证环境是否安装完毕 - **File - Settings - Tools - Python Integrated Tools - Default Test Runner**选择**py.test** - 执行**runCase.py**,观察结果是否成功,excel中有一条访问百度的用例,可以看看执行结果百度是否访问成功 - 查看report下是否有测试报告生成 ## 项目结构说明 - conf ===========> 配置文件 - core ===========> 公共方法,工具类等 - db_operate ==========> 数据库相关方法封装 - files ==========> 测试文件 - logs ==========> 日志文件 - report ==========> 测试报告 - test_case ===========> 测试用例 - venv ============> 虚拟环境 - requirements.txt ============> 相关依赖包文件 - runCase.py =============> 测试用例执行器 - READMD.md ============> 项目说明文档 ## EXCEL字段说明 - **description**:用例描述 - **url**:接口地址 - **method**:请求方式(目前只支持GET,POST) - **headers**:请求头,格式为 {"key","value"} - **cookies**:Cookies就是Cookies啦,格式为 {"key":"value"} - **para -------- 该资源内项目源码是个人的毕设,代码都测试ok,都是运行成功后才上传资源,答辩评审平均分达到96分,放心下载使用! <项目介绍> 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。 --------
在 Django 项目中,可以使用第三方库 `django-rest-swagger` 自动生成接口文档。 以下是具体的步骤: 1. 安装 `django-rest-swagger` ```bash pip install django-rest-swagger ``` 2. 将 `rest_framework` 和 `rest_framework_swagger` 添加到 Django 项目的 `INSTALLED_APPS` 中: ```python INSTALLED_APPS = [ # ... 'rest_framework', 'rest_framework_swagger', # ... ] ``` 3. 在 Django 项目的 `urls.py` 中添加 Swagger API URL: ```python from rest_framework_swagger.views import get_swagger_view schema_view = get_swagger_view(title='API 文档') urlpatterns = [ # ... url(r'^api-docs/$', schema_view), # ... ] ``` 4. 在需要生成文档的 API 视图中添加 `swagger_auto_schema` 装饰器: ```python from rest_framework.decorators import api_view from rest_framework.response import Response from rest_framework import status from rest_framework_swagger import swagger_auto_schema @api_view(['GET']) @swagger_auto_schema( operation_description='获取用户信息', responses={ status.HTTP_200_OK: '返回用户信息', status.HTTP_404_NOT_FOUND: '用户不存在' } ) def get_user(request, user_id): try: user = User.objects.get(id=user_id) except User.DoesNotExist: return Response({'error': 'User does not exist'}, status=status.HTTP_404_NOT_FOUND) return Response({ 'id': user.id, 'username': user.username, 'email': user.email }, status=status.HTTP_200_OK) ``` 5. 运行 Django 项目,在浏览器中访问 Swagger API URL:`http://localhost:8000/api-docs/`,即可查看生成接口文档。 注意事项: - 如果需要在文档中显示请求参数、响应数据的数据类型和描述信息,需要在对应的 API 视图中使用 `serializer_class` 属性指定序列化器。例如: ```python @api_view(['POST']) @swagger_auto_schema( operation_description='创建用户', request_body=UserSerializer, responses={ status.HTTP_201_CREATED: '用户创建成功', status.HTTP_400_BAD_REQUEST: '请求参数不合法' } ) def create_user(request): serializer = UserSerializer(data=request.data) if serializer.is_valid(): serializer.save() return Response(serializer.data, status=status.HTTP_201_CREATED) else: return Response(serializer.errors, status=status.HTTP_400_BAD_REQUEST) ``` - `swagger_auto_schema` 装饰器还支持其他参数,例如 `tags`、`operation_id` 等,可以根据实际需求进行设置。详细文档可以参考 `django-rest-swagger` 的官方文档。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值