Use of unsanitized data to make API calls Cette page n'est pas encore disponible en français, sa traduction est en cours.
Si vous avez des questions ou des retours sur notre projet de traduction actuel,
n'hésitez pas à nous contacter .
TRY THIS RULE ID: python-flask/html-format-from-user-input
Language: Python
Severity: Error
Category: Security
CWE : 79
Description Use of unsanitized from incoming request for SQL queries is unsafe and leads to SQL injections. Data from requests must be sanitized before being used to issues SQL queries, open file or deserialize data. Make sure the data is sanitized before use.
Learn More Non-Compliant Code Examples import flask
import requests
app = flask . Flask ( __name__ )
@app.route ( "/route/to/resource/<resource_id>" )
def resource1 ( resource_id ):
return f "<a href='/path/to/ { resource_id } '>Click me!</a>"
@app.route ( "/route/to/resource/<resource_id>" )
def resource2 ( resource_id ):
return "<a href='/path/to/ {0} '>Click me!</a>" . format ( resource_id )
@app.route ( "/route/to/resource/<resource_id>" )
def resource3 ():
resource_id = flask . request . args . get ( "resource_id" )
return "<a href='/path/to/ %s '>Click me!</a>" % resource_id
@app.route ( "/route/to/resource/<resource_id>" )
def resource4 ( resource_id ):
ret = f "<a href='/path/to/ { resource_id } '>Click me!</a>"
return ret
@app.route ( "/route/to/resource/<resource_id>" )
def resource2 ():
resource_id = flask . request . args . get ( "resource_id" )
ret = "<a href='/path/to/ {0} '>Click me!</a>" . format ( resource_id )
return ret
@app.route ( "/route/to/resource/<resource_id>" )
def resource3 ( resource_id ):
ret = "<a href='/path/to/ %s '>Click me!</a>" % resource_id
return ret
Compliant Code Examples import flask
import requests
app = flask . Flask ( __name__ )
@app.route ( "/route/to/resource/<resource_id>" )
def resource2 ( resource_id ):
return "<a href='/path/to/ {0} '>Click me!</a>" . format ( sanitize ( resource_id ))
@app.route ( "/route/to/resource/<resource_id>" )
def resource2 ():
resource_id = get . data ()
ret = requests . get ( foo );
ret = "<a href='/path/to/ {0} '>Click me!</a>" . format ( resource_id )
return ret
Seamless integrations. Try Datadog Code Analysis