Envoyer SMS par feuille excel via Macro - CODE EXISTANT à modifier

PatLac

XLDnaute Occasionnel
Bonjour à tous !
Je désire envoyer des SMS par l'intermédiaire d'une macro inclue dans une feuille Excel.:)

J'ai 2 codes : un qui fonctionne, et l'autre pas.

Celui qui fonctionne à une coût/SMS plus important que celui qui ne fonctionne pas :(

Je voudrais bien sur utiliser celui qui ne fonctionne actuellement pas , car 2 fois moins cher que celui qui fonctionne. :confused:

Je sollicite vos capacités en VBA pour m'aider.

Je mets ci-dessous les 2 codes et vous remercie pour votre bienséance.
Cordiales salutations.

Code fonctionnel
Code:
Sub SendSMS()

    Dim strReturn As String
    Dim Apikey As String
    Dim Number As String
    Dim Message As String
    Dim Expediteur As String
    Dim i As Integer
    
    Apikey = "VotreApiKey"
    
    Message = Worksheets("Feuil1").Cells(2, 2).Value
    Expediteur = Worksheets("Feuil1").Cells(1, 2).Value
    
    i = 5
    While (Worksheets("Feuil1").Cells(i, 1).Value <> "")
    
        Worksheets("Feuil1").Cells(i, 2).Value = ""
        Number = Worksheets("Feuil1").Cells(i, 1)
        strReturn = send(Apikey, Number, URLEncode(Message), URLEncode(Expediteur), False)
        Worksheets("Feuil1").Cells(i, 2).Value = strReturn
        i = i + 1
    Wend
End Sub

Function send(Apikey, Number, Message, Expediteur, MsgID) As String
    Dim objWinHTTP As Object
    Dim strReturn As String
    Dim Request As String
    Dim url As String

    Set objWinHTTP = CreateObject("WinHttp.WinHttpRequest.5.1")

    url = "http://www.envoyersms.org/api/v1/?method=send"
    Request = "&apikey=" & URLEncode(Apikey) & "&number=" & URLEncode(Number)
    Request = Request & "&message=" & URLEncode(Message)
    Request = Request & "&expediteur=" & URLEncode(Expediteur) & "&msg_id=" & MsgID

    objWinHTTP.Open "GET", url & Request, False
    objWinHTTP.SetTimeouts 30000, 30000, 30000, 30000
    objWinHTTP.send
    If objWinHTTP.StatusText = "OK" Then
        strReturn = objWinHTTP.ResponseText
        Debug.Print strReturn
    End If

    Set objWinHTTP = Nothing
    send = strReturn
End Function


Public Function URLEncode(sRawURL) As String
    On Error GoTo Catch
    Dim iLoop As Integer
    Dim sRtn As String
    Dim sTmp As String
    Const sValidChars = "1234567890ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz:/.?=_-$()~&"
    If Len(sRawURL) > 0 Then
        For iLoop = 1 To Len(sRawURL)
            sTmp = Mid(sRawURL, iLoop, 1)
            If InStr(1, sValidChars, sTmp, vbBinaryCompare) = 0 Then
                sTmp = Hex(Asc(sTmp))
                If sTmp = "20" Then
                    sTmp = "+"
                ElseIf Len(sTmp) = 1 Then
                    sTmp = "%0" & sTmp
                Else
                    sTmp = "%" & sTmp
                End If
            End If
            sRtn = sRtn & sTmp
        Next iLoop
        URLEncode = sRtn
    End If
Finally:
        Exit Function
Catch:
        URLEncode = ""
        Resume Finally
End Function

Code NON-FONCTIONNEL que vous pouvez retrouver ici également
Code:
Imports System.Diagnostics.CodeAnalysis
Imports System.Security.Principal
Imports System.Web.Routing
Imports System.Net
Imports System.IO
Imports System.Xml
 
 
Const ENVOYER_SMS_PRO_HOST As String = "www.envoyersmspro.com"
Const ENVOYER_SMS_PRO_PROTOCOL As String = "https://"
Const ENVOYER_SMS_PRO_LOGIN As String = ""
Const ENVOYER_SMS_PRO_PASSWORD As String = ""
Const ENVOYER_SMS_PRO_URL As String = "/api/message/send"
 
Dim strPost As String
' Build POST String
strPost = "text=" + System.Web.HttpUtility.UrlEncode("Nouveau message via l'API d'Envoyer SMS Pro depuis un script VB .NET") + "&recipients=" + System.Web.HttpUtility.UrlEncode("33600000000") + "&sendername=" + System.Web.HttpUtility.UrlEncode("SOCIETE")
 
' Create POST
Dim request As WebRequest = WebRequest.Create(ENVOYER_SMS_PRO_PROTOCOL + ENVOYER_SMS_PRO_HOST + ENVOYER_SMS_PRO_URL)
request.Method = "POST"
Dim byteArray As Byte() = Encoding.UTF8.GetBytes(strPost)
 
Dim myCred As New NetworkCredential(ENVOYER_SMS_PRO_LOGIN, ENVOYER_SMS_PRO_PASSWORD, "")
 
request.ContentType = "application/x-www-form-urlencoded"
request.Credentials = myCred
request.ContentLength = byteArray.Length
Dim dataStream As Stream = request.GetRequestStream()
dataStream.Write(byteArray, 0, byteArray.Length)
dataStream.Close()
' Get the response.
Dim response As WebResponse = request.GetResponse()
dataStream = response.GetResponseStream()
Dim reader As New StreamReader(dataStream)
Dim responseFromServer As String = reader.ReadToEnd()
' Clean upthe streams.
reader.Close()
dataStream.Close()
response.Close()
' Return result to calling function
If responseFromServer.Length > 0 Then
    Dim textResponse As String
    ' Create an XmlReader
    Using readerXML As XmlReader = XmlReader.Create(New StringReader(responseFromServer))
        readerXML.ReadToFollowing("status")
        If readerXML.ReadElementContentAsString() = "success" Then
            readerXML.ReadToFollowing("message_id")
            textResponse = "Le messageid : " + readerXML.ReadElementContentAsString()
        Else
            textResponse = "Impossible d'envoyer le message"
            While readerXML.Read()
                ' Check for start elements.
                If readerXML.IsStartElement() Then
                    ' See if perls element or article element.
                    If readerXML.Name = "request" Then
                        textResponse += "La requête : " + readerXML.ReadElementContentAsString + ControlChars.NewLine
                        textResponse += "L'errorid : " + readerXML.ReadElementContentAsString + ControlChars.NewLine
                        textResponse += "L'error message : " + readerXML.ReadElementContentAsString + ControlChars.NewLine
                    End If
                End If
            End While
        End If
    End Using
    ViewData("Message") = textResponse
Else
    ViewData("Message") = CType(response, HttpWebResponse).StatusDescription
End If

:)
 

Staple1600

XLDnaute Barbatruc
Bonjour fanch55

[Suggestion en passant avant l'apéro du samedi]
En ces temps de COVID, j'encourage Escouger a créer sa propre discussion.
Ainsi , on évitera les miasmes de 2013 et on repartirta sur de bonnes bases, cellules grandes ouvertes pour aérer le Tableur
[/Suggestion en passant avant l'apéro du samedi]
 

soan

XLDnaute Barbatruc
Inactif
Bonsoir BrunoM45, Staple, fanch, le fil,

tu as écrit : « Désolé, je n'ai pas compris l'allusion 🤔 »

comme au début tes 2 autres smileys 😜 😂 étaient collés tout contre 🤔 j'ai cru que c'était ironique, et que tu plaisantais ; puis j'ai vu ta phrase : « Moi son avatar je le vois blanc » ; alors j'ai compris qu'c'était pas ironique ; mais là, j'comprends pas, car moi j'ai ceci :​

Image 1.jpg


j'ai seulement tronqué la largeur de l'image pour qu'elle prenne moins de place, y'a pas d'autre retouche d'image ! tu comprends maint'nant pourquoi j'ai dit qu'j'ai cru qu'c'était toi ! mébon, comme t'as écrit qu'y'a pas d'royalties sur l'œil na'vi de ton avatar, no problem ! :D faudra juste que j'fasse attention d'pas confondre les différents schtroumpfs ! suggestion : comme tu peux pas mettre un avatar de la schtroumpfette, tu peux pas mettre un avatar de celui avec son bonnet rouge ? oui, c'est ça, le Grand Schtroumpf ; j'dis pas qu'ça t'rajeunira, mais tu pourras bénéficier de sa grande sagesse, acquise au bout de longues années d'expérience ; tu pourras aussi nous préparer quelques unes de tes potions, qui sont des applications directes de tes formules Excel lues dans tes anciens grimoires d'alchimie ; sauf que j'préfère quand même la salsepareille et le jus d'framboise ! 😋 😋 😋 attention quand même :

Image 2.jpg




j'adore ta phrase : « rien n'est plus gratuit dans ce monde :( arf si, l'aide sur les forums ✌️ » ; ah ben voilà ! t'as enfin trouvé l'explication du mystère du crossposting ! (celui que t'aime tant !) 🤪 😂 🤣

réponse de Bruno : il vaut mieux éviter les sujets qui fâchent ! 😜 😅 😂 🤣

soan
 
Dernière édition:
C

Compte Supprimé 979

Guest
j'adore ta phrase : « rien n'est plus gratuit dans ce monde :( arf si, l'aide sur les forums ✌️ » ; ah ben voilà ! t'as enfin trouvé l'explication du mystère du crossposting ! (celui que t'aime tant !) 🤪 😂 🤣
@soan, juste à ce sujet ;) qui ne me fache pas du tout 😂

Pour moi le crossposting, c'est tout bonnement un manque d'éducation et surtout de respect vis à vis des bénévoles que nous sommes :eek:

Et la réponse : "je le fais car j'obtiens plus de réponses sur lesquelles me baser"
à mes yeux c'est juste du pipi de chat 🤮 c'est tout bonnement que les gens sont pressés et veulent avoir des réponses rapides 🤬 à ça moi je dis FCK 😜
 

soan

XLDnaute Barbatruc
Inactif
@BrunoM45

oui, c'est une façon de voir ; moi non plus, je n'aime pas trop le crossposting, mais d'un autre côté, j'me dis qu'on est en démocratie, et que si un « client » (un membre) choisit d'aller « faire ses courses » chez Leclerc (par exemple sur le site Excel-Pratique), on n'a aucun droit de lui dire : « puisque vous êtes allés chez Leclerc, vous n'avez plus le droit d'aller faire des courses chez Carrefour (le site CommentÇaMarche) ou chez Cora (le site XLD) » ; mais à condition, bien sûr, qu'il n'oublie pas de prévenir sur les autres forums que ce n'est plus la peine de chercher s'il a trouvé une solution qui lui convient ; avec ce bémol : s'il a envie d'avoir plusieurs réponses différentes, pour pouvoir les comparer et choisir la réponse qu'il préfère, pourquoi pas ? il ne restera plus alors qu'un seul gros problème : s'il n'arrive pas à choisir entre les différentes solutions, est-ce que tu seras d'accord pour bien vouloir l'aider à choisir ? 😁 😜 😂 🤣 non, Bruno, tu n'as pas le droit d'étrangler le « client » ! 😱 😱 😱 😱 David préfère si tu peux préserver la santé des membres et autres visiteurs du site XLD ! 😄 😄 😄 😄

soan
 

Staple1600

XLDnaute Barbatruc
Bonjour le fil

[Pour infos]
Et dans la série [Oncle Staple raconte]
Avant l'internet d'aujourd'hui, il y avait l'internet d'hier
La nétiquette est une règle informelle, puis une charte qui définit les règles de conduite et de politesse recommandées sur les premiers médias de communication mis à disposition par Internet. Il s'agit de tentatives de formalisation d'un certain contrat social pour Internet.

Le premier document officiel définissant les règles de la nétiquette est la RFC 18551, rédigée par Sally Hambridge (de chez Intel) pour l'Internet Engineering Task Force, et diffusée en octobre 1995. D'autres documents font aussi autorité, comme Netiquette2 (Virginia Shea, 1994) et The Net : Users guidelines and netiquette3 (Arlene Rinaldi, 1996).
Il est toujours bon de savoir d'où on vient.
Pour les curieux (et/ou les moins de 20 ans)
Take me back in 1995
[/Oncle Staple raconte]

NB: Rien n'empêche de signaler qu'on a posé sa question à plusieurs endroits (et le cas échéant de mettre un lien vers les principaux sites)

Quant à la démocratie...Vu qu'elle n'entrave que dalle à Excel, ce n'est ni le lieu, ni l'endroit pour une autre histoire d'Oncle Staple

PS: Escourger a du faire une crise d'asthme avec la poussière de 2013.
;)
J'ai point vu de nouvelle discussion relative aux SMS s'affichée sur XLD.
 

Discussions similaires

Réponses
2
Affichages
577
Réponses
6
Affichages
543

Statistiques des forums

Discussions
314 499
Messages
2 110 247
Membres
110 711
dernier inscrit
chmessi