我試圖建立一個python燒瓶web應用程序與教程,我遇到麻煩實施我的註冊方法。 教程:http://code.tutsplus.com/tutorials/creating-a-web-app-from-scratch-using-python-flask-and-mysql--cms-22972python flask bucketlist應用程序
我得到一個500錯誤,當我按 '註冊' 按鈕:_name = REQUEST.FORM [ 'inputName'] 類型錯誤: 'cached_property' 對象沒有屬性 '的GetItem'
不知道爲什麼我收到500錯誤。任何幫助,將不勝感激。由於
下面是我的Python代碼:
from flask import Flask, render_template, json, Request
app = Flask(__name__)
@app.route('/main')
def main():
return render_template('index.html')
@app.route('/showSignUp')
def showSignUp():
return render_template('signup.html')
@app.route('/signUp',methods=['POST'])
def signUp():
_name = Request.form['inputName']
_email = Request.form['inputEmail']
_password = Request.form['inputPassword']
if _name and _email and _password:
return json.dumps({'html':'<span>All fields good !!</span>'})
else:
return json.dumps({'html:':'<span>Enter the required fields</span>'})
if __name__ == "__main__":
app.run(debug=True)
這裏是JavaScript Ajax代碼:
$(function() {
$('#btnSignUp').click(function() {
$.ajax({
url: '/signUp',
data: $('form').serialize(),
type: 'POST',
success: function(response) {
console.log(response);
},
error: function(error) {
console.log(error);
}
});
});
});
這裏是signup.html
<!DOCTYPE html>
<html lang="en">
<head>
<title>Python Flask Bucket List App</title>
<link href="http://getbootstrap.com/dist/css/bootstrap.min.css" rel="stylesheet" />
<link href="http://getbootstrap.com/examples/jumbotron-narrow/jumbotron-narrow.css" rel="stylesheet" />
<link href="../static/signup.css" rel="stylesheet" />
<script src="../static/js/jquery-3.1.0.js"></script>
<script src="../static/js/signUp.js"></script>
</head>
<body>
<div class="container">
<div class="header">
<nav>
<ul class="nav nav-pills pulls-right">
<li role="presentation"><a href="main">Home</a></li>
<li role="presentation"><a href="#">Sign In</a></li>
<li role="presentation" class="active"><a href="#">Sign Up</a></li>
</ul>
</nav>
<h3 class="text-muted">Python Flask App</h3>
</div>
<div class="jumbotron">
<h1>Bucket List App</h1>
<form class="form-signin">
<label for="inputName" class="sr-only">Name</label>
<input type="name" name="inputName" id="inputName" class="form-control" placeholder="Name" required autofocus />
<label for="inputEmail" class="sr-only">Email address</label>
<input type="email" name="inputEmail" id="inputEmail" class="form-control" placeholder="Email address" required autofocus />
<label for="inputPassword" class="sr-only">Password</label>
<input type="password" name="inputPassword" id="inputPassword" class="form-control" placeholder="Password" required />
<button id="btnSignUp" class="btn btn-lg btn-primary btn-block" type="button">Sign up</button>
</form>
</div>
<footer class="footer">
<p>© Company 2016</p>
</footer>
</div>
</body>
</html>
你能分享'>> print(type(cached_property))'嗎? Flask具有很好的調試接口 –
類型:'Request'到'request'。 – davidism
@dhuenecke,嗨dhuenecke,我正在按照相同的教程,也有signUp方法的麻煩。點擊按鈕後它確實會做出反應,我想這可能是jQuery沒有安裝或正確放置。你能否告訴我你是如何實現你的jQuery的?謝謝。 – Samoth