利用阿里云ECS运行Python脚本监测汽车车窗车门状态

本文涉及的产品
云服务器 ECS,每月免费额度200元 3个月
云服务器ECS,u1 2核4GB 1个月
简介: 利用阿里云CES运行脚本监测汽车车窗车门状态

1、购买阿里云服务器

https://www.aliyun.com/product/ecs

2、安装宝塔

yum install -ywget && wget-O install.sh http://download.bt.cn/install/install_6.0.sh && sh install.sh ed099927

3、编写脚本

①导入包

importrequestsimportjsonimportosimporttimeimportsmtplibfromemail.mime.textimportMIMETextfromemail.utilsimportformataddr

②请求登录接口

deflogin():
try:
url="######"payload=json.dumps({
"username": username,
"password": password        })
headers= {
'Host': 'api.xchanger.cn',
'Cookie': '###########',
'accept': 'application/json;responseformat=3',
'content-type': 'application/json',
'x-app-id': '##',
'user-agent': 'BackgroundShortcutRunner/1092.8.7 CFNetwork/1220.1 Darwin/20.3.0',
'accept-language': 'zh-cn'        }
response=requests.request("POST", url, headers=headers, data=payload,verify=False)
print(response.json())
accessToken=response.json()['data']['accessToken']
userId=response.json()['data']['userId']
withopen(r'login.txt', "w+") asf1:
f1.write(accessToken)
withopen(r'userId.txt', "w+") asf2:
f2.write(userId)
returnaccessTokenexceptExceptionasDamnMistake:
print(DamnMistake)
mail("登录错误",str(DamnMistake))

③请求车辆状态接口

defstatus(sessionToken):
ifos.path.exists(r'userId.txt'):
withopen(r'userId.txt', "r") asf:
userId=f.read()
else:
userId="#####"url="#####"+vin+"#####"+userIdpayload= {}
headers= {
'Host': 'api.xchanger.cn',
'Cookie': '#######',
'accept': 'application/json;responseformat=3',
'ecarx-net-platform': 'tsp',
'user-agent': '#########)',
'authorization': sessionToken,
'accept-language': 'zh-cn'    }
response=requests.request("GET", url, headers=headers, data=payload,verify=False)
try:
#数据更新日期updateTime=response.json()['data']['vehicleStatus']['updateTime']
updateTime=time.strftime("%Y-%m-%d %H:%M:%S", time.localtime(response.json()['data']['vehicleStatus']['updateTime']/1000))
#左前车窗(2是关闭)winStatusDriver=response.json()['data']['vehicleStatus']['additionalVehicleStatus']['climateStatus']['winStatusDriver']
#右前车窗(2是关闭)winStatusPassenger=response.json()['data']['vehicleStatus']['additionalVehicleStatus']['climateStatus']['winStatusPassenger']
#左后车窗(2是关闭)winStatusDriverRear=response.json()['data']['vehicleStatus']['additionalVehicleStatus']['climateStatus']['winStatusDriverRear']
#右后车窗(2是关闭)winStatusPassengerRear=response.json()['data']['vehicleStatus']['additionalVehicleStatus']['climateStatus']['winStatusPassengerRear']
#冷却液是否正常(ture是正常)engineCoolantTemperatureValidity=response.json()['data']['vehicleStatus']['additionalVehicleStatus']['runningStatus']['engineCoolantTemperatureValidity']
#后尾箱是否开启(1开启,0没有开启)trunkOpenStatus=response.json()['data']['vehicleStatus']['additionalVehicleStatus']['drivingSafetyStatus']['trunkOpenStatus']
#引擎盖是否开启(1开启,0没有开启)engineHoodOpenStatus=response.json()['data']['vehicleStatus']['additionalVehicleStatus']['drivingSafetyStatus']['engineHoodOpenStatus']
#左前门打开状态(0是关闭)doorOpenStatusDriver=response.json()['data']['vehicleStatus']['additionalVehicleStatus']['drivingSafetyStatus']['doorOpenStatusDriver']
#右前门打开状态(0是关闭)doorOpenStatusPassenger=response.json()['data']['vehicleStatus']['additionalVehicleStatus']['drivingSafetyStatus']['doorOpenStatusPassenger']
#左后门打开状态(0是关闭)doorOpenStatusDriverRear=response.json()['data']['vehicleStatus']['additionalVehicleStatus']['drivingSafetyStatus']['doorOpenStatusDriverRear']
#右后门打开状态(0是关闭)doorOpenStatusPassengerRear=response.json()['data']['vehicleStatus']['additionalVehicleStatus']['drivingSafetyStatus']['doorOpenStatusPassengerRear']
#左前门门锁状态(1是已上锁)doorLockStatusDriver=response.json()['data']['vehicleStatus']['additionalVehicleStatus']['drivingSafetyStatus']['doorLockStatusDriver']
#左后门门锁状态(1是已上锁)doorLockStatusDriverRear=response.json()['data']['vehicleStatus']['additionalVehicleStatus']['drivingSafetyStatus']['doorLockStatusDriverRear']
#右前门门锁状态(1是已上锁)doorLockStatusPassenger=response.json()['data']['vehicleStatus']['additionalVehicleStatus']['drivingSafetyStatus']['doorLockStatusPassenger']
#右后门门锁状态(1是已上锁)doorLockStatusPassengerRear=response.json()['data']['vehicleStatus']['additionalVehicleStatus']['drivingSafetyStatus']['doorLockStatusPassengerRear']
#车辆报警是否开启(1为已开启)vehicleAlarm=response.json()['data']['vehicleStatus']['additionalVehicleStatus']['drivingSafetyStatus']['vehicleAlarm']
#电瓶电压voltage=response.json()['data']['vehicleStatus']['additionalVehicleStatus']['maintenanceStatus']['mainBatteryStatus']['voltage']
#发动机状态(engine_off为关闭,engine_running为开启)engineStatus=response.json()['data']['vehicleStatus']['basicVehicleStatus']['engineStatus']
carStatus_dict= {
"数据更新时间": updateTime,
"左前车窗": winStatusDriver,
"右前车窗": winStatusPassenger,
"左后车窗": winStatusDriverRear,
"右后车窗": winStatusPassengerRear,
"后尾箱是否开启": trunkOpenStatus,
"引擎盖是否开启": engineHoodOpenStatus,
"左前门打开状态": doorOpenStatusDriver,
"右前门打开状态": doorOpenStatusPassenger,
"左后门打开状态": doorOpenStatusDriverRear,
"右后门打开状态": doorOpenStatusPassengerRear,
"左前门门锁状态": doorLockStatusDriver,
"左后门门锁状态": doorLockStatusDriverRear,
"右前门门锁状态": doorLockStatusPassenger,
"右后门门锁状态": doorLockStatusPassengerRear,
"车辆报警是否开启": vehicleAlarm,
"电瓶电压": voltage,
"发动机状态": engineStatus        }
withopen(r'carStatus_dict.txt', "w+") asf:
f.write(str(carStatus_dict))
returncarStatus_dictexceptExceptionasDamnMistake:
print(DamnMistake)
mail("获取各项数据错误",str(DamnMistake))


⑤发送邮件

defmail(msgTitle, result_json):
my_sender='####@qq.com'# 发件人邮箱账号my_pass='####'# 发件人邮箱密码my_user='#####@qq.com'# 收件人邮箱账号try:
msg=MIMEText(json.dumps(result_json, sort_keys=True, indent=4, separators=(',', ':'), ensure_ascii=False),
'plain', 'utf-8')
msg['From'] =formataddr(["###", my_sender])  # 括号里的对应发件人邮箱昵称、发件人邮箱账号msg['To'] =formataddr(["FK", my_user])  # 括号里的对应收件人邮箱昵称、收件人邮箱账号msg['Subject'] =msgTitle# 邮件的主题server=smtplib.SMTP_SSL("smtp.qq.com", 465)  # 发件人邮箱中的SMTP服务器,端口是25server.login(my_sender, my_pass)  # 括号中对应的是发件人邮箱账号、邮箱密码server.sendmail(my_sender, my_user, msg.as_string())  # 括号中对应的是发件人邮箱账号、收件人邮箱账号、发送邮件server.quit()  # 关闭连接exceptExceptionasfuckError:  # 如果 try 中的语句没有执行,则会执行下面的print('发送邮件报错了,报错内容为:\n')
print(fuckError)

⑥主程序

defmain():
sessionToken=update_token()
carStatus_dict=status(sessionToken)
print(carStatus_dict)
car_Alarm=[]
ifcarStatus_dict['发动机状态'] =="engine_off":
ifcarStatus_dict['左前车窗'] !="2":
car_Alarm.append("左前车窗未关闭")
ifcarStatus_dict['右前车窗'] !="2":
car_Alarm.append("右前车窗未关闭")
ifcarStatus_dict['左后车窗'] !="2":
car_Alarm.append("左后车窗未关闭")
ifcarStatus_dict['右后车窗'] !="2":
car_Alarm.append("右后车窗未关闭")
ifcarStatus_dict['后尾箱是否开启'] =="1":
car_Alarm.append("后尾箱未关闭")
ifcarStatus_dict['左前门门锁状态'] !="1":
car_Alarm.append("左前门未锁")
ifcarStatus_dict['左后门门锁状态'] !="1":
car_Alarm.append("左后门未锁")
ifcarStatus_dict['右前门门锁状态'] !="1":
car_Alarm.append("右前门未锁")
ifcarStatus_dict['右后门门锁状态'] !="1":
car_Alarm.append("右后门未锁")
ifcarStatus_dict['左前门打开状态'] =="1":
car_Alarm.append("左前门未关闭")
ifcarStatus_dict['左后门打开状态'] =="1":
car_Alarm.append("左后门未关闭")
ifcarStatus_dict['右前门打开状态'] =="1":
car_Alarm.append("右前门未关闭")
ifcarStatus_dict['右后门打开状态'] =="1":
car_Alarm.append("右后门未关闭")
print(car_Alarm)
else:
passiflen(car_Alarm)>0:
car_Alarm.append("数据更新时间:"+carStatus_dict['数据更新时间'])
withopen(r'car_Alarm.txt', "w+") asf1:
f1.write(str(car_Alarm))
mail("车辆报警!!!!!!", car_Alarm)


4、上传脚本

①打开宝塔

②点击“文件”

③上传

image.png

5、开启定时任务

①打开宝塔

②点击“计划任务”

image.png

6、结束

image.png

image.png































相关实践学习
一小时快速掌握 SQL 语法
本实验带您学习SQL的基础语法,快速入门SQL。
7天玩转云服务器
云服务器ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,可降低 IT 成本,提升运维效率。本课程手把手带你了解ECS、掌握基本操作、动手实操快照管理、镜像管理等。了解产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2天前
|
存储 NoSQL Redis
在Python Web开发过程中,为什么Redis运行速度快
【5月更文挑战第15天】Redis在Python Web开发中运行速度快,原因包括:1) 丰富数据类型满足多样化需求;2) 简单数据模型提升查询效率;3) 单线程模型结合非阻塞I/O实现高效处理;4) 持久化机制保证数据安全;5) 二进制协议与管道技术优化网络通信。这些因素共同确保Redis能处理大量请求并保持高性能。
24 1
|
2天前
|
数据采集 Web App开发 数据处理
Lua vs. Python:哪个更适合构建稳定可靠的长期运行爬虫?
Lua vs. Python:哪个更适合构建稳定可靠的长期运行爬虫?
|
2天前
|
Oracle Java 关系型数据库
【服务器】python通过JDBC连接到位于Linux远程服务器上的Oracle数据库
【服务器】python通过JDBC连接到位于Linux远程服务器上的Oracle数据库
14 6
|
2天前
|
缓存 Shell 开发工具
[oeasy]python0016_在vim中直接运行python程序
在 Vim 编辑器中,可以通过`:!`命令来执行外部程序,例如`:!python3 oeasy.py`来运行Python程序。如果想在不退出Vim的情况下运行当前编辑的Python文件,可以使用`%`符号代表当前文件名,所以`:!python3 %`同样能运行程序。此外,可以使用`|`符号连续执行命令,例如`:w|!python3 %`会先保存文件(`w`)然后运行Python程序。这样,就可以在不离开Vim的情况下完成编辑、保存和运行Python程序的流程。
19 0
|
2天前
|
SQL DataWorks 安全
DataWorks产品使用合集之DataWorks资源里python运行时候,查看中途打印日志如何解决
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
26 0
|
2天前
|
机器学习/深度学习 人工智能 供应链
【专栏】阿里云RPA的Rap程序是自动化流程脚本,基于AI和机器学习,实现业务流程自动化
【4月更文挑战第29天】阿里云RPA的Rap程序是自动化流程脚本,基于AI和机器学习,实现业务流程自动化。具有灵活性、易用性、高效稳定和智能学习等特点。广泛应用于财务、人力资源、客服和供应链等领域,未来将与AI深度融合,跨平台应用,行业定制化,并构建完善生态,助力企业效率提升和创新。
|
2天前
|
测试技术 Python
python运行集成测试
【4月更文挑战第22天】
11 1
|
2天前
|
运维 监控 Serverless
Serverless 应用引擎产品使用之阿里函数计算中在自定义环境下用debian10运行django,用官方层的python3.9,配置好环境变量后发现自定义层的django找不到了如何解决
阿里云Serverless 应用引擎(SAE)提供了完整的微服务应用生命周期管理能力,包括应用部署、服务治理、开发运维、资源管理等功能,并通过扩展功能支持多环境管理、API Gateway、事件驱动等高级应用场景,帮助企业快速构建、部署、运维和扩展微服务架构,实现Serverless化的应用部署与运维模式。以下是对SAE产品使用合集的概述,包括应用管理、服务治理、开发运维、资源管理等方面。
22 3
|
2天前
|
XML 测试技术 持续交付
python运行集成测试
【4月更文挑战第21天】
22 2
|
2天前
|
前端开发 Serverless Shell
Serverless 应用引擎操作报错合集之在阿里云函数计算中,laravel zip包使用示例的start.sh脚本启动时出现错误代码如何解决
Serverless 应用引擎(SAE)是阿里云提供的Serverless PaaS平台,支持Spring Cloud、Dubbo、HSF等主流微服务框架,简化应用的部署、运维和弹性伸缩。在使用SAE过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
30 3