Onko mahdollista päästä verkkosivuille HTTPS: n avulla ja jotka vaativat sisäänkirjautumisen / salasanan Excelillä? No, kyllä ja ei. Tässä on sopimus ja miksi se ei ole niin suoraviivaista.
Ensinnäkin määritellään ehdot
HTTPS on sopimuksen mukaan tunnus, jota kutsutaan SSL (Secure Sockets Layer). Sillä ei oikeastaan ole mitään tekemistä salasanojen tai kirjautumisten kanssa sellaisenaan. Mitä SSL tekee, se muodostaa salatun yhteyden web-asiakkaan ja palvelimen välille, jotta mitään tietoa ei lähetetä näiden kahden välillä "selkeästi" - käyttämällä salaamattomia lähetyksiä. Jos tietoihin sisältyy kirjautumis- ja salasanatiedot, siirron salaus suojaa niitä uteliailta silmiltä... mutta salasanojen salaus ei ole vaatimus. Käytin ilmausta "sopimuksen mukaan", koska todellinen tietoturvatekniikka on SSL. HTTPS antaa vain palvelimelle signaalin, jota asiakas aikoo käyttää kyseistä protokollaa. SSL: ää voidaan käyttää monilla muilla tavoilla.
Joten... jos tietokoneesi lähettää URL-osoitteen palvelimelle, joka käyttää SSL: tä ja että URL alkaa merkillä HTTPS, tietokoneesi sanoo palvelimelle:
"Hei herra Server, ravistakaamme käsiä tämän salauksen suhteen, jotta mitä tahansa sanomme tästä eteenpäin, se ei tarttuisi jollekin pahalle kaverille. Ja kun se on valmis, siirry eteenpäin ja lähetä minulle URL-osoitteen osoittava sivu. "
Palvelin lähettää takaisin keskeiset tiedot SSL-yhteyden muodostamiseksi. Tietokoneesi on itse tehtävä jotain sen kanssa.
Se on "avain" (pun... hyvin, sorta tarkoitettu) ymmärtää VBA Excelissä. VBA: n ohjelmoinnin pitäisi itse asiassa suorittaa seuraava askel ja toteuttaa SSL asiakaspuolella.
'Oikeat' selaimet tekevät sen automaattisesti ja osoittavat tilariville pienen lukon symbolin osoittamaan, että se on tehty. Mutta jos VBA avaa vain verkkosivun tiedostona ja lukee siinä olevat tiedot laskentataulukon soluihin (erittäin yleinen esimerkki), Excel ei tee sitä ilman ylimääräisiä ohjelmointeja. Excel huomaa vain, että palvelimen armollinen tarjous kättelemistä ja suojatun SSL-viestinnän perustamista ei ohita.
Mutta voit lukea pyytämäsi sivun aivan samalla tavalla
Todistaaksemme sen, käytämme Googlen Gmail-palvelun käyttämää SSL-yhteyttä (joka alkaa "https") ja koodaamme puhelun avataksesi yhteyden samalla tavalla kuin se oli tiedosto.
Tämä lukee verkkosivun kuin se olisi yksinkertainen tiedosto. Koska viimeisimmät Excel-versiot tuovat HTML-koodin automaattisesti, kun Open-käsky on suoritettu, Gmail-sivu (vähennettynä dynaamisilla HTML-objekteilla) tuodaan taulukkoon. SSL-yhteyksien tavoitteena on vaihtaa tietoja, ei vain lukea verkkosivuja, joten tämä ei normaalisti johda sinut kovin kaukana.
Jotta voisit tehdä enemmän, sinun on oltava Excel VBA -ohjelmassa jollain tavalla tuki sekä SSL-protokollaa että ehkä myös DHTML-tukea. Olet todennäköisesti parempi aloittaa kokonaan Visual Basic eikä Excel VBA. Käytä sitten säätimiä, kuten Internet Transfer API WinInet, ja kutsu Excel-objekteja tarvittaessa. Mutta WinInetiä on mahdollista käyttää suoraan Excel VBA -ohjelmasta.
WinInet on sovellusohjelmointirajapinta WinInet.dll -sovellukseen. Sitä käytetään pääasiassa yhtenä Internet Explorerin tärkeimmistä komponenteista, mutta voit käyttää sitä myös suoraan koodistasi ja HTTPS: ään. Koodin kirjoittaminen WinInet-käyttöä varten on ainakin keskivaikea tehtävä. Yleensä vaiheet ovat seuraavat:
- Yhdistä HTTPS-palvelimeen ja lähetä HTTPS-pyyntö
- Jos palvelin pyytää allekirjoitettua asiakasvarmennetta, lähetä pyyntö uudelleen, kun olet liittänyt varmenneyhteyden
- Jos palvelin on tyytyväinen, istunto todennetaan
WinInet-koodin kirjoittamisessa käyttämään https: ää tavallisen HTTP: n sijasta on kaksi suurta eroa:
Sinun tulisi myös pitää mielessä, että sisäänkirjautumisen / salasanan vaihtaminen on loogisesti riippumaton istunnon salaamisesta https: n ja SSL: n avulla. Voit tehdä yhden tai toisen, tai molemmat. Monissa tapauksissa he käyvät yhdessä, mutta eivät aina. Ja WinInet-vaatimusten toteuttaminen ei tee mitään vastatakseen automaattisesti kirjautumis- / salasanapyyntöihin. Jos esimerkiksi käyttäjätunnus ja salasana ovat osa web-lomaketta, sinun on ehkä selvitettävä kenttien nimet ja päivitä kentät Excel VBA: sta ennen kirjautumisjonon "lähettämistä" palvelimelle. Oikein reagoiminen verkkopalvelimen tietoturvaan on suuri osa selaimen tekemistä. Toisaalta, jos vaaditaan SSL-todennus, voit harkita InternetExplorer-objektin käyttöä sisäänkirjautumiseen VBA: n sisällä ...
Tärkeintä on, että https: n käyttäminen ja palvelimelle kirjautuminen Excel VBA -ohjelmasta on mahdollista, mutta älä odota kirjoittavan koodin, joka tekee sen muutamassa minuutissa.