windwos 安装 pysqlcipher3

news/2024/10/18 9:22:20/

windwos 安装 pysqlcipher3

安装软件

参考别人的文章,有的要安装Tcl Windows(64-bit, x64),下载地址 但是我没有安装也可以用

安装python

  • 推荐安装 python3.7 日常使用够了,不要追求新出来的版本,不太完善。

安装visual studio

  • Visual Studio下载地址(本文安装的是2022版本)
  • 安装只选择 使用C++的桌面开发 的组件就好了(安装大约 下载3G,安装占用10G)

安装openssl

  • 注意需要将OpenSSL的dll安装到系统目录,如果只是安装在OpenSSL的bin目录的话,使用的时候需要将bin目录加入系统PATH,或者自行拷贝相关dll到调用程序目录。
  • 这个版本是 1.1.1t,与之前的版本不太一样,部分文件名称改了(之后有填坑)

安装Tcl Windows(64-bit, x64)

  • 编译时要用到这个东西。 下载地址:Download & Install Tcl | ActiveState

开始编译

开始编译

python setup.py build_amalgamation
  • 编译会有很多坑,填坑内容在后边。

完成编译

  正在创建库 build\temp.win-amd64-3.7\Release\src\python3\_sqlite3.cp37-win_amd64.lib 和对象 build\temp.win-amd64-3.7\Release\src\python3\_sqlite3.cp37-win_amd64.exp
正在生成代码
已完成代码的生成

安装模块

python setup.py installpip list##############################
# Package      Version
# ------------ -------
# pip          23.1.2
# pysqlcipher3 1.2.0
# pysqleet     0.0.0
# setuptools   47.1.0
##############################

编译填坑

报错 - Fatal error: OpenSSL could not be detected!

C:\Users\Administrator\Desktop\新建文件夹\pysqlcipher3-1.2.0>python setup.py build_amalgamation
running build_amalgamation
Builds a C extension using a sqlcipher amalgamation
Fatal error: OpenSSL could not be detected!
  • 添加环境遍历OPENSSL_CONF,值是 “安装位置\OpenSSL-Win64\bin\openssl.cfg”

分析 setup.py 源码代码发现 : 需要有一个OPENSSL_CONF的环境变量,存放openssl的配置

         # Try to locate opensslopenssl_conf = os.environ.get('OPENSSL_CONF')if not openssl_conf:error_message = 'Fatal error: OpenSSL could not be detected!'raise RuntimeError(error_message)

os.environ.get() 是 python 中 os 模块获取环境变量的一个方法,如果有这个键,返回对应的值,如果没有,则返回 none

报错 - amalgamation中没有sqlite3.h, sqlite3.c

running build_amalgamation
Builds a C extension using a sqlcipher amalgamation
SQL Cipher amalgamation not found. Please download or build theamalgamation and make sure the following files are present in theamalgamation folder: sqlite3.h, sqlite3.c
  • 方法一:(新手慎用,有大坑,安装成功后文件可能加密不生效)
    下载pysqlcipher-amalgamation, 选Source Code,里面有sqlite3.h, sqlite3.c文件
    SQLite Download Page
  • 方法二:
    下载 sqlcipher,编译文件
    1. `git clone https://github.com/sqlcipher/sqlcipher.git``
    2. ``nmake /f Makefile.msc`
      nmake需要在 x64 Native Tools Command Prompt for VS 2022 的终端下使用
    3. 编译会报错,只要生成sqlite3.h, sqlite3.c文件即可
      想完整编译需要修改Makefile.msc再构建,https://youtu.be/SFHGeetZ0po 完整编译视频

报错 - 没有sqlcipher/sqlite3.h

C:\Users\Administrator\Desktop\新建文件夹\pysqlcipher3-1.2.0\src\python3\connection.h(33): fatal error C1083: 无法打开包括文件: “sqlcipher/sqlite3.h”: No such file or directory
  • 在amalgamation文件夹中创建sqlcipher文件夹,将sqlite3.h复制一份到sqlcipher文件夹

报错 - LNK1181: 无法打开输入文件“libeay32.lib”

LINK : fatal error LNK1181: 无法打开输入文件“libeay32.lib”
error: command 'D:\\software\\Microsoft Visual Studio\\Community2022\\VC\\Tools\\MSVC\\14.36.32532\\bin\\HostX86\\x64\\link.exe' failed with exit status 1181

从 1.1.0 版本开始,OpenSSL 将它们的库名称从: libeay32.dll -> libcrypto.dll ssleay32.dll -> libssl.dll
版本问题,改名了

  • 方法1:

    # 完整处理方法
    - 复制 libcrypto.def 为 libeay32.def
    - 复制 libcrypto.lib 为 libeay32.lib
    - 复制 libssl.def 为 ssleay32.def
    - 复制 libssl.lib 为 ssleay32.lib
    # 偷懒复制一个就够了,这里就用了libeay32.lib
    - 复制 libcrypto.lib 为 libeay32.lib
    
  • 方法2:
    文件名称在 setup.py 代码写的,改成 libcrypto.lib 也可以实现(注意是lib文件)

                # Configure the linkerext.extra_link_args.append("libeay32.lib")ext.extra_link_args.append('/LIBPATH:' + openssl_lib_path)
    

报错 - failed with exit code 2

系统环境可以正常使用,虚拟环境使用常报的错误

src\python3\cache.c(261): error C2017: 非法的转义序列
src\python3\cache.c(261): error C2061: 语法错误: 标识符“Node”
src\python3\cache.c(261): error C2001: 常量中有换行符
src\python3\cache.c(303): error C2017: 非法的转义序列
src\python3\cache.c(303): error C2224: “.Cache”的左侧必须具有结构/联合类型
src\python3\cache.c(303): error C2001: 常量中有换行符
src\python3\cache.c(303): error C2059: 语法错误:“字符串”
error: command 'D:\\software\\Microsoft Visual Studio\\Community2022\\VC\\Tools\\MSVC\\14.36.32532\\bin\\HostX86\\x64\\cl.exe' failed with exit code 2
  • 报错文件指向src\python3\cache.c打开看看

    # 分析报错文件,MODULE_NAME有问题
    261        MODULE_NAME "Node",                             /* tp_name */
    303        MODULE_NAME ".Cache",                           /* tp_name */
    
  • MODULE_NAME在编译前没有进行正确的分析,就是这个不能用

  • 分析py文件看看 MODULE_NAME 是个啥

    define_macros = [('MODULE_NAME', quote_argument(PACKAGE_NAME + '.dbapi2'))]
    print(define_macros) # 搞一个输出看看是啥 我的是 pysqlcipher3.dbapi2
    
  • 分析py文件发现,MODULE_NAME 的值应该是 pysqlcipher3.dbapi2

  • src\python3\cache.c文件中的MODULE_NAME替换成pysqlcipher3.dbapi2试试

  • 新的报错

    src\python3\connection.c(1546): warning C4090: “=”: 不同的“const”限定符
    src\python3\connection.c(1697): error C2017: 非法的转义序列
    
  • 查看报错文件(1546 是个告警),发现还是MODULE_NAME

    1697        MODULE_NAME ".Connection",                      /* tp_name */
    
  • 改了MODULE_NAME在尝试,最后发现src\python3*.c 几乎都用了MODULE_NAME,都改成pysqlcipher3.dbapi2就可以了

参考文章

  • 编译Windows 64bit平台pysqlcipher3 for Python3.7
  • 编译安装pysqlcipher3
  • 安装pysqlcipher3时出现问题 - 问答 - 腾讯云开发者社区-腾讯云 (tencent.com)
    • 这篇是关键,也是大坑,应该是机器翻译过来的有些东西意思都变了。

http://www.ppmy.cn/news/103972.html

相关文章

Postman 接口测试神器

Postman 接口测试神器 Postman 是一个接口测试和 http 请求的神器,非常好用。 官方 github 地址: Postman Inc. GitHub Postman 的优点: 支持各种的请求类型: get、post、put、patch、delete 等支持在线存储数据,通过账号就可以进行迁移…

MySQL数据库安全与备份

✅作者简介:热爱Java后端开发的一名学习者,大家可以跟我一起讨论各种问题喔。 🍎个人主页:Hhzzy99 🍊个人信条:坚持就是胜利! 💞当前专栏:MySQL 🥭本文内容&a…

无屏幕实现连接树莓派

无屏幕实现连接树莓派 欢迎来到我的博客!今天我将与大家分享如何无需使用屏幕,实现与树莓派的连接。对于那些在树莓派项目中不方便使用屏幕的人来说,这将是一个有用的技巧。 材料清单 在开始之前,让我们先准备好所需的材料&…

C++ Primer第五版_第十八章习题答案(21~30)

文章目录 练习18.21练习18.22练习18.23练习18.24练习18.25练习18.26练习18.27练习18.28练习18.29练习18.30 练习18.21 解释下列声明的含义,在它们当作存在错误吗?如果有,请指出来并说明错误的原因。 (a) class CADVehicle : public CAD, Vehi…

多线程环境中的共享变量怎么保护起来的(volatile关键字与互斥锁)

文章目录 一、volatile关键字与互斥锁介绍(1)volatile关键字(2)互斥锁 二、volatile关键字与互斥锁的作用(1)第一个代码实例(2)第二个代码实例(3)第三个代码实…

TDengine 数据库SQL操作 | 建库、建表、数据读写

一、前文 TDengine 入门教程——导读 二、库操作 2.1 创建库 CREATE DATABASE test; BUFFER: 一个 VNODE 写入内存池大小,单位为 MB,默认为 96,最小为 3,最大为 16384。CACHEMODEL:表示是否在内存中缓存子表的最近数据…

【CTF】2023Ciscn WEB方向题解

前言 太菜了太菜了,太久没打比赛啥也不会做,部分题目可去NSSCTF进行复现:NSSCTF 比赛体验一般,一黑灯基本上题都烂掉 unzip 这道题估计大家都会,算是一道原题了 参考:https://xz.aliyun.com/t/10533 由于环境没了,靠…

javascript获取对象的键名列表、键值列表

Object.keys&#xff1a;获取对象的键名列表 Object.values&#xff1a;获取对象的键值列表 <script>var obj {name: 1,age: 2,order: 3}const klist Object.keys(obj)const vals Object.values(obj)console.log(obj, obj)console.log(键名列表, klist)console.log(键…