App Engine: Flask HTML Data Form
The average cloud developer salary in the USA is $130,000 per year or $62.50 per hour. Entry level positions start at $112,028 per year while most experienced workers make up to $165,481 per year.
Show me the Money
Create directory for webform
Go to cloud shell
data:image/s3,"s3://crabby-images/b9068/b90684b52d760bc6ed19fa10edca3db2aac9f75a" alt=""
Welcome to Cloud Shell! Type "help" to get started.
Your Cloud Platform project in this session is set to uconn-engr.
Use “gcloud config set project [PROJECT_ID]” to change to a different project.
john_iacovacci1@cloudshell:~ (uconn-engr)$ mkdir webform
data:image/s3,"s3://crabby-images/d85f2/d85f2446d305ea58e036136db765f7fa5da33f46" alt=""
data:image/s3,"s3://crabby-images/16586/1658669530717c010d1e9a0293c25963262099a0" alt=""
Right click directory for new file
data:image/s3,"s3://crabby-images/775ba/775ba2b54f3090481be89e40dfd00c94bd6a1682" alt=""
Create a file in that directory called main.py
==========================================================
from flask import Flask, request, render_template
app = Flask(__name__)
@app.route('/', methods=['POST','GET'])
def run_quickstart():
if request.method == 'POST':
data = request.form.to_dict(flat=True)
Name = data['my-name']
Address = data['my-address']
City = data['my-city']
State = data['my-state']
Zip = data['my-zip']
Phone = data['my-phone']
Email = data['my-email']
Comments = data['my-comments']
return render_template('formdata.html', FormName=Name, FormAddress=Address, FormCity=City, FormState=State, FormZip=Zip, FormPhone=Phone, FormEmail=Email, FormComments=Comments)
else:
return render_template('index.html')
if __name__ == "__main__":
app.run(host="127.0.0.1", port=8080, debug=True)
=========================================================
Create another file in the same directory called requirements.txt
=========================================================
Flask==3.0.1
=========================================================
Create file called app.yaml
=========================================================
runtime: python39
=========================================================
Create a new folder called templates and create html files in that directory
data:image/s3,"s3://crabby-images/c0719/c071953625924eba3eac5c51f94ec3f3495838ee" alt=""
data:image/s3,"s3://crabby-images/c5535/c553594541f6e520937ffe9c66b6f42fc72055ef" alt=""
Select the templates folder
data:image/s3,"s3://crabby-images/c728a/c728a49b1fc4fb2e237ca7c12c8e0df65cfb014d" alt=""
templates/index.html
=========================================================
<!DOCTYPE html>
<html lang="en">
<head>
<title>Form Validation</title>
<script>
function validateForm() {
let name = document.forms["myForm"]["my-name"].value;
let email = document.forms["myForm"]["my-email"].value;
if (name == "") {
alert("Name must be filled out");
return false;
}
if (email == "") {
alert("Email must be filled out");
return false;
}
// Add more validation rules as needed
}
</script>
</head>
<body>
<h2>Input</h2>
<form name="myForm" onsubmit="return validateForm()" method="post" action="/">
Name: <input type="text" name="my-name"></p>
Address: <input type="text" name="my-address"></p>
City: <input type="text" name="my-city"></p>
State: <input type="text" name="my-state"></p>
Zip: <input type="text" name="my-zip"></p>
Phone: <input type="text" name="my-phone"></p>
Email: <input type="text" name="my-email"></p>
Comments: <textarea name="my-comments" rows="10" cols="30"> </textarea><br>
<button type="submit">Submit</button>
</form>
</body>
</html>
=========================================================
Then create a file called
data:image/s3,"s3://crabby-images/74339/74339049d56d3f25ad57133c95f0699f4e1034e5" alt=""
templates/formdata.html
=========================================================
<!doctype html>
<html>
<body>
<h2>Customer Information</h2>
<p>
Name: {{ FormName }} <br>
Address: {{ FormAddress }} <br>
City: {{ FormCity }} <br>
State: {{ FormState }} <br>
Zip: {{ FormZip }} <br>
Phone: {{ FormPhone }} <br>
Email: {{ FormEmail }} <br>
Comments:{{ FormComments }}
</p>
</body>
</html>
=========================================================
Save all
data:image/s3,"s3://crabby-images/1577f/1577f65bd50785fe74689fec430bd2a3a708153f" alt=""
Open Terminal
data:image/s3,"s3://crabby-images/a24b1/a24b1f2446a661b86a8ed1cd0bd162a36f4bb4af" alt=""
Change directory into webforms
john_iacovacci1@cloudshell:~ (uconn-engr)$ cd webform
john_iacovacci1@cloudshell:~/webform (uconn-engr)$
Type in gcloud app deploy and then authorize
data:image/s3,"s3://crabby-images/1f5f1/1f5f1c573101703f4c5b155a94cb89b835844b73" alt=""
john_iacovacci1@cloudshell:~/webform (uconn-engr)$ gcloud app deploy
Services to deploy:
descriptor: [/home/john_iacovacci1/webform/app.yaml]
source: [/home/john_iacovacci1/webform]
target project: [uconn-engr]
target service: [default]
target version: [20220207t013140]
target url: [https://uconn-engr.uc.r.appspot.com]
target service account: [App Engine default service account]
Do you want to continue (Y/n)?
Type Y
Beginning deployment of service [default]...
Uploading 0 files to Google Cloud Storage
100%
File upload done.
Updating service [default]...done.
Setting traffic split for service [default]...done.
Deployed service [default] to [https://uconn-engr.uc.r.appspot.com]
You can stream logs from the command line by running:
$ gcloud app logs tail -s default
To
view your application in the web browser run:
$ gcloud app browse
john_iacovacci1@cloudshell:~/webform (uconn-engr)$
Go to your App Engine Dashboard
data:image/s3,"s3://crabby-images/b4a03/b4a03052675c409f531390da9b11b31c139b53b8" alt=""
Click application link
data:image/s3,"s3://crabby-images/0fdbf/0fdbf93ef1e1ecee5bc09a9ece060eba5785bed7" alt=""
Web Form
how
ReplyDelete