2023.11.13使用flask将图片进行黑白处理(url方式进行传输)

2023.11.13使用flask将图片进行黑白处理(url方式进行传输)

和下述文章进行对比,实现效果相同,但是使用url方式更简便。

2023.11.12使用flask对图片进行黑白处理(base64编码方式传输)
https://editor.csdn.net/md/?articleId=134370865

复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Image Processor</title>
</head>
<body>
    <h1>Image Processor</h1>
    <form id="uploadForm" enctype="multipart/form-data">
        <input type="file" name="file" accept="image/*" onchange="previewImage(event)">
        <input type="button" value="Process" onclick="processImage()">
    </form>
    <h2>Preview Image</h2>
    <img id="preview" src="#" alt="Preview Image">

    <h2>Processed Image</h2>
    <img id="processed" src="#" alt="Processed Image">

    <script>
        function previewImage(event) {
            var input = event.target;
            if (input.files && input.files[0]) {
                var reader = new FileReader();
                reader.onload = function (e) {
                    document.getElementById('preview').src = e.target.result;
                };
                reader.readAsDataURL(input.files[0]);
            }
        }

        function processImage() {
            var fileInput = document.querySelector('input[type="file"]');
            var file = fileInput.files[0];
            var formData = new FormData();
            formData.append('file', file);

            var xhr = new XMLHttpRequest();
            xhr.open('POST', '/process', true);
            xhr.onreadystatechange = function () {
                if (xhr.readyState === 4 && xhr.status === 200) {
                    var response = JSON.parse(xhr.responseText);
                    if (response.processed_image) {
                        document.getElementById('processed').src = response.processed_image;
                    }
                }
            };
            xhr.send(formData);
        }
    </script>
</body>
</html>

from flask import Flask, render_template, request, jsonify
from PIL import Image

app = Flask(__name__)

@app.route('/')
def index():
    return render_template('index.html')

@app.route('/process', methods=['POST'])
def process():
    if 'file' not in request.files:
        return jsonify({'error': 'No file part'})

    file = request.files['file']
    img = Image.open(file)
    bw_img = img.convert('L')  # 转换为黑白图片
    bw_img.save('static/processed_image.jpg')  # 保存处理后的图片

    return jsonify({'processed_image': '/static/processed_image.jpg'})

if __name__ == '__main__':
    app.run(debug=True)
相关推荐
程序员三藏6 分钟前
2025最新的软件测试面试八股文(800+道题)
自动化测试·软件测试·python·功能测试·测试工具·面试·职场和发展
期待のcode28 分钟前
Spring框架1—Spring的IOC核心技术1
java·后端·spring·架构
Pocker_Spades_A29 分钟前
Python快速入门专业版(二十三):for循环基础:遍历字符串、列表与range()函数(计数案例)
python
闲人编程32 分钟前
图像去雾算法:从物理模型到深度学习实现
图像处理·人工智能·python·深度学习·算法·计算机视觉·去雾
Livingbody2 小时前
10分钟完成 ERNIE-4.5-21B-A3B-Thinking深度思考模型部署
后端
Kyln.Wu2 小时前
【python实用小脚本-211】[硬件互联] 桌面壁纸×Python梦幻联动|用10行代码实现“开机盲盒”自动化改造实录(建议收藏)
开发语言·python·自动化
Ms_Big2 小时前
ppliteseg改rknn,部署在嵌入式板,加速模型
人工智能·python·深度学习
胡萝卜的兔3 小时前
go 日志的分装和使用 Zap + lumberjack
开发语言·后端·golang
折翼的恶魔3 小时前
数据分析:合并
python·数据分析·pandas
en-route3 小时前
如何在 Spring Boot 中指定不同的配置文件?
java·spring boot·后端