用python实现微信刷点击率的示例代码-泓源视野

用python实现微信刷点击率的示例代码

用python实现刷点击率的示例代码

今天小编就为大家分享一篇用python实现刷点击率的示例代码,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

背景

同事的老爸参加微信的一个活动,需要刷点击率,因此,写了一个程序助之。

准备

微信活动也是有真实地址的。

通过mitmproxy(man in the middle proxy)的方式,可以获取微信获取网页的真实地址(url)。

完整可运行代码  python2 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
import os
import time
import argparse
import platform
def visit_win(url, times, duration):
import urllib2
def _visit_win():
try:
s = urllib2.urlopen(url).read()
except urllib2.HTTPError,e:
print (e.code)
for i in range(times):
_visit_win()
print("{} Done!".format(i+1))
#do not use duration in win
def visit_linux(url, times, duration):
import subprocess
cmd = "curl {}".format(url)
for i in range(times):
subprocess.Popen(cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE,shell=True)
print("{} Done!".format(i+1))
time.sleep(duration)
def parse_input():
input_parser = argparse.ArgumentParser()
input_parser.add_argument("--url",'-u', help="the url your need to visit")
input_parser.add_argument("--times",'-t', type=int, default=10, help="how many times you need to visit")
input_parser.add_argument("--duration",'-d', default=0.5, type=float, help="the duration between two visits")
input_args = input_parser.parse_args()
url = input_args.url
times = input_args.times
duration = input_args.duration
return url, times, duration
def main():
url, times, duration = parse_input()
if platform.system().lower() == 'linux':
visit_linux(url, times, duration)
else:
visit_win(url, times, duration)
print("My evil job is finished!")
if __name__ == '__main__':
main()

import os
import time
import argparse
import platform

def visit_win(url, times, duration):
import urllib.request, urllib.error, urllib.parse
def _visit_win():
try:
s = urllib.request.urlopen(url).read()
except urllib.error.HTTPError as e:
print((e.code))
for i in range(times):
_visit_win()
print(("{} Done!".format(i+1)))
#do not use duration in win

def visit_linux(url, times, duration):
import subprocess
cmd = "curl {}".format(url)
for i in range(times):
subprocess.Popen(cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE,shell=True)
print(("{} Done!".format(i+1)))
time.sleep(duration)

def parse_input():
input_parser = argparse.ArgumentParser()
input_parser.add_argument("--url",'-u', help="the url your need to visit")
input_parser.add_argument("--times",'-t', type=int, default=15, help="how many times you need to visit")
input_parser.add_argument("--duration",'-d', default=2.5, type=float, help="the duration between two visits")
input_args = input_parser.parse_args()
url = input_args.url
times = input_args.times
duration = input_args.duration
return url, times, duration

def main():
url, times, duration = parse_input()
if platform.system().lower() == 'linux':
visit_linux(url, times, duration)
else:
visit_win(url, times, duration)
print("My evil job is finished!")

if __name__ == '__main__':
main()

运行的话python3 click.py -u https://byy3.com -t10 -d10

说明-t代表刷点击的次数   -d代表每次时间间隔

我的说明  可以配合contab创建一个cron.sh 和一个shell配置好放到服务器中。

跨平台

linux通过curl可以非常快速的访问。

但是同事不懂linux,只能通过urllib库写个跨平台的实现

可扩展性

为了增加程序的通用性,加入argparse库,通过程序入参实现灵活应用。

**注意:

推荐使用argparse,WXCOP的很多同学还是使用老的OPTPARSE库,argparse是用来替代OPTPARSE库的(来自官方)**

 

速度

使用subprocess库会比os.system的方式快,因为,它会fork一个进程,而os.system是阻塞(等待网页返回很慢),速度快很多。

另外,保留了linux的curl方式,它比urllib库要快

函数内的函数

visit_win里还有一个只能内部使用的_visit_win

这样可以表明这个函数的作用域

库的导入

没有呆板的在开头导入所有需要的库,而是根据操作系统,在需要时,才导入特定的库

期望大家的优化

代码里留了优化空间,例如使用线程的方式加快urllib的访问速度等

最后

我写python好几年了,有很多积累,欢迎python爱好者一起交流。

以上这篇用python实现刷点击率的示例代码就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

本文由 泓源视野 作者:admin 发表,其版权均为 泓源视野 所有,文章内容系作者个人观点,不代表 泓源视野 对观点赞同或支持。如需转载,请注明文章来源。
0

发表评论

Protected with IP Blacklist CloudIP Blacklist Cloud
您是第8237307 位访客, 您的IP是:[54.161.98.96]