2024年最全一起用python做个炫酷音乐播放器,想听啥随便搜!【V2,2024年最新网络安全开发知识体系

给大家的福利

零基础入门

对于从来没有接触过网络安全的同学,我们帮你准备了详细的学习成长路线图。可以说是最科学最系统的学习路线,大家跟着这个大的方向学习准没问题。

同时每个成长路线对应的板块都有配套的视频提供:

在这里插入图片描述

因篇幅有限,仅展示部分资料

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化资料的朋友,可以点击这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

     self.work.start()
     self.work.trigger.connect(self.disdownall)
 except:
     print('默认图片下载错误')
     pass

下载搜索页列表所有音乐

def downloadalls(self):
self.downloadall(‘boing’)

下载喜爱的歌列表所有音乐

def downloadalllove(self):
self.downloadall(‘love’)


**添加喜爱的歌:**


对于添加喜爱的歌曲,我们可以通过当前播放音乐的❤标志,也可以通过右键音乐列表进行喜爱的歌曲添加。核心代码如下:



通过点击❤标志,对当前播放音乐添加喜爱的歌

def lovesong(self):
if bo == ‘boing’ or bo == ‘boed’:
try:
global loves
global loveurls
global lovepics
global lovelrc
if bo == ‘boing’:
loves.append(songs[num])
loveurls.append(urls[num])
lovepics.append(pic[num])
lovelrc.append(lrcs[num])
elif bo == ‘boed’:
loves.append(songed[num])
loveurls.append(urled[num])
lovepics.append(picd[num])
lovelrc.append(lrcd[num])
else:
pass
except:
pass
self.work = firstThread()
self.work.start()
self.work.trigger.connect(self.dispng)
r = 0
self.listwidget3.clear()
for i in loves:
self.listwidget3.addItem(i)
self.listwidget3.item®.setForeground(Qt.white)
r = r + 1
print(loves)
else:
pass

通过右键音乐列表进行喜爱的歌曲添加

def addItem(self):
try:
global loves
global loveurls
global lovepics
global lovelrc
if list_confident == ‘boing’:
loves.append(songs[num_m])
loveurls.append(urls[num_m])
lovepics.append(pic[num_m])
lovelrc.append(lrcs[num_m])
else:
loves.append(songed[num_m])
loveurls.append(urled[num_m])
lovepics.append(picd[num_m])
lovelrc.append(lrcd[num_m])
self.work = firstThread()
self.work.start()
self.work.trigger.connect(self.dispng)
except:
pass
r = 0
self.listwidget3.clear()
for i in loves:
self.listwidget3.addItem(i)
self.listwidget3.item®.setForeground(Qt.white)
r = r + 1
print(‘done’)
print(loves)


这样我们就可以把歌曲添加到喜爱的歌子列表页面下,如下图所示。  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/095ecc38a70049aa9a6b6af8f22ec59d.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBARHJhZ29u5bCR5bm0,size_20,color_FFFFFF,t_70,g_se,x_16)


##### 3. 喜爱的歌初始化读取显示及列表播放


对于添加到喜爱的歌曲列表,我们需要在退出音乐播放器程序时,将这些数据保存到本地文件,方便后面重新运行时初始化读取显示列表。


**喜爱歌曲本地保存:**  
 我们可以把喜爱的歌曲列表、喜爱歌曲图片、歌曲url链接、歌词等数据保存到本地。核心代码如下:



def close(self):
reply = QMessageBox.question(self, u’警告’, u’确定退出?', QMessageBox.Yes,
QMessageBox.No)
if reply == QMessageBox.Yes:
close = True
try:
mixer.music.stop()
except:
pass
try:
rmtree(str(data))
except Exception as e:
print(‘删除错误类型是’, e.class.name)
print(‘删除错误明细是’, e)
filepath = ‘{}/musicdata’.format(apdata)
try:
mkdir(filepath)
except:
pass
print(filepath)
with open(filepath + “/loves”, ‘w’, encoding=‘utf-8’) as f:
f.truncate(0)
print(f.write(str(loves)))
with open(filepath + “/lovepics”, ‘w’, encoding=‘utf-8’) as f:
f.truncate(0)
print(f.write(str(lovepics)))
with open(filepath + “/loveurls”, ‘w’, encoding=‘utf-8’) as f:
f.truncate(0)
print(f.write(str(loveurls)))
with open(filepath + “/lovelrc”, ‘w’, encoding=‘utf-8’) as f:
f.truncate(0)
print(f.write(str(lovelrc)))
with open(filepath + “/voice”, ‘w’, encoding=‘utf-8’) as f:
f.truncate(0)
print(f.write(str(voice)))
try:
rmtree(str(data))
except Exception as e:
print(‘删除错误类型是’, e.class.name)
print(‘删除错误明细是’, e)
exit()
else:
pass


**喜爱的歌初始化读取:**  
 重新运行音乐播放器时,我们需要加载保存在本地的喜爱歌曲数据,并将歌曲列表信息加载显示到喜爱的歌子列表页面中。核心代码如下:



def run(self):
try:
apdataas = getenv(“APPDATA”)
filepathas = ‘{}/musicdata’.format(apdataas)
global lovelrc
global loveurls
global loves
global lovepics
global voice
# 读取历史数据开始
try:
with open(filepathas + “/voice”, ‘r’, encoding=‘utf-8’) as f:
a = f.read()
# print(a)
voice = float(a)
print(voice)
self.trigger.emit(str(‘voicedone’))
except:
self.trigger.emit(str(‘voicedone’))
pass
with open(filepathas + “/loves”, ‘r’, encoding=‘utf-8’) as f:
a = f.read()
print(a)
strer = a
loves = literal_eval(strer)
with open(filepathas + “/lovepics”, ‘r’, encoding=‘utf-8’) as f:
a = f.read()
print(a)
strer = a
lovepics = literal_eval(strer)
with open(filepathas + “/loveurls”, ‘r’, encoding=‘utf-8’) as f:
a = f.read()
print(a)
strer = a
loveurls = literal_eval(strer)
with open(filepathas + “/lovelrc”, ‘r’, encoding=‘utf-8’) as f:
a = f.read()
print(a)
strer = a
lovelrc = literal_eval(strer)
self.trigger.emit(str(‘login’))
print(loves)
print(‘read finish’)
except:
print(‘read error’)
pass
# 读取数据结束

# 下载喜爱的歌列表中首项的歌曲封面
try:
    req = get(lovepics[0])
    checkfile = open(str(data + '/ls3.png'), 'w+b')
    for i in req.iter_content(100000):
        checkfile.write(i)

    checkfile.close()
    lsfile = str(data + '/ls3.png')
    safile = str(data + '/first.png')
    draw(lsfile, safile)
    self.trigger.emit(str('first'))
except:
    self.trigger.emit(str('nofirst'))
    pass    

**列表播放:**  
 对于加载的喜爱歌曲列表,我们可以对歌曲进行列表一键播放。



音乐播放

def bofang(self, num, bo):
print(‘尝试进行播放’)
try:
import urllib
global pause
global songs
global music
global downloading
downloading = True
self.console_button_3.setIcon(icon(‘fa.pause’, color=‘#F76677’, font=18))
pause = False
try:
mixer.stop()
except:
pass
mixer.init()
try:
self.Timer = QTimer()
self.Timer.start(500)
except:
pass
try:
self.label.setText(‘正在寻找文件…’)
self.work = WorkThread()
self.work.start()
self.work.trigger.connect(self.display)
except:
print(‘无法播放,歌曲下载错误’)
downloading = False
pass
except:
sleep(0.1)
print(‘播放系统错误’)
pass

播放所有歌曲

def playall(self, typer):
global num
global bo
try:
bo = typer
num = 0
self.bofang(bo, num)
except:
print(‘playall error’)
pass

播放喜爱歌曲

def allplaylove(self):
self.playall(‘love’)


##### 4. 歌词显示


对于播放的歌曲,我们可以进行歌词打印显示。核心代码如下:



def run(self):
if bo == ‘love’:
try:
proxies = {
‘http’: ‘http://124.72.109.183:8118’,
‘http’: ‘http://49.85.1.79:31666’

        }
        headers = {
            'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/86.0.4240.198 Safari/537.36',
            'X-Requested-With': 'XMLHttpRequest'}
        try:
            try:
                try:
                    aq = lovepics[num]
                    aqq = aq.split('/')
                except:
                    pass
                if type == 'kugou' and len(aqq) - 1 == 6:
                    aqqe = str(aqq[0]) + str('//') + str(aqq[2]) + str('/') + str(aqq[3]) + str('/') + str(
                        '400') + str('/') + str(aqq[5]) + str('/') + str(aqq[6])
                    print(aqqe)
                elif type == 'netease' and len(aqq) - 1 == 4:
                    aqn = aq.split('?')
                    b = '?param=500x500'
                    aqqe = (str(aqn[0]) + str(b))
                    print(aqqe)
                else:
                    aqqe = lovepics[num]
                req = get(aqqe)

                checkfile = open(str(data + '/ls1.png'), 'w+b')
                for i in req.iter_content(100000):
                    checkfile.write(i)

                checkfile.close()
                lsfile = str(data + '/ls1.png')
                safile = str(data + '/back.png')
                draw(lsfile, safile)
                picno = True
            except:
                print('图片错误')
                picno = False
                pass

            url1 = loveurls[num]
            print(url1)
            # os.makedirs('music', exist\_ok=True)
            number = number + 1
            path = str(data + '\{}.临时文件'.format(number))
            headers = {
                'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/121.110.430.128 Safari/537.36',
                'X-Requested-With': 'XMLHttpRequest'
            }
            with get(url1, stream=True, headers=headers) as r, open(path, 'wb') as file:
                total_size = int(r.headers['content-length'])
                content_size = 0
                for content in r.iter_content(chunk_size=1024):
                    if not stopdown:
                        file.write(content)
                        content_size += len(content)
                        plan = (content_size / total_size) \* 100
                        # print(int(plan))
                        develop = str(int(plan)) + str('%')
                        self.trigger.emit(str(develop))
                    else:
                        print ('down')
                        break
                    stopdown = False
            to = 'downloadmusic\{}.mp3'.format(songed[num])
            makedirs('downloadmusic', exist_ok=True)
        except:
            self.trigger.emit(str('nofinish'))
            pass
        try:
            lrct = []
            f = lovelrc[num]  # 按行读取
            # print(f)
            lines = f.split('\n')
            # print(lines)
            for i in lines:
                line1 = i.split('[')
                try:
                    line2 = line1[1].split(']')
                    if line2 == '':
                        pass
                    else:
                        linew = line2[1]
                        # print(linew)
                        lrct.append(linew)
                    self.trigger.emit(str('lrcfinish'))
                except:
                    print('歌词错误')
        except:
            pass
        try:
            copyfile(path, to)
        except:
            pass
        downloading = False
        self.trigger.emit(str('finish'))
    except:
        self.trigger.emit(str('nofinish'))  

效果如下所示:  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/b79c6688e9ac44cb85649c16795367f0.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBARHJhZ29u5bCR5bm0,size_20,color_FFFFFF,t_70,g_se,x_16)


##### 5. 本地歌曲读取播放


首先我们可以对本地文件夹目录下的音乐进行读取添加到本地歌曲列表中,根据歌曲的文件名进行列表显示。核心代码如下:



本地歌曲文件夹读取添加

def add(self):
try:
global SongPath
global SongName
global num
global filew
global asas
fileN = QFileDialog.getExistingDirectory(None, “选取文件夹”, “”)
if not fileN == ‘’:
self.listwidget5.clear()
filew = fileN + ‘/’
asas = filew
l1 = [name for name in listdir(fileN) if name.endswith(‘.mp3’) or name.endswith(‘.flac’) or name.endswith(‘.wma’) or name.endswith(‘.MP3’) or name.endswith(‘.FLAC’) or name.endswith(‘.WMA’)]
SongNameadd = l1
SongPathadd = [filew + i for i in SongNameadd]
SongName = SongName + SongNameadd
SongPath = SongPath + SongPathadd
print(SongPath)
r = 0
for i in SongName:
self.listwidget5.addItem(i) # 将文件名添加到listWidget
self.listwidget5.item®.setForeground(Qt.white)
r = r + 1
except:
filew = asas


当然我们还可以对本地加载歌曲进行双击播放,首先我们需要将本地歌曲子列表页面中进行双击事件绑定。



self.tab5 = QWidget()
self.tab5.setObjectName(“tab5”)
self.tab5_layout = QGridLayout()
self.tab5.setLayout(self.tab5_layout)
self.listwidget5 = QListWidget(self.tab5)
self.listwidget5.doubleClicked.connect(lambda: self.change(self.listwidget5))
self.listwidget5.setContextMenuPolicy(Qt.CustomContextMenu)
self.listwidget5.customContextMenuRequested[QPoint].connect(self.myListWidgetContext5)


对子列表页面进行绑定之后,接下来我们就可以完成双击事件,获取歌曲名称,并进行本地播放。



加载当前播放的本地歌曲

def change(self, listwidget):

如何自学黑客&网络安全

黑客零基础入门学习路线&规划

初级黑客
1、网络安全理论知识(2天)
①了解行业相关背景,前景,确定发展方向。
②学习网络安全相关法律法规。
③网络安全运营的概念。
④等保简介、等保规定、流程和规范。(非常重要)

2、渗透测试基础(一周)
①渗透测试的流程、分类、标准
②信息收集技术:主动/被动信息搜集、Nmap工具、Google Hacking
③漏洞扫描、漏洞利用、原理,利用方法、工具(MSF)、绕过IDS和反病毒侦察
④主机攻防演练:MS17-010、MS08-067、MS10-046、MS12-20等

3、操作系统基础(一周)
①Windows系统常见功能和命令
②Kali Linux系统常见功能和命令
③操作系统安全(系统入侵排查/系统加固基础)

4、计算机网络基础(一周)
①计算机网络基础、协议和架构
②网络通信原理、OSI模型、数据转发流程
③常见协议解析(HTTP、TCP/IP、ARP等)
④网络攻击技术与网络安全防御技术
⑤Web漏洞原理与防御:主动/被动攻击、DDOS攻击、CVE漏洞复现

5、数据库基础操作(2天)
①数据库基础
②SQL语言基础
③数据库安全加固

6、Web渗透(1周)
①HTML、CSS和JavaScript简介
②OWASP Top10
③Web漏洞扫描工具
④Web渗透工具:Nmap、BurpSuite、SQLMap、其他(菜刀、漏扫等)
恭喜你,如果学到这里,你基本可以从事一份网络安全相关的工作,比如渗透测试、Web 渗透、安全服务、安全分析等岗位;如果等保模块学的好,还可以从事等保工程师。薪资区间6k-15k

到此为止,大概1个月的时间。你已经成为了一名“脚本小子”。那么你还想往下探索吗?

如果你想要入坑黑客&网络安全,笔者给大家准备了一份:282G全网最全的网络安全资料包评论区留言即可领取!

7、脚本编程(初级/中级/高级)
在网络安全领域。是否具备编程能力是“脚本小子”和真正黑客的本质区别。在实际的渗透测试过程中,面对复杂多变的网络环境,当常用工具不能满足实际需求的时候,往往需要对现有工具进行扩展,或者编写符合我们要求的工具、自动化脚本,这个时候就需要具备一定的编程能力。在分秒必争的CTF竞赛中,想要高效地使用自制的脚本工具来实现各种目的,更是需要拥有编程能力.

如果你零基础入门,笔者建议选择脚本语言Python/PHP/Go/Java中的一种,对常用库进行编程学习;搭建开发环境和选择IDE,PHP环境推荐Wamp和XAMPP, IDE强烈推荐Sublime;·Python编程学习,学习内容包含:语法、正则、文件、 网络、多线程等常用库,推荐《Python核心编程》,不要看完;·用Python编写漏洞的exp,然后写一个简单的网络爬虫;·PHP基本语法学习并书写一个简单的博客系统;熟悉MVC架构,并试着学习一个PHP框架或者Python框架 (可选);·了解Bootstrap的布局或者CSS。

8、超级黑客
这部分内容对零基础的同学来说还比较遥远,就不展开细说了,附上学习路线。
img

网络安全工程师企业级学习路线

img
如图片过大被平台压缩导致看不清的话,评论区点赞和评论区留言获取吧。我都会回复的

视频配套资料&国内外网安书籍、文档&工具

当然除了有配套的视频,同时也为大家整理了各种文档和书籍资料&工具,并且已经帮大家分好类了。

img
一些笔者自己买的、其他平台白嫖不到的视频教程。
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化资料的朋友,可以点击这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 24
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值