• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Flask, problem z mysql

Hosting forpsi easy 1 pln
0 głosów
135 wizyt
pytanie zadane 27 października 2020 w Python przez antypop Mądrala (5,720 p.)

Hej, mam problem. Mianowicie napisałem taki kod:

@app.route('/<element>')
def render_index(element):

    message = element

    sql = "select * from routes where path = {}".format(message)

gdzie w zmiennej sql powinno się utworzyć zapytanie select * from routes where path = cośTam, ale pymyslq zwraca mi błąd:

 "Unknown column 'favicon.ico' in 'where clause'"

jak listuje sobie zmienną sql w konsoli to dostaje coś takiego :

select * from routes where path = favicon.ico

Może mi ktoś wyjaśnić wtf i co robię źle? :)

1 odpowiedź

0 głosów
odpowiedź 27 października 2020 przez adrian17 Ekspert (337,860 p.)
wybrane 29 października 2020 przez antypop
 
Najlepsza

Przeglądarka pyta o favicon, więc pyta o `/favicon.ico`. Trafia to potem do Twojego kodu jako 'element'.

Ogólnie, to trochę dziwne żeby cały url Twojej strony zawsze trafiał do jednego endpointa jako argument, to trochę przeczy celu routingu wbudowanego we Flaska...

Inna sprawa, że masz tutaj ewidentny trywialny SQL injection. Naucz się normalnie przekazywać argumenty do zapytania SQLowego :/

komentarz 27 października 2020 przez antypop Mądrala (5,720 p.)
Dzięki,

podrzucisz linka do jakichś dobrych praktyk przy zapytaniach sqlowych? :)
komentarz 28 października 2020 przez adrian17 Ekspert (337,860 p.)

Trochę zależy od tego jak gadasz z bazą (bo tego nie pokazałeś), ale ogólnie zazwyczaj sprowadza się to do:

cursor.execute("select * from x where cos={} and cos2={}".format(zmienna1, zmienna2))
->
cursor.execute("select * from x where cos=%s and cos2=%s", (zmienna1, zmienna2))

nawet krótsze :)

Można też użyć ORMa (SQLAlchemy i biblioteki Flask-SQLAlchemy) i w ogóle nie pisać SQLa:

route = Routes.query.filter_by(path=message).first()

 

komentarz 29 października 2020 przez antypop Mądrala (5,720 p.)
mysql :)

Dzięki. Dopiero się uczę tego języka i pracy z nim.

Pozdrawiam

Podobne pytania

0 głosów
0 odpowiedzi 245 wizyt
pytanie zadane 14 października 2017 w Python przez Bohdan Nowicjusz (120 p.)
0 głosów
1 odpowiedź 241 wizyt
pytanie zadane 18 sierpnia 2022 w Python przez Podlasianin Początkujący (400 p.)
0 głosów
0 odpowiedzi 337 wizyt

92,125 zapytań

140,785 odpowiedzi

317,804 komentarzy

61,446 pasjonatów

Advent of Code 2023

Top 15 użytkowników

  1. 1468p. - Łukasz Eckert
  2. 1444p. - Dawid128
  3. 1430p. - CC PL
  4. 1419p. - rafalszastok
  5. 1418p. - Marcin Putra
  6. 1373p. - Mikbac
  7. 1362p. - rucin93
  8. 1351p. - sefirek
  9. 1325p. - Michal Drewniak
  10. 1296p. - Adrian Wieprzkowicz
  11. 1267p. - Eryk Andrzejewski
  12. 1260p. - TheLukaszNs
  13. 1239p. - JarekDev
  14. 1188p. - Rafał Trójniak
  15. 1179p. - 13NOONE37
Szczegóły i pełne wyniki

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Uwaga - w dniach od 02.12 do 08.12 trwają Mikołajki (książki drukowane mają rabat -35%, ebooki do -45%). Zaś dodatkowy, specjalny kod zniżkowy: HELMIKOLAJ-10 dla naszych Widzów zapewni Wam oszczędność -10zł dla zamówień powyżej 70zł! Warto korzystać!

Akademia Sekuraka

Akademia Sekuraka 2024 zapewnia dostęp do minimum 15 szkoleń online z bezpieczeństwa IT oraz dostęp także do materiałów z edycji Sekurak Academy z roku 2023!

Przy zakupie możecie skorzystać z kodu: pasja-akademia - użyjcie go w koszyku, a uzyskacie rabat -30% na bilety w wersji "Standard"! Więcej informacji na temat akademii 2024 znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...