模擬一個在線音樂播放程序
# 1, 使用C/S架構來進行設計,分別寫出客戶端和服務器程序
# 2,客戶端鏈接服務器之后,服務器向用戶提示可以選擇的歌曲列表,用戶選擇后開始播放(音頻文件存放在本地即可)
#思路是通過socketserver ,客戶端發送指令到服務端,服務端連接數據庫查到歌曲名字路徑返回給客戶端,客戶端通過pygame模塊查找到歌曲路徑 播放歌曲
#創建數據表,插入歌曲名字和路徑
CREATE TABLE t_music(
id INT PRIMARY KEY AUTO_INCREMENT,
NAME VARCHAR(32),
path VARCHAR(32)
)
SELECT * FROM t_music
INSERT INTO t_music(NAME,path) VALUE("味道","D:\\\\老男孩\\\\味道.mp3"),("世間美好與你環環相扣","D:\\\\老男孩\\\\世間美好與你環環相扣.mp3")
服務端:
import pymysql
import json
import socketserver
class MyServer(socketserver.BaseRequestHandler):
@classmethod
def conn(cls,name):
conn = pymysql.connect(host="localhost", user="root", password="123456", db="music", charset="utf8")
cur = conn.cursor()
sql = "select path from t_music where name='%s'" % name
cur.execute(sql)
data = cur.fetchall()
return data
@classmethod
def conn2(cls):
conn = pymysql.connect(host="localhost", user="root", password="123456", db="music", charset="utf8")
cur = conn.cursor()
sql = "select name from t_music"
cur.execute(sql)
data = cur.fetchall()
mydic = {}
lst = []
for i in data:
for j in i:
print(i[0])
lst.append(i[0])
for k, v in enumerate(lst):
mydic[k] = v
a = json.dumps(mydic)
return a
def handle(self):
while True:
data = self.request.recv(1024)
print('->client',data)
if data.decode() == 'a':
# pass
self.request.send(self.conn2().encode())
else:
self.request.send(self.conn(data.decode())[0][0].encode())
socketserver.TCPServer.allow_reuse_address = True
server = socketserver.ThreadingTCPServer(('127.0.0.1', 8080), MyServer)
server.serve_forever()
客戶端:
import socket
import json
client = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
client.connect(('127.0.0.1', 8080))
def broadcast(): # broadcast播放
import pygame
import time
pygame.mixer.init() #初始化
pygame.mixer.music.load(data1) # 通過路徑path 加載
pygame.mixer.music.play() #在程序運行中會播放
# print("正在播放的歌曲:%s" % name)
time.sleep(100) #讓程序保持運行狀態
while True:
name =input("請輸入a獲取歌曲列表或歌曲名字播放:")
client.send(name.encode('utf-8'))
data1 = client.recv(1024).decode('utf-8')
if name =='a':
data2 =json.loads(data1)
print(data2)
else:
print(data1)
broadcast()
#使用 mixer 播放音效
#山楂樹之戀 世間美好與你環環相扣 味道