zdppy+vue3+onlyoffice文档管理系统实战 20240823上课笔记 zdppy_cache框架的低代码实现

遗留问题

  • 1、封装API
  • 2、有账号密码
  • 3、查询所有有效的具体数据,也就是缓存的所有字段

封装查询所有有效具体数据的方法

基本封装

def get_all(self, is_active=True, limit=100000):"""遍历数据库中所有的key,默认查询所有没过期的:param is_active: 是否只查没过期的:param limit: 默认10000,但是允许做限制:return: 遍历到的所有的key,没有返回空列表"""_disk_get = self._disk.getcolumns = ["key", "raw", "store_time", "expire_time", "access_time", "access_count", "tag", "size", "mode","filename", "value"]column = ",".join(columns)rows = Noneif is_active:# 查没过期的select = f'SELECT {column} FROM Cache where expire_time > ? LIMIT ?'rows = self._sql(select, (time.time(), limit)).fetchall()else:# 查所有的select = f'SELECT {column} FROM Cache  LIMIT ?'rows = self._sql(select, (limit,)).fetchall()# 处理data = []for row in rows:item = {}for i in range(len(columns)):item[columns[i]] = row[i]data.append(item)# 返回return data

基本用法

import zdppy_cache as c
import time# 设置缓存
key = "code"
value = "A13k"
c.set(key, value, 3)# 获取所有的缓存的key-value
print(c.get_all())time.sleep(3)
print("默认查询未过期的:", c.get_all())
print("查询过期的:", c.get_all(False))# 清空缓存
c.delete_all()

查询总缓存大小

最简单的方案

它是基于磁盘的,我们统计磁盘大小就知道了。

基本封装

def get_size():"""获取占据的内存大小但是只有在调用方法的那一刻会占据内存,平时都是存储在磁盘中的"""with Cache(cache_directory) as cache:return cache.volume()

使用示例

import zdppy_cache as c
import time# 设置缓存
key = "code"
value = "A13k"
c.set(key, value, 3)# 获取占据磁盘大小
print(c.get_size())# 加很多东西
for i in range(100):c.set(f"zhangsan{i}", i)print(c.get_size())# 清空缓存
c.delete_all()

有账号密码

思路?

账号密码是用来校验权限,主要是为了确定自己专属数据库。

对账号密码做sha256加密得到一个字符串作为缓存目录。如果这个目录存在,说明系统中有该用户,否则没有,新建。

python实现sha256加密

import hashlibdata = "你好"   # 要进行加密的数据
data_sha = hashlib.sha256(data.encode('utf-8')).hexdigest()   
print(data_sha)

需要key用户私钥吗?

不需要,简单点。

简单的实现

import hashlib
import shutil
import os
from .core import Cacheclass UserCache:def __init__(self, username, password, cache_dir="./tmp/.zdppy_cache"):# 构建缓存目录self.key = hashlib.sha256(f"{username}&&{password}".encode('utf-8')).hexdigest()self.cache_dir = os.path.join(cache_dir, self.key).replace("\\", "/")if not os.path.isdir(self.cache_dir):os.makedirs(self.cache_dir)self.cache = Cache(self.cache_dir)def set(self, key, value, expire=180):"""设置缓存"""self.cache.set(key, value, expire)def get(self, key):"""获取缓存"""value = self.cache.get(key)return valuedef delete_all(self):"""清空缓存"""self.cache.close()try:shutil.rmtree(self.cache_dir)except OSError:pass

使用示例

import zdppy_cache# 设置缓存
key = "code"
value = "A13k"# 设置缓存
c = zdppy_cache.UserCache("admin", "admin123456")
c.set(key, value, 3)# 获取缓存
print(c.get(key))# 让另一个用户去获取缓存
c = zdppy_cache.UserCache("admin", "admin123457")
print("另一个用户", c.get(key))# 清空缓存
c.delete_all()

封装API

基本目标

  • 1、管理员,传两个配置的key进来
    • 1、设置缓存
    • 2、获取缓存
    • 3、删除缓存
    • 4、清空缓存
    • 5、查询所有key,带查询参数:active只查激活的,value包含value默认只获取key
    • 6、当前缓存大小
    • 7、看所有数据
  • 2、普通用户,功能和管理员完全一样,但是必须要传账号密码

实现基于zdppy_api的接口缓存

基本示例:

import api
import zdppy_cachekey1 = "admin"
key2 = "admin123456"
app = api.Api(routes=[*zdppy_cache.zdppy_api.cache(key1, key2, api)]
)if __name__ == '__main__':app.run()

设置缓存:

req -X POST -d '{\"key\":1,\"value\":111}' http://127.0.0.1:8888/zdppy_cache/set

在这里插入图片描述

获取缓存:

req -d '{\"key\":1}' http://127.0.0.1:8888/zdppy_cache/get

在这里插入图片描述

想法

  • 查询总缓存大小 搞定

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/52527.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于GPT回答:结合不同专业,论述GIS应用的关键技术问题

1. 智能化数据质量管理 **技术挑战:** - 自动化数据清洗与补全 - 自适应数据标准化 **解决方案:** - **AI驱动的数据处理**:利用深度学习进行数据修复和格式转换,提高数据质量和一致性。 2. 高效空间数据集成 **技术挑战&a…

【Tools】区块链技术的应用场景和优势

紧紧握着 青花信物 信守着承诺 离别总在 失意中度过 记忆油膏 反复涂抹 无法愈合的伤口 你的回头 划伤了沉默 🎵 周传雄《青花》 区块链技术的应用场景和优势是多样且广泛的。以下是一些常见的应用场景和优势: 金融服务&#xff1a…

51单片机——LED灯控制

1、LED介绍 中文名:发光二极管 外文名:Light Emitting Diode 简称:LED 用途:照明、广告灯、指引灯、屏幕 2、LED原理图 电阻在原理图上标注为1k,表示这是1千欧的电阻,实际在电路板上的表示是102 102解…

Godot《躲避小兵》实战之创建游戏主场景

游戏主场景 现在是时候将我们所做的一切整合到一个可玩的游戏场景中了。 创建新场景并添加一个 Node节点,命名为 Main。(我们之所以使用 Node 而不是 Node2D,是因为这个节点会作为处理游戏逻辑的容器使用。本身是不需要 2D 功能的。&#x…

C\C++ Sqlite3使用详解

C\C++ Sqlite3使用详解 一、源码下载二、sqlite3接口说明C++2.1 项目创建以及sqlite3使用2.1 连接数据库2.2 sqlite创建表2.2.1 示例代码2.2.2 注意事项2.3 sqlite插入数据2.3.1 示例代码2.3.2 注意事项2.4 sqlite数据删除2.5 sqlite数据查询一、源码下载 下载地址: https://…

oneapi 获取通义千问模型密钥

1、打开 阿里云百炼大模型平台,点击开通,登录账号 2、获取密钥 3、查看模型名称,可以添加到 oneapi 的渠道中 别忘了添加向量模型

python库(21):

1 TextBlob简介 TextBlob 是一个基于 Python 的文本处理库,能够让基础的自然语言处理任务变得异常简单。 它提供了一个简单直观的 API,让你能够轻松执行词性标注、名词短语提取、情感分析、文本分类和关键词提取等功能。 值得一提的是,Tex…

[Linux]如何在虚拟机安装Ubuntu?(小白向)

一、我们为什么要在虚拟机中安装Ubuntu? 在虚拟机中安装系统主要是为了让一个系统与我们原本的系统隔离,不管是想运行一些不安全的软件,或者是想运行一些独特的操作系统,我们都可以选择使用虚拟机来安装和隔离这些操作系统。如果你是一位Lin…

编译报错declaration may not appear after executable statement in block

这个错误是因为在代码块中,声明语句不能出现在可执行语句之后。也就是说,如果你在一个代码块中先写了一些可执行语句,再写了一 些声明语句,就会出现这个错误。 解决方法:将声明语句放在可执行语句之前,或者…

跨越语言障碍:2024四款实用在线翻译工具评测!

随着技术的不断进步,各种在线翻译工具层出不穷,帮助我们轻松跨越语言的鸿沟。今天,让我们一起探索几款非常实用的在线翻译工具! 福昕在线翻译 直达链接: https://fanyi.pdf365.cn/ 福昕在线翻译是一款专注于文档翻…

【C++】函数模板特化:深度解析与应用场景

📢博客主页:https://blog.csdn.net/2301_779549673 📢欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请指正! 📢本文由 JohnKi 原创,首发于 CSDN🙉 📢未来很长&#…

[LeetCode]46.全排列(python)

1.代码 from typing import List class Solution:def permute(self, nums: List[int]) -> List[List[int]]:result: List[List[int]] [] length len(nums)def fill(n: int, nums: List[int]):if n length:result.append(nums[:]) returnfor i in range(n, length):num…

JVM-Java的四种引用

引用分析 无论是通过引用计数算法判断对象的引用数量,还是通过可达性分析算法判断对象是否可达,判定对象是否可被回收都与引用有关,Java 提供了四种强度不同的引用类型 强引用: 被强引用关联的对象不会被回收,只有所…

SQLite 插入数据并返回自增ID

要插入数据并返回自增ID,我们可以使用SQLite的last_insert_rowid()函数。这个函数返回了最后一次插入操作的自增ID。 下面我们通过一个示例来演示如何插入数据并返回自增ID。 首先,创建一个表来存储学生信息: CREATE TABLE students (id I…

【drools】8.44 例子ubuntu24.04 运行;IntelliJ 修复java: 错误: 不支持发行版本 5

首先是要有jdk 安装:这里是oracle的,不是openjdk ,【ubuntu24.04】安装oracle javasdk– 官方说可以直接跑 root@k8s-master-pfsrv:/home/zhangbin/perfwork/drools/drools-distribution-8.44.0.Final/examples# ./runExamples.sh Usage: ./runExamples.sh For example: .…

dubbo:dubbo+nacos整合springcloud gateway实现网关(三)

文章目录 0. 引言1. 集成gateway网关1.1 实操步骤1.2 dubbo提供者注册到nacos出现两个实例的问题 2. 源码3. 总结 0. 引言 上次我们讲到使用zookeeper作为注册中心搭建dubbo微服务框架,但是我们还缺少一个服务总入口,也就是我们的网关服务。所以今天我们…

速盾:cdn能防ip追踪吗?

CDN,即内容分发网络(Content Delivery Network),是一种通过网络分布在多个地理位置的服务器集群来提供高效内容传输服务的技术。CDN的主要目的是通过就近提供内容来加快网站的加载速度,并减少因服务器过载而导致的延迟…

DataWhale AI夏令营-《李宏毅深度学习教程》笔记

DataWhale AI夏令营-《李宏毅深度学习教程》笔记 第三章 深度学习基础补充一些基础临界点及其种类逃离临界点方法批量动量自适应学习率学习率调度 之前一直接触的LLM大模型做一些应用,或者传统的自然语言处理,都是直接拿别人的模型用,要不就是…

2024.8.23 刷题总结

2024.8.23 **每日一题** 198.打家劫舍,这道题是一道简单的入门动态规划问题,根据题目意思,我们不能取数组中相邻的元素然后还必须满足总结果最大,所以我们可以维护一个数组,用来保存在数组每个位置之前能取到的最大值&…

【openwrt-21.02】openwrt-21.02 T750 按键GPIO自动进入刷机模式功能实现

Openwrt版本 NAME="OpenWrt" VERSION="21.02-SNAPSHOT" ID="openwrt" ID_LIKE="lede openwrt" PRETTY_NAME="OpenWrt 21.02-SNAPSHOT" VERSION_ID="21.02-snapshot" HOME_URL="https://openwrt.org/" …