windwos 安装 pysqlcipher3

这篇具有很好参考价值的文章主要介绍了windwos 安装 pysqlcipher3。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

windwos 安装 pysqlcipher3

安装软件

安装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 install

pip 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 openssl
         openssl_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 the
        amalgamation and make sure the following files are present in the
        amalgamation 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 linker
                ext.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就可以了文章来源地址https://www.toymoban.com/news/detail-467972.html

参考文章

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

到了这里,关于windwos 安装 pysqlcipher3的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • windwos开机自启动位置

    1、公共自启动文件夹,该目录下普通权限软件快捷方式可开机自启; win r打开运行窗口输入shell:Common Startup   2、HKEY_LOCAL_MACHINESYSTEMCurrentControlSetServices 该目录下似乎是服务能自启动;    3、HKEY_LOCAL_MACHINESOFTWAREWow6432NodeMicrosoftWindowsCurrentVersionRun HKEY_LOCAL_MACHINESOFTWARE

    2024年02月13日
    浏览(21)
  • windwos使用FRP方式

    建议查看流程图哦 当今绝大部分都是这个操作系统了 解压好后主要用到上面这两个东西 把里面的配置信息全部删除即可 配置方式如下 下面这个是frp的服务器(服务端口的配置) server_addr = frp.freefrp.net 下面是链接这个服务器的端口 server_port = 7000 下面是连接端口的密码 token =

    2024年02月13日
    浏览(32)
  • Windwos server 服务器 安全基线 安全加固操作

    目录 账号管理、认证授权 账号 ELK-Windows-01-01-01  ELK-Windows-01-01-02 ELK-Windows-01-01-03 口令 ELK-Windows-01-02-01 ​​​​​​​ELK-Windows-01-02-02 ​​​​​​​授权 ELK-Windows-01-03-01 ​​​​​​​ELK-Windows-01-03-02 ​​​​​​​ELK-Windows-01-03-03 ​​​​​​​ ELK-Windows-01-03-04 ​​

    2024年02月03日
    浏览(55)
  • windwos2016 由于没有远程桌面授权服务器可以提供许可证

    经常会遇到,server2016、server2012、server2008操作系统,安装远程桌面服务之后没有激活,经过120天到期之后,没办法再使用,重新安装激活远程桌面服务也不能用。 1、regedit进入注册表删除如下注册表内容 HKEY_LOCAL_MACHINESoftwareMicrosoftMSLicensing HKEY_LOCAL_MACHINESYSTEMCurrentControlSe

    2024年02月13日
    浏览(39)
  • Windwos10系统提示”无法完成更新、正在撤销更改、请不要关闭你的计算机“解决办法

    如下图提示:长时间卡在这个位置 按照下列方式选择 强制重启再显示加载圆圈的时候再强制重启连续三次 2.查看高级选项 3.选择登录的账户输入密码 4.再弹出的cmd窗口输入以下俩条命令 5.关闭cmd窗口,选择继续使用 6.再这个界面下连续按5下shift键弹出cmd 7.在cmd中输入 8.在弹

    2024年02月06日
    浏览(41)
  • 内网穿透实战应用-windwos10系统搭建我的世界服务器,内网穿透实现联机游戏Minecraft

    今天和大家分享一下只需简单几步即可在windwos系统搭建我的世界服务器,并通过cpolar内网穿透工具将本地服务暴露到公网连接,实现与小伙伴一起联机游戏。 以windows10系统为例,配置java环境,搭建我的世界服务器,下载最新版java版本 https://www.oracle.com/java/technologies/downloads/

    2024年02月11日
    浏览(50)
  • pyinstaller打包提示PermissionError: [Errno 13] Permission denied....\\ucrtbase.dll 的解决办法:@Windwos10 64位

    首先,ucrtbase.dll是一个windows的dll的文件,和Pycharm没有太大关系,是一个windows操作系统和C++的一个交互的dll的动态库,显然,Pycharm调用他的接口API以至于,可以让我们要打包的EXE文件运行起来。 What Is Ucrtbase.dll The ucrtbased dll file is a software component of Microsoft Visual C++ that is an

    2024年02月06日
    浏览(70)
  • MySQL三种安装方法(yum安装、编译安装、二进制安装)

    切记:一定要关闭防火墙和selinux!!! 服务器配置:2C4G即可,一台 mysql的官方网站:www.mysql.com 中文官网:https://www.mysql.com/cn/ 1、下载mysql的yum源 2、安装mysql的yum仓库 3、配置yum源 4、安装数据库 5、查找密码 6、修改密码 两种方式: 第一种:登录数据库后操作 第二种:免入

    2024年02月07日
    浏览(53)
  • 【conda安装】mamba安装 ==conda安装记录

    mamba文档 mamba安装教程 Mamba 是一个快速、强大且跨平台的包管理器 。 它运行在 Windows、OS X 和 Linux(包括 ARM64 和 PPC64LE)上, 并且与软件包完全兼容conda,支持 conda 的大部分命令 。 该mamba-org组织拥有多种 Mamba 风格: mamba:一个基于 Python 的 CLI 被认为是 的直接替代品conda,

    2024年02月09日
    浏览(51)
  • Nginx安装步骤——离线安装与在线安装详解

    1.安装环境 依赖包下载地址 官方下载地址:https://pkgs.org/download/gcc-c++ 阿里云镜像站:http://mirrors.aliyun.com/centos/7/os/x86_64/Packages/ 1.1 检查是否已安装gcc,如果最后一行有版本信息则为已有相关环境 如果没有则将以下依赖包下载并上传到服务器 gcc依赖清单: cpp-4.8.5-44.el7.x86_64

    2024年02月14日
    浏览(46)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包