SWIFT/SEPA:n sisältöä

Lasse777

Jonkin verran on tullut tehtyä XML-faileja vuosien varrella, HTML-koodausten ohella, joten aivan outoa aihe ei ole. Nyt yritän päästä noiden uusien SEPA-maksuhommien ja sen XML.n kanssa tutuksi. Muutama XML:äään liittyvä juttu ja sen käyttöidea ei vaan avaudu.

Esim. SEPA:n maksutiedosto alkaa aina tällaisella vakioloitsulla:




....

Näitä en ymmärrä:
1. Kun tällainen avataan vaikka selainohjelmalla, niin käykö selain silloin osoitteessa "http://www.w3.org/2001/XMLSchema-instance" ja lukee sieltä jotakin, tai tekee XML-tiedostolle jonkin tarkistuksen tuolla osoitteessa olevaa Schemaaa vasten?

Mietin vain että jos koko EU-alueella kaikkien firmojan kaikkia SEPA-maksutiedostoja luettaessa selain käy aina tuossa osoitteessa, niin eihän siihen minkään serverin kapasiteetti voi riittä. Joku tarkoitus tuolla www-osoitteella kuitenkin on, mutta mikä? Mitenkä usein tai millä periaatteella selaimet siis käyvät tuolla, mahdollisesti tsekkaamassa jotakin?

2. Entä tämä litania: xmlns = "urn:iso:std:iso:20022:tech:xsd:pain.001.001.02"
Koko tässä käytetyn addressin notaatio on minulle outoa. Osoittaako pötkö "urn:iso:std:iso:20022:..." jonnekin netissä olevaan tiedostoon? Vai onko tuollainen file olemassa jo omassa koneessani, vaikka jossakin cachessa tai muualla valmiina? Tietoliikennettä skannailemalla, mielestäni selain ei käy tuollaisia tsekkaamassa tai hakemassa yhteyden aikana.

Joten miten noita kaksoispiste ":"-merkintöjä ylipäätään olisi ymmärrettävä, millaiseen ja missä sijaitsevaan paikkaan ne osoittavat?

. . .
Eli osaan nyt siis tehdä halutunlaisia SEPA:n XML-tiedostoja, sisältäen kulloinkin tarvittavan datan. Alkuun vain laitan kiinteänä tuon alussa olevan noin 4-rivisen litanian.

Mutta haluaisin myös ymmärtää että mitä nuo alussa olevat litaniat käytännössä tarkoittavat. Onko tuolla osoitteessa "http://www.w3.org/2001/XMLSchema-instance" olemassa jokin Schema-tiedosto, jota itsekin mahdollisesti voisin käytellä jos haluan tarkistaa eli validoida oman luomani XML-dokumentin oikeellisuutta.

Olen kokeillut käydä selaimella viereilemassa noissa osoitteissa, mutta en oikein ole päässyt kärrylle. Osanneeko joku vääntää rautalangasta mallia?
t Lasse

8

2018

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • Lasse777

      >Esim. SEPA:n maksutiedosto alkaa aina tällaisella vakioloitsulla:
      >

      Hmm, ei tämä foorumisysteemi taidakaan antaa XML-koodin tulla näkyville lainkaan. Melkein kaikki strippaantui edeltä pois. Kokeilen uudelleen:



      Document
      VASENKULMA_ xmlns = "urn:iso:std:iso:20022:tech:xsd:pain.001.001.02"
      xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
      xsi:schemaLocation = "urn:iso:std:iso:20022:tech:xsd:pain.001.001.02 pain.001.001.02.xsd"
      VASENKULMA_pain.001.001.02_OIKEAKULMA
      VASENKULMA_GrpHdr_OIKEAKULMA ....

      Selite:
      VASENKULMA_ = vasen kulmasulku
      OIKEAKULMA_ = oikea kulmasulku

      ---
      Jos ei edelleenkään tule mitään läpi, joku ehkä ystävällisesti kertonee miten näitä XML-malleja voi täällä esittää?
      Lasse

      • xmlxml

        Clientit kuten selain ei käy xml-namespace-'osoitteissa', 'osoitteet' ovat nimellisiä.
        Namespacet (xmlns=uri) ovat vain määrityksiä siihen, miten käytetyt tyypit tulkitaan.
        Yleensä tyypit tulee xml-standardista (w3.org Schema-namespace löytyy aina schemasta), mutta uusia voi määritellä (menee scheman targetnamespaceen).
        Yleensä asetetaan myös defaultnamespace ja targetnamespace (=scheman/dokumentin namespace) (ja usein samaksi). Nämä asetukset vaikuttavat prefixeihin xml-docissa (tarvitaanko niitä vai ei).
        uri voi olla url (http://..) tai urn (urn:..).

        Erikseen on validaattorit, millä testataan, että xml-doc vastaa xml-schemaa (schema luetaan xml-docin schemaLocation-arvosta joten sen on syytä olla siellä). Selaimet ei lue/tarvi schemaa.
        Jotkut testityökalut voi myös tarvita schemaa (tekee sen perusteella xml-docin), samoin esim. weblogicin kanssa kehitystyössä tarvitaan schemoja, mitkä on talletettava ko paikkaan.


      • Lasse777
        xmlxml kirjoitti:

        Clientit kuten selain ei käy xml-namespace-'osoitteissa', 'osoitteet' ovat nimellisiä.
        Namespacet (xmlns=uri) ovat vain määrityksiä siihen, miten käytetyt tyypit tulkitaan.
        Yleensä tyypit tulee xml-standardista (w3.org Schema-namespace löytyy aina schemasta), mutta uusia voi määritellä (menee scheman targetnamespaceen).
        Yleensä asetetaan myös defaultnamespace ja targetnamespace (=scheman/dokumentin namespace) (ja usein samaksi). Nämä asetukset vaikuttavat prefixeihin xml-docissa (tarvitaanko niitä vai ei).
        uri voi olla url (http://..) tai urn (urn:..).

        Erikseen on validaattorit, millä testataan, että xml-doc vastaa xml-schemaa (schema luetaan xml-docin schemaLocation-arvosta joten sen on syytä olla siellä). Selaimet ei lue/tarvi schemaa.
        Jotkut testityökalut voi myös tarvita schemaa (tekee sen perusteella xml-docin), samoin esim. weblogicin kanssa kehitystyössä tarvitaan schemoja, mitkä on talletettava ko paikkaan.

        >Erikseen on validaattorit, millä testataan, että xml-doc vastaa xml-schemaa (schema
        >luetaan xml-docin schemaLocation-arvosta joten sen on syytä olla siellä). Selaimet
        >ei lue/tarvi schemaa.
        >Jotkut testityökalut voi myös tarvita schemaa (tekee sen perusteella xml-docin),
        >samoin esim. weblogicin kanssa kehitystyössä tarvitaan schemoja, mitkä on
        >talletettava ko paikkaan.

        Jonkin verran olen itsekin päässyt tässä asiassa viime kuukauden tarpomisen perästä eteenpäin.

        XML-esimerkkitiedostona vaikka tässä Nordean linkissä oleva yksi XML-tiedosto:
        http://www.nordea.fi/sitemod/upload/root/fi_org/liite/Yrityksen_maksut_esimerkit.xml

        Tuossakin XML:n alussa on tämän tyyppinen urn-loitsu:
        ""

        Siis onko niin että normaalikäytössä selain ei ikinä välitä mitään mitä tämä teksti sisältää? Eikä yritä haeskella mitään Schema-tiedostojakaan, ei siis tuosta osoitteesta, eikä mistään namespacesta eikä koneen paikallisesta Schema Cachesta, eikä siis mistään?? Eli siis kyseistä tiedostoa ei tarviste olla käsillä eikä mistään selaimelle ladattavissa tms?

        Ja silloin siis kaikki tuo: "urn:iso..." jne. osuus on vain sitä tarvetta varten JOS halutaan jollakin ulkopuolisella testiohjelmalla testata vaikak tuon Nordean XML:n sisältöä, niin silloin etsitään käsiin kyseisen Namespacen sisältävä XSD-Schematiedosto, ja sitä vasten sitten tarkistetaan?

        Tätäkö tämä kaikki lyhykäisyydessään tarkoittaa?

        Tähän meneessä olen siis onnistuneesti oppinut pelaamaan noiden SEPA-failien kanssa, mutta minä vain sokkona laitan tuon urn-osuuden sellaisenaan aina XML:n alkuun. Mutta en ymmärrä hölkkäsen pöläystä sen merkiyksestä. Siis että kuka, ja missä vaiheessa sitä tietoa tarvistee ja sen lukee.


      • xmlxml
        Lasse777 kirjoitti:

        >Erikseen on validaattorit, millä testataan, että xml-doc vastaa xml-schemaa (schema
        >luetaan xml-docin schemaLocation-arvosta joten sen on syytä olla siellä). Selaimet
        >ei lue/tarvi schemaa.
        >Jotkut testityökalut voi myös tarvita schemaa (tekee sen perusteella xml-docin),
        >samoin esim. weblogicin kanssa kehitystyössä tarvitaan schemoja, mitkä on
        >talletettava ko paikkaan.

        Jonkin verran olen itsekin päässyt tässä asiassa viime kuukauden tarpomisen perästä eteenpäin.

        XML-esimerkkitiedostona vaikka tässä Nordean linkissä oleva yksi XML-tiedosto:
        http://www.nordea.fi/sitemod/upload/root/fi_org/liite/Yrityksen_maksut_esimerkit.xml

        Tuossakin XML:n alussa on tämän tyyppinen urn-loitsu:
        ""

        Siis onko niin että normaalikäytössä selain ei ikinä välitä mitään mitä tämä teksti sisältää? Eikä yritä haeskella mitään Schema-tiedostojakaan, ei siis tuosta osoitteesta, eikä mistään namespacesta eikä koneen paikallisesta Schema Cachesta, eikä siis mistään?? Eli siis kyseistä tiedostoa ei tarviste olla käsillä eikä mistään selaimelle ladattavissa tms?

        Ja silloin siis kaikki tuo: "urn:iso..." jne. osuus on vain sitä tarvetta varten JOS halutaan jollakin ulkopuolisella testiohjelmalla testata vaikak tuon Nordean XML:n sisältöä, niin silloin etsitään käsiin kyseisen Namespacen sisältävä XSD-Schematiedosto, ja sitä vasten sitten tarkistetaan?

        Tätäkö tämä kaikki lyhykäisyydessään tarkoittaa?

        Tähän meneessä olen siis onnistuneesti oppinut pelaamaan noiden SEPA-failien kanssa, mutta minä vain sokkona laitan tuon urn-osuuden sellaisenaan aina XML:n alkuun. Mutta en ymmärrä hölkkäsen pöläystä sen merkiyksestä. Siis että kuka, ja missä vaiheessa sitä tietoa tarvistee ja sen lukee.

        Ei tavallinen selain lue schemoja. Periaatteessa xml-doceissa/schemoissa pitää olla ne alun määritykset (w3-standardinamespace ja sitten se omat local-namespacet) ja tietenkin xml-speksin mukaiset elementit. xml-docin oikeellisuutta tarvitsee varmasti tuotekehitysvaiheessa verrata schemaan (kuten sepan urn:pain ja mitenkäs sen löytäisi ilman tätä määritystä) ja kuten sanottu documentin validisuus schemaan nähden pitäisi tarkistaa jollain automaattitestauksella (xmlspy:llakin taitaa onnistua).

        Joku spesifinen client-ohjelma (kuten soap) voi vaatia ja lukea schemaa ja wsdl:ää lokaalisti (esim soapui:lla voi testata soapia, kun on wsdl ja mahdollinen schemafile, tai se voi määriteltynä olla wsdln sisälläkin), mutta vastausviestin tarkistus on manuaalinen.

        Selain sitten tarvitsee yleensä xslt-muunnoksen (tai cssn) että xml-doc näkyy helposti ihmisen luettavassa muodossa.


      • Lasse777
        xmlxml kirjoitti:

        Ei tavallinen selain lue schemoja. Periaatteessa xml-doceissa/schemoissa pitää olla ne alun määritykset (w3-standardinamespace ja sitten se omat local-namespacet) ja tietenkin xml-speksin mukaiset elementit. xml-docin oikeellisuutta tarvitsee varmasti tuotekehitysvaiheessa verrata schemaan (kuten sepan urn:pain ja mitenkäs sen löytäisi ilman tätä määritystä) ja kuten sanottu documentin validisuus schemaan nähden pitäisi tarkistaa jollain automaattitestauksella (xmlspy:llakin taitaa onnistua).

        Joku spesifinen client-ohjelma (kuten soap) voi vaatia ja lukea schemaa ja wsdl:ää lokaalisti (esim soapui:lla voi testata soapia, kun on wsdl ja mahdollinen schemafile, tai se voi määriteltynä olla wsdln sisälläkin), mutta vastausviestin tarkistus on manuaalinen.

        Selain sitten tarvitsee yleensä xslt-muunnoksen (tai cssn) että xml-doc näkyy helposti ihmisen luettavassa muodossa.

        Thanksit selvennyksistä.

        >Joku spesifinen client-ohjelma (kuten soap) voi vaatia ja lukea schemaa ja wsdl:ää
        >lokaalisti (esim soapui:lla voi testata soapia, kun on wsdl ja mahdollinen schemafile,
        >tai se voi määriteltynä olla wsdln sisälläkin), mutta vastausviestin tarkistus on manuaalinen.

        Osin menee yli hilseen..., lienet itse Java-koodari? Ja meikäläinen Win32:lle raapii koodia. Tuota WSDL:ää ei onneksi mainita missään Sepaan liittyvissä jutuissa lainkaan, on vain pelkkä XSD-schematiedostoa vastaan tarkistus, ja se alkaa jo hoitua.

        Sen sijaan WSDL-määritykset mainitaan samaan SEPA-soppaan liittyvän pankkien Web Servicesin yhteydessä. Siellä on vielä perkaamatonta ja tutkimatonta tonttia riittämiin meikälle:(


    • schema

      Moro!
      Varsin mielenkiintoinen viestiketju, mutta lopputulema jäi uupumaan eli miten kävi saitko xml maksuaineiston muodostettua?

      • Lasse777

        >mutta lopputulema jäi uupumaan eli miten kävi saitko xml maksuaineiston
        >muodostettua?

        No totta mooses! Niitä alkoi syntyä ja hommat kukkua. Alun perinkään ei ollut itse XML-tiedoston muodostamisen kanssa mitään ohjelmateknisiä ongelmia.

        En vain ollut perillä mitä nuo lukuisat viittaukset SEPA-tiedoston headerissa oikein tarkoittavat. Missä fyysisesti sijaitseviin "urn:iso:std:iso:20022:tech:xsd:pain.001.001.02" tms. nimisiin tiedostoihin ne oikein viittaavat jne.

        Kun tuon mössön logiikka alkoi hissuksiin ja riittävässä määrin avautua, niin kyllä Sepa-maksutiedostoja on syntynyt. Ja ainakin muutamia kymmeniä eri ihmisiä niillä nytkin eri paikoissa makselee firmansa laskuja.


    • iban schema xls

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

    Luetuimmat keskustelut

    1. Mistä puhuitte viimeksi kun näitte

      Kerro yksi aiheista
      Ikävä
      107
      7763
    2. 112
      6026
    3. Se on hyvästi

      Toivottavasti ei tavata.
      Ikävä
      83
      5177
    4. Olenko saanut sinut koukkuun?

      Hyvä. Rakastan sua.
      Ikävä
      139
      4546
    5. Alavuden sairaala

      Säästääkö Alavuden sairaala sähkössä. Kävin Sunnuntaina vast. otolla. Odotushuone ja käytävä jolla lääkäri otti vastaan
      Ähtäri
      11
      3220
    6. Sisäsiittosuus

      Tämän kevään ylioppilaista 90% oli sama sukunimi?
      Suomussalmi
      59
      2997
    7. Miksi sä valitsit

      Juuri minut sieltä?
      Ikävä
      58
      2938
    8. Törkeää toimintaa

      Todella törkeitä kaheleita niitä on Ylivieskassakin. https://www.ess.fi/uutissuomalainen/8570818
      Ylivieska
      10
      2454
    9. Kerro nyt rehellisesti fiilikset?

      Rehellinem fiilis
      Suhteet
      61
      2437
    10. Hei........

      Pelkkä sun näkeminen saa mut hymyilemään pitkin iltaa. Oot niin 🤩😘 Edellinen poistettiin.
      Ikävä
      56
      2066
    Aihe