flask-demo / app.py
heboya8's picture
Update app.py
a56ec85 verified
from flask import Flask, render_template, request, redirect, url_for
from PIL import Image
import os
import uuid
import logging
# Configure logging
logging.basicConfig(level=logging.INFO)
logger = logging.getLogger(__name__)
app = Flask(__name__)
# Set upload folder
UPLOAD_FOLDER = 'static/uploads'
os.makedirs(UPLOAD_FOLDER, exist_ok=True)
app.config['UPLOAD_FOLDER'] = UPLOAD_FOLDER
@app.route('/')
def index():
return render_template('index.html')
@app.route('/upload', methods=['POST'])
def upload_file():
if 'file' not in request.files:
logger.warning("No file part in request.")
return redirect(request.url)
file = request.files['file']
if file.filename == '':
logger.warning("No file selected.")
return redirect(request.url)
try:
# Save uploaded file
filename = str(uuid.uuid4()) + os.path.splitext(file.filename)[1]
filepath = os.path.join(app.config['UPLOAD_FOLDER'], filename)
file.save(filepath)
logger.info(f"File saved: {filename}")
# Verify and resize image
image = Image.open(filepath).convert("RGB")
image = image.resize((800, 600)) # Resize for consistent display
image.save(filepath) # Overwrite with resized image
logger.info(f"Image resized and saved: {filename}")
return render_template('results.html',
image=url_for('static', filename=f'uploads/{filename}'))
except Exception as e:
logger.error(f"Error processing file: {str(e)}")
return render_template('index.html', error=f"Error processing file: {str(e)}")
if __name__ == '__main__':
app.run(host='0.0.0.0', port=7860)