20213222黄臻鹏 实验三 《Python程序设计》实验报告

shengchijianyong 2023-06-23 19:09:51

学号 20213222 2022-2023-2 《Python程序设计》实验三报告

课程:《Python程序设计》
班级: 2132
姓名: 黄臻鹏
学号:20213222
实验教师:王志强
实验日期:2023年4月13日
必修/选修: 公选课

1.实验内容

(一)实验内容

创建服务端和客户端,服务端在特定端口监听多个客户请求。客户端和服务端通过Socket套接字(TCP/UDP)进行通信。

(二)实验要求

(1)创建服务端和客户端,选择一个通信端口,用Python语言编程实现通信演示程序;

(2)要求包含文件的基本操作,例如打开和读写操作。

(3)要求发送方从文件读取内容,加密后并传输;接收方收到密文并解密,保存在文件中。

(4)程序代码托管到码云。
注:在华为ECS服务器(OpenOuler系统)和物理机(Windows/Linux系统)上使用VIM、PDB、IDLE、Pycharm等工具编程实现。

(三)实验报告

在规定时间前发表博客,标题“学号 实验三《Python程序设计》实验报告”

2. 实验过程及结果

(1). 选择8000端口,ip地址为192.168.172.214
服务端:


 
  1. import socket

  2. s = socket.socket(socket.AF_INET,socket.SOCK_STREAM)

  3. s.bind(("192.168.172.214",8000))

  4. s.listen()

  5. conn,adress = s.accept()#阻塞

  6. data = conn.recv(1024)#接受

  7. print("从客户端收到的信息为:",data.decode)

  8. conn.sendall("信息已收到!".encode())

  9. s.close()

  10.  

(2).客户端:


 
  1. import socket

  2. s = socket.socket(socket.AF_INET,socket.SOCK_STREAM)

  3. s.connect(("192.168.172.214",8000))

  4. s.sendall("我系zxh".encode)

  5. data=s.recv(1024)

  6. print("从服务器接收到的数据为:",data.decode())

  7. s.close()

  8.  

(3)加上添加文件操作


 
  1. import socket

  2.  
  3. s = socket.socket(socket.AF_INET,socket.SOCK_STREAM)

  4. s.bind(("192.168.172.214",8000))

  5. s.listen()

  6. conn,address=s.accept()

  7. data=conn.recv(1024)

  8. print("从客户端收到的信息为:",data.decode())

  9. conn.sendall("Receive!".encode())

  10. s.close()

  11.  

(客户端)


 

 

客户端:


 

 

  1.  
  2. import socket

  3.  
  4. if os.path.exists("秘密"):

  5. file1=open("秘密","a+")

  6. else:

  7. file1=open("秘密","w+")

  8. file1.write("Have you eaten?")

  9. file1.seek(0)

  10. cryptostring = file1.readline()

  11. print(cryptostring)

  12. s=socket.socket(socket.AF_INET, socket.SOCK_STREAM)

  13. s.connect(("192.168.172.214",8000))

  14. s.sendall(cryptostring.encode())

  15. data=s.recv(1024)

  16. print("从服务器接受的数据为:",data.decode())

  17. s.close()

    进行加密
    服务端:

    
     
  18. import socket

  19. from DesModule import des_descrypt,des_encrypt

  20.  
  21. from DesModule import des_encrypt

  22. from DesModule import des_descrypt

  23. import socket

  24. import os

  25.  
  26. if os.path.exists("秘密"):

  27. file1=open("秘密","a+")

  28. else:

  29. file1=open("秘密","w+")

  30. file1.write("Have you eaten?")

  31. file1.seek(0)

  32. cryptostring = file1.readline()

  33. text=des_encrypt(cryptostring,"12345678")

  34. s=socket.socket(socket.AF_INET, socket.SOCK_STREAM)

  35. s.connect(("127.0.0.1",8000))

  36. s.sendall(text.encode())

  37. data=s.recv(1024)

  38. print("从客户端收到的信息解密前为:",data)

  39. plaintext=des_descrypt(data,"12345678")

  40. print("从服务器接受的数据为:",plaintext)

  41. file1.write(plaintext)

  42. file1.close()

  43. s.close()

    • s = socket.socket(socket.AF_INET,socket.SOCK_STREAM)

    • s.bind(("127.0.0.1",8000))

    • s.listen()

    • conn,address=s.accept()

    • data=conn.recv(1024)

    • print("从客户端收到的信息解密前为:",data)

    • plaintext=des_descrypt(data,"12345678")

    • print("从客户端收到的信息为:",plaintext)

    • cryptostring="Receive!"

    • text=des_encrypt(cryptostring,"12345678")

    • conn.sendall(text.encode())

    • s.close()img 

      3.实验过程中遇到的问题和解决过程

      问题1:目标计算机积极拒绝
      问题1解决方案:关闭防火墙

       

...全文
213 回复 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

144

社区成员

发帖
与我相关
我的任务
社区描述
开展Python教学和技术交流
python 高校 北京·丰台区
社区管理员
  • blackwall0321
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧