2

我一直在尝试使用way2sms 发送免费短信。我发现这个链接似乎适用于 python 3:https ://github.com/shubhamc183/way2sms

我已将此文件保存为 way2sms.py:

import requests
from bs4 import BeautifulSoup

class sms:

def __init__(self,username,password):

    '''
    Takes username and password as parameters for constructors
    and try to log in
    '''

    self.url='http://site24.way2sms.com/Login1.action?'

    self.cred={'username': username, 'password': password}

    self.s=requests.Session()           # Session because we want to maintain the cookies

    '''
    changing s.headers['User-Agent'] to spoof that python is requesting
    '''

    self.s.headers['User-Agent']="Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:50.0) Gecko/20100101 Firefox/50.0"

    self.q=self.s.post(self.url,data=self.cred)

    self.loggedIn=False             # a variable of knowing whether logged in or not

    if "http://site24.way2sms.com/main.action" in self.q.url:           # http status 200 == OK

        print("Successfully logged in..!")

        self.loggedIn=True

    else:

        print("Can't login, once check credential..!")

        self.loggedIn=False

    self.jsid=self.s.cookies.get_dict()['JSESSIONID'][4:]       # JSID is the main KEY as JSID are produced every time a session satrts

def msgSentToday(self):

    '''
    Returns number of SMS sent today as there is a limit of 100 messages everyday..!
    '''

    if self.loggedIn == False:
        print("Can't perform since NOT logged in..!")
        return -1

    self.msg_left_url='http://site24.way2sms.com/sentSMS?Token='+self.jsid

    self.q=self.s.get(self.msg_left_url)

    self.soup=BeautifulSoup(self.q.text,'html.parser')      #we want the number of messages sent which is present in the

    self.t=self.soup.find("div",{"class":"hed"}).h2.text        # div element with class "hed" -> h2

    self.sent=0

    for self.i in self.t:

        if self.i.isdecimal():

            self.sent=10*self.sent+int(self.i)

    return self.sent

def send(self,mobile_no,msg):

    '''
    Sends the message to the given mobile number
    '''

    if self.loggedIn == False:
        print("Can't perform since NOT logged in..!")
        return False

    if len(msg)>139 or len(mobile_no)!=10 or not mobile_no.isdecimal(): #checks whether the given message is of length more than 139

        return False                            #or the mobile_no is valid

    self.payload={'ssaction':'ss',
            'Token':self.jsid,                  #inorder to visualize how I came to these payload,
                'mobile':mobile_no,                 #must see the NETWORK section in Inspect Element
                 'message':msg,                     #while messagin someone from your browser
                'msgLen':'129'
                 }

    self.msg_url='http://site24.way2sms.com/smstoss.action'

    self.q=self.s.post(self.msg_url,data=self.payload)

    if self.q.status_code==200:

        return True

    else:
        return False

def sendLater(self, mobile_no, msg, date, time):                #Function for future SMS feature.
                                        #date must be in dd/mm/yyyy format
                                        #time must be in 24hr format. For ex: 18:05

    if self.loggedIn == False:
        print("Can't perform since NOT logged in..!")
        return False

    if len(msg)>139 or len(mobile_no)!=10 or not mobile_no.isdecimal():
        return False

    dateparts = date.split('/')         #These steps to check for valid date and time and formatting
    timeparts = time.split(':')
    if int(dateparts[0])<1 or int(dateparts[0])>32 or int(dateparts[1])>12 or int(dateparts[1])<1 or int(dateparts[2])<2017 or int(timeparts[0])<0 or int(timeparts[0])>23 or int(timeparts[1])>59 or int(timeparts[1])<0:
        return False
    date = dateparts[0].zfill(2) + "/" + dateparts[1].zfill(2) + "/" + dateparts[2]
    time = timeparts[0].zfill(2) + ":" + timeparts[1].zfill(2)

    self.payload={'Token':self.jsid,
            'mobile':mobile_no,
            'sdate':date,
            'stime':time,
            'message':msg,
            'msgLen':'129'
            }

    self.msg_url='http://site24.way2sms.com/schedulesms.action'
    self.q=self.s.post(self.msg_url, data=self.payload)

    if self.q.status_code==200:
        return True
    else:
        return False

def logout(self):

    self.s.get('http://site24.way2sms.com/entry?ec=0080&id=dwks')

    self.s.close()                              # close the Session

    self.loggedIn=False

并将另一个文件保存为 smsing.py:

import way2sms
q=way2sms.sms(1234567890,'password') #username = 1234567890
q.send('0987654321','hello') #receiver ph no.:0987654321, message=hello
n=q.msgSentToday()
q.logout()

-我尝试将用户名作为字符串传递,否则。如果未以字符串形式给出密码,则会显示错误。我的用户名和密码都是正确的。当我执行 smsing.py... 时显示:

>>>Can't login, once check credential..!
Can't perform since NOT logged in..!
Can't perform since NOT logged in..!

有了这么简单的代码,我认为这很容易。但我无法找到哪里出错了。是因为我使用的是Windows 7吗?有人可以帮帮我吗?

4

3 回答 3

2

sms使用way2sms帐户发送,您可以使用以下代码段。

在此之前,您需要Key此处创建 API

import requests
url = "https://smsapi.engineeringtgr.com/send/"
params = dict(
    Mobile='login username',
    Password='login password',
    Key='generated from above sms api',
    Message='Your message Here',
    To='recipient')

resp = requests.get(url, params)
print(resp, resp.text)

注意:每天限制为约 20 条短信

于 2018-11-12T12:48:57.267 回答
0

首先确保您拥有所有依赖项,例如请求和 bs4,如果不尝试使用 pip3 下载它们,因为此代码适用于 Python3而不是python2。

我已经更新了存储库

手机号码也应该是字符串格式

所以,而不是

q=way2sms.sms(1234567890,'password') #username = 1234567890

利用

q=way2sms.sms('1234567890','password') #username = 1234567890
于 2018-07-15T12:31:15.470 回答
0
import requests

url = "https://www.fast2sms.com/dev/bulk"

payload = "sender_id=FSTSMS&message=Good morning , this is prasad  sending from python.&language=english&route=p&numbers=9052766763,7013514480"

headers = {

'authorization': "your app key",

'Content-Type': "application/x-www-form-urlencoded",

'Cache-Control': "no-cache",

}

response = requests.request("POST", url, data=payload, headers=headers)

print(response.text)
于 2019-03-05T06:57:12.333 回答