Käyttäjä lisää tiedon tietokantaan

neuvojakaipaan

Minun pitäisi luoda ohjelmisto, jonka avulla käyttäjä voi lisätä tietokantaan tietoja. Ongelmana on kuitenkin se, etten tiedä miten tämä käytännössä tapahtuu. Osaan kyllä sijoittaa valmiin SQL lausekkeen Java-koodin sekaan, ja tiedon lisääminen tietokantaan onnistuu, mutta en saa ohjelmistoa kysymään tietokantaan lisättäviä tietoja varsinaiselta käyttäjältä. Miten tämä onnistuu?

2

187

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • neuvojakaipaan

      Toivon, että joku osaisi auttaa minua tässä. Alla on pätkä koodista, jota käytän.
      Miten sitä tulisi muuttaa, että tiedon tietokantaan lisää ohjelmiston käyttäjä eikä koodaaja.


      public static void addReports(){

      try{

      debug("Loading MySQL driver: " driverName);
      Class.forName(driverName);

      debug("Logging to MySQL" url);
      Connection con = DriverManager.getConnection(url);

      debug("Making SQL statement");


      String sql = "INSERT INTO person"
      "( id, name, birth, phone )"
      "VALUES"
      "( 5, 'Mikko', '1983-07-02', '123-987654')"
      "";

      debug("SQL: " sql);
      debug("Creating Database tunnel");
      Statement smtm = con.createStatement();

      debug("Sending SQL query");
      int count = smtm.executeUpdate(sql);

      smtm.close();
      con.close();

      } catch (Exception error){
      System.err.println( error.getMessage() );
      error.printStackTrace();
      System.exit(1);
      }

      System.out.println( "Normal Exit" );
      }

    • kliittymäkäsittelijä

      Siihen pitää tehdä admin-käyttöliittymä. Jos tietojen lisäystä tehdään netin yli, tietokantaa ei voi aksessoida suoraan javan jdbc:llä, vaan normaali http tai paremminkin https-admin-sivun kautta ja serveripäässä käsittelijällä (suora kanta-aksessi on tietoturvariski ja normaalisti palomuurit blokkaa sen poiskin). Ja admin-sivulle pitäisi olla pääsy vain admin-tunnus salasanalla.

      Esimerkki vastaavasta tilanteesta (html-formi ja serveripäässä java-jsp-käsittelijä, huomaa syöttötietojen tarkistus ja prepared statement turvallinen käyttö: se ei saa sisältää sisäkkäisiä ' tai " merkkejä):

      http://zetcode.com/tutorials/jeetutorials/mysqldatabase/

      Toivottavasti näet idean

    Ketjusta on poistettu 0 sääntöjenvastaista viestiä.

    Luetuimmat keskustelut

    1. 20v on otettu kiinni

      Tulipalo oli sytytetty joten murhasiko ex omat lapsensa ja heidän Äidin. Tuskin sitä kukaan ohikulkijakaan sytytti.
      Savonlinna
      167
      10309
    2. Mitä meidän välillä

      Tapahtuu lopulta?
      Ikävä
      55
      2813
    3. IL - Auerin lapsia oli houkuteltu rahalla Annelin puolelle?

      16:12 Outoja väitteitä Sijaisäidin mukaan Auerin lapsia koetettiin houkutella nettipalstoilla muuttamaan kertomuksiaan
      Maailman menoa
      80
      2528
    4. 85
      2351
    5. Savonlinan perhesurma, epäilty mies romani, äiti kantaväestöä

      https://www.is.fi/kotimaa/art-2000011676508.html Savonlinnan seudun romaniyhdistyksestä kerrottiin lauantaina IS:lle, e
      Maailman menoa
      147
      2094
    6. Savonlinnan murhapolttaja romani

      Ainakin IS kertoo. Arvasin heti ettei ole normi valkolainen suomalainen.
      Maailman menoa
      235
      1908
    7. Ei me taideta

      Pystyä kokonaan olemaan erossa.
      Ikävä
      44
      1392
    8. Kun aika on oikea niin

      Tupsahdat uudelleen tai löydän edes melkein yhtä ihanan ja joudun tyytymään... Suukko poskelles. 😘 Viattomasti vain.. �
      Ikävä
      13
      1365
    9. Muutama vuosi sitten oli pulaa hoitohenkilökunnasta

      Nyt heitä sanotaan irti. Tarve ei ole hävinnyt mihinkään, ei myöskään raha jolla ihmisten työnteosta maksettiin; raha va
      Maailman menoa
      115
      1197
    10. Ilouutinen: Osmo Peltola jo teini-iässä, silti yhdessä Peltsi-isän kanssa taas tv:ssä!

      Ihan paras parivaljakko: Peltsi-isä ja Osmo-poika. Tämä on kyllä sellaista hyvänmielen telkkariohjelmaa, josta kukaan ei
      Tv-sarjat
      34
      873
    Aihe