I am developing a web app with Flask using CS50 IDE. I want the user to upload a file with a form. But when the form is submitted, I get a "500 Internal Server Error", whether a file is selected on not.
If a file is selected, there are no error logs in the console.
If NO file is selected, there is the following error log:
ERROR:application:Exception on /new-item [POST]
Traceback (most recent call last):
File "/usr/local/lib/python3.7/site-packages/flask/app.py", line 2446, in wsgi_app
response = self.full_dispatch_request()
File "/usr/local/lib/python3.7/site-packages/flask/app.py", line 1951, in full_dispatch_request
rv = self.handle_user_exception(e)
File "/usr/local/lib/python3.7/site-packages/flask/app.py", line 1820, in handle_user_exception
reraise(exc_type, exc_value, tb)
File "/usr/local/lib/python3.7/site-packages/flask/_compat.py", line 39, in reraise
raise value
File "/usr/local/lib/python3.7/site-packages/flask/app.py", line 1949, in full_dispatch_request
rv = self.dispatch_request()
File "/usr/local/lib/python3.7/site-packages/flask/app.py", line 1935, in dispatch_request
return self.view_functions[rule.endpoint](**req.view_args)
File "/home/ubuntu/final-project/helpers.py", line 34, in decorated_function
return f(*args, **kwargs)
File "/home/ubuntu/final-project/application.py", line 45, in decorated_function
return f(*args, **kwargs)
File "/home/ubuntu/final-project/application.py", line 350, in newItem
file.save(os.path.join(app.config['IMAGE_UPLOADS'], filename))
File "/usr/local/lib/python3.7/site-packages/werkzeug/datastructures.py", line 2800, in save
dst = open(dst, "wb")
IsADirectoryError: [Errno 21] Is a directory: 'static/img/menu/'
Flask code
app.config["IMAGE_UPLOADS"] = "static/img/menu/"
@app.route("/new-item", methods=['GET', 'POST'])
def newItem():
if request.method == "POST":
if request.files:
file = request.files["file"]
filename = secure_filename(file.filename)
file.save(os.path.join(app.config['IMAGE_UPLOADS'], filename))
HTML code
<form action="/new-item" method="post" enctype="multipart/form-data">
<div>
<input type="file" name="file">
<label>Choose Image</label>
</div>
<button type="submit">Submit</button>
</form>
Any idea what's causing the error?