在Postman中执行GET
时出现此错误。
完整追溯:
* Running on http://0.0.0.0:5001/ (Press CTRL+C to quit)
[2020-08-25 15:11:01,390] ERROR in app: Exception on /get_chain [GET]
Traceback (most recent call last):
File "D:\conda\lib\site-packages\flask\app.py", line 1982, in wsgi_app
the :attr:`before_first_request_funcs` and only exactly once per
File "D:\conda\lib\site-packages\flask\app.py", line 1614, in full_dispatch_request
@setupmethod
File "D:\conda\lib\site-packages\flask\app.py", line 1517, in handle_user_exception
self.add_template_global(f, name=name)
File "D:\conda\lib\site-packages\flask\_compat.py", line 39, in reraise
raise value
File "D:\conda\lib\site-packages\flask\app.py", line 1610, in full_dispatch_request
"""
File "D:\conda\lib\site-packages\flask\app.py", line 1819, in preprocess_request
AttributeError: 'NoneType' object has no attribute 'request'
127.0.0.1 - - [25/Aug/2020 15:11:01] "GET /get_chain HTTP/1.1" 500 -
Error on request:
Traceback (most recent call last):
File "D:\conda\lib\site-packages\werkzeug\serving.py", line 323, in run_wsgi
execute(self.server.app)
File "D:\conda\lib\site-packages\werkzeug\serving.py", line 312, in execute
application_iter = app(environ, start_response)
File "D:\conda\lib\site-packages\flask\app.py", line 1997, in __call__
"""This method is called to create the default ``OPTIONS`` response.
File "D:\conda\lib\site-packages\flask\app.py", line 1993, in wsgi_app
func()
File "D:\conda\lib\site-packages\flask\ctx.py", line 452, in auto_pop
self.pop(exc)
File "D:\conda\lib\site-packages\flask\ctx.py", line 415, in pop
self.app.do_teardown_request(exc)
File "D:\conda\lib\site-packages\flask\app.py", line 1875, in do_teardown_request
server_error.original_exception = e
AttributeError: 'NoneType' object has no attribute 'request'
我将完整的代码放在下面,但是我认为它没有任何问题。
完整代码:
# Module 2 - Create a cryptocurrency
# To be installed:
# Flask==0.12.2: pip install Flask==0.12.2
# Postman HTTP Client: https://www.getpostman.com/
# Importing the libraries
import datetime
import hashlib
import json
from flask import Flask, jsonify, request
import requests
from uuid import uuid4
from urllib.parse import urlparse
# Part 1 - Building a Blockchain
class Blockchain:
def __init__(self):
self.chain = []
self.transaction = []
self.create_block(proof = 1, previous_hash = '0')
self.nodes = set()
def create_block(self, proof, previous_hash):
block = {'index': len(self.chain) + 1,
'timestamp': str(datetime.datetime.now()),
'proof': proof,
'previous_hash': previous_hash,
'transaction': self.transaction}
self.transaction = []
self.chain.append(block)
return block
def get_previous_block(self):
return self.chain[-1]
def proof_of_work(self, previous_proof):
new_proof = 1
check_proof = False
while check_proof is False:
hash_operation = hashlib.sha256(str(new_proof**2 - previous_proof**2).encode()).hexdigest()
if hash_operation[:4] == '0000':
check_proof = True
else:
new_proof += 1
return new_proof
def hash(self, block):
encoded_block = json.dumps(block, sort_keys = True).encode()
return hashlib.sha256(encoded_block).hexdigest()
def is_chain_valid(self, chain):
previous_block = chain[0]
block_index = 1
while block_index < len(chain):
block = chain[block_index]
if block['previous_hash'] != self.hash(previous_block):
return False
previous_proof = previous_block['proof']
proof = block['proof']
hash_operation = hashlib.sha256(str(proof**2 - previous_proof**2).encode()).hexdigest()
if hash_operation[:4] != '0000':
return False
previous_block = block
block_index += 1
return True
def add_transaction(self, sender, receiver, amount):
self.transaction.append({'sender': sender,
'receiver': receiver,
'amount': amount})
previous_block = self.get_previous_block()
return previous_block['index'] + 1
def add_node(self, address):
parsed_url = urlparse(address)
self.nodes.add(parsed_url.netloc)
def replace_chain(self):
network = self.nodes
longest_chain = None
max_length = len(self.chain)
for node in network:
response = requests.get(f'http://{node}/get_chain')
if response .status_code == 200:
length = response.json(['length'])
chain = response.json(['chain'])
if length > max_length and self.is_chain_valid(chain):
max_length = length
longest_chain = chain
if longest_chain:
self.chain = longest_chain
return True
return False
# Part 2 - Mining our Blockchain
# Creating a Web App
app = Flask(__name__)
# Creating an address for the node on port 5000
node_address = str(uuid4()).replace('-', '')
# Creating a Blockchain
blockchain = Blockchain()
# Mining a new block
@app.route('/mine_block', methods = ['GET'])
def mine_block():
previous_block = blockchain.get_previous_block()
previous_proof = previous_block['proof']
proof = blockchain.proof_of_work(previous_proof)
previous_hash = blockchain.hash(previous_block)
blockchain.add_transaction(sender = node_address, receiver = 'Macios', amount = 1)
block = blockchain.create_block(proof, previous_hash)
response = {'message': 'Congratulations, you just mined a block!',
'index': block['index'],
'timestamp': block['timestamp'],
'proof': block['proof'],
'previous_hash': block['previous_hash'],
'transactions': block['transactions']}
return jsonify(response), 200
# Getting the full Blockchain
@app.route('/get_chain', methods = ['GET'])
def get_chain():
response = {'chain': blockchain.chain,
'length': len(blockchain.chain)}
return jsonify(response), 200
# Checking if the Blockchain is valid
@app.route('/is_valid', methods = ['GET'])
def is_valid():
is_valid = blockchain.is_chain_valid(blockchain.chain)
if is_valid:
response = {'message': 'All good. The Blockchain is valid.'}
else:
response = {'message': 'Houston, we have a problem. The Blockchain is not valid.'}
return jsonify(response), 200
# Adding a new transaction to the blockchain
@app.route('/add_transaction', methods = ['POST'])
def add_transaction():
json = request.get_json()
transaction_keys = ['sender', 'receiver', 'amount']
if not all(key in json for key in transaction_keys):
return 'Some elements of the transaction are missing', 400
index = blockchain.add_transaction(json['sender'], json['receiver'], json['amount'])
response = {'message': f'This transaction will be added to Block {index}'}
return jsonify(response), 201
# Part 3 - Decentralizing our blockchain
# Connecting new nodes
@app.route('/connect_node', methods = ['POST'])
def connect_node():
json = request.get_json()
nodes = json.get('nodes')
if nodes is None:
return 'No node', 400
for node in nodes:
blockchain.add_node(node)
response = {'message': 'All the nodes are now connected. The Hadcoin Blockchain now contains the following nodes',
'total_nodes': list(blockchain.nodes)}
return jsonify(response), 201
# Replacing the chain by the longest chain if needed
@app.route('/replacing_chain', methods = ['GET'])
def replace_chain():
is_chain_replaced = blockchain.replace_chain()
if is_chain_replaced:
response = {'message': 'The nodes had different chains so the chain was replaced by the longest one.',
'new_chain': blockchain.chain}
else:
response = {'message': 'All good. The chain is the largest one.',
'actual_chain': blockchain.chain}
return jsonify(response), 200
# Running the app
app.run(host = '0.0.0.0', port = 5001)
当然,这是在邮递员中执行GET请求时发生的。我用http://127.0.0.1:5001/get_chain
做。除了get_chain
之外,其他请求也会发生同样的情况。
我也尝试使用http://localhost:5001/get_chain
进行'GET'操作,但结果是相同的。
我还尝试在与5000、5001不同的端口上运行,但是仍然相同
该代码已经过检查,可以在某些通行证上使用,而在其他一些通行证上则无效。可能是什么原因造成的?