写在前面

也许现在的你需要用PB完成毕业设计、需要维护远古时代的代码,又或者是你呆的公司就是要求要用PB开发项目。

不管你是出于什么原因还在使用PB,不可否认PB在数据窗口非常优秀,熟练使用之后开发数据库相关的应用非常高效

但由于PB这一框架出现得比较早,而且主要用于传统基于数据库得CS开发。

在网络、系统、数据传输等方面有很多欠缺,需要实现某些功能特别费劲,需要引入各种动态库才能实现

一、PB项目开发痛点

  • 调用基于http协议开发的webapi接口实现方式单一
  • 数据传输格式json数据的封装与解析不方便
  • 各种加密解密或者签名算法实现比较困难
  • utf8utf16ansi等字符集编码相互转换困难
  • 没法处理大文件(几百兆的txt文件下载,导入)

二、Pbidea来了

既然PB中存在这些问题,但又不得不使用PB时。

你是不是会想PB中有没有类似与Java中HutoolfastjsonLog4j等等这样的类库呢?

当然是有的,它就是今天要推荐给你的Pbidea.dll

Pbidea是大自在大佬开发的,平常大家都喊在叔。并且该项目一直在维护中,就在昨天20230804还发布了一个新版本。

它不仅可以解决上面的痛点,还封装了很多扩展功能,方便PBer们使用。

利用它,你甚至可以使用在PB中使用redisRibbitMQkafka 等这样的高并发组件。

还有你平常觉得在PB中很难实现的pdf、图片展现处理等等都能轻松实现。

这些怎么时候,在后面会一一说明

三、Pbidea 介绍

3.1 下载

① 通过GitHub下载

https://github.com/lxb320124/pbidea

② 通过QQ群下载

GitHub上面好像没有同步更新,如果你需要最新的需要通过QQ群文件下载。

由于这里不方便发群,小伙伴们找不到可以私信哦。最新版是昨天(2023年08月04日更新的)

3.2 文件目录简介

从上面渠道下载完项目后解压,目录如下。

你需要关注的主要是两个目录。9-->里面是基于PB9的demo。10-->是基于PB9以上版本的demo

3.4 运行起来

既然demo都下载下来了,那么当然是要跑起来看看了。个人电脑上安装的是PB12.5 ,所以就打开了10目录下的demo

① 打开工作空间

② 选择文件夹10下面的pbjson.pbw

③ 直接运行

四、Pbidea 使用

从上面运行起来的demo中,我们可以看到,Pbidea包含了如下功能

  • json/bson/xml等各种交换格式
  • httpclient
  • 加/解密和编码
  • FTP/sFTP/FTP服务器
  • 扩展数据类型(map,string等)
  • 压缩/解压缩
  • 数据库扩展
  • PDF浏览与dw2pdf
  • 图形图片条码、多媒体
  • 数据窗口增强
  • websocket和tcp/ip客户端
  • 高并发组件
  • 物联网开发和只能设备
  • 计算机/打印及系统
  • 控件与界面美观
  • 其他PowerBuilder扩展功能
  • 行业应用案例

接下来的小节中,将带大家怎么找对应功能的代码。并对部分功能简单一一说明

4.1 项目代码说明

websuit.pbl-->uo_json 中申明动态库

pbjons-->uo_tabpage_json 调用上面申明好的动态库中方法(具体代码实现)

4.2 json/bson/xm等各种交换格式 模块

①提供功能

  • 快速解析和生成json,基于datawinow 导入导出
  • bson数据的解析和生成
  • xml文件、字符串解析和生成

②涉及uo对象及可视化uo

  • uo_jsonuo_xmluo_bjson
  • uo_tabpage_jsonuo_tabpage_xmluo_tabpage_bson

③界面位置

4.3 httpclient 模块

① 提供功能

  • 提供基于Winhttphttp/https协议的数据访问,封装由下载和上传功能,可以直接传输json对象,自带utf8转码
  • 提供基于libcurlhttp/https协议的数据访问,封装由下载和上传功能,可以直接传输json对象,自带utf8转码

②涉及uo对象及可视化uo

  • uo_httpclientuo_curl
  • uo_tabpage_httpclientuo_tabpage_curl

③界面位置

4.4 加/解密和编码

基于openssl实现常用功能

① 提供功能

  • RSA公钥私钥生成,加密、解密、签名和验签

  • CRC32CRC16CRC18校验

  • MD5、SHA、SM3、base64、urlencode/urldecode、timestamp等编码解密

  • AES、DES、3DES、SM4 等加密解密功能

② 涉及uo对象及可视化uo

  • uo_crypto
  • uo_tabpage_crypto_rsauo_tabpage_crypto_crcuo_tabpage_crypto_auo_tabpage_crypto_sm2uo_tabpage_crypto_asn1

③ 截图

4.5 FTP/sFTP/FTP服务器

① 提供功能

  • 提供一个ftp服务器,可以共享本机文件给客户端
  • 基于libftp,完全从底层协议实现的ftp客户端
  • 基于ssh协议的FTP 客户端,除上传下载以外,还可以在服务端执行操作系统命令,相当于合并了ssh功能

②涉及uo对象及可视化uo

  • uo_ftp_serveruo_ftp
  • uo_tabpage_ftp_serveruo_tabpage_ftpuo_tabpage_ftp_browseruo_tabpage_sftp

③ 截图

4.6 扩展数据类型(map、string等)

①提供功能

  • 扩展实现了map容器
  • 扩展了二进制数据处理功能
  • 扩展了字符串处理功能
    • 正则表达式搜索、匹配、替换
    • 大文本按行处理
    • 字符集转换
    • 直接读写文本文件
    • 字符串分割
    • 控制台输出调试功能
  • 位操作与进制转换
  • 大整数biginteger处理功能
  • 日期事件处理与计算

②涉及uo对象及可视化uo

  • uo_mapuo_blobuo_stringuo_bitsuo_bigintegeruo_datatime
  • uo_tabpage_map_asn1uo_tabpage_blobuo_tabpage_stringuo_tabpage_bitsuo_tabpage_bigintegeruo_tabpage_datatime

③ 截图

4.7 压缩/解压缩

①提供功能

  • 提供zip格式的压缩和解压缩功能(还可以将BLOB数据添加进压缩包,或者将压缩包内容读取到BLOB变量)
  • 提供数据流压缩和解压缩功能。支持压缩、解压缩.gz格式文件

②涉及uo对象及可视化uo

  • uo_zipuo_compress
  • uo_tabpage_zipuo_tabpage_compress

③ 截图

4.8 数据库扩展

① 提供功能

  • 提供众多数据库连接支持,快速高效范围数据库和结果集
  • 自身数据库改进,支持断线检测功能
  • dbf文件的导入与导出
  • 解析Oracle的TNS文件为json格式
  • 提供非关系型数据库的支持

②涉及uo对象及可视化uo

  • uo_databaseuo_transationuo_dbfuo_json、`uo_kv``
  • uo_tabpage_sqluo_tabpage_transationuo_tabpage_dbfuo_tabpage_kv

③ 截图

4.9 PDF浏览与dw2dbf

① 提供功能

  • 加载pdf文件,可打印和另存
  • 将pdf文件转换成图片
  • 将pdf转换为纯文本内容,可取到每个单词
  • 在指定位置添加图片
  • 添加手写签名
  • dw生成pdf文件和图片

②涉及uo对象及可视化uo

  • uo_pdfmakeruo_pdfview
  • uo_tabpage_pdf_makeruo_tabpage_pdf_viewuo_tabpage_pdf_fpsbuo_tabpage_pdf_merge

③ 截图

4.10 图形图形条形码、多媒体

① 提供功能

  • 支持bmp、jpg、png、emf、wmf、gif、tif等格式图片加载、显示转换
  • 支持条码、二维码生成
  • 支持条码、二维码识别
  • 图片浏览控件
  • 图形处理工具,类似于windows自带的绘图工具
  • 音频文件合并阅读

② 涉及uo对象及可视化uo

  • uo_imageuo_imageviewuo_painteruo_wavfileuo_speakuo_speak_recognize

  • uo_tabpage_imageuo_tabpage_codeuo_tabpage_symboluo_tabpage_image_viewuo_tabpage_painter_chart_arcuo_tabpage_painter_chart_areauo_tabpage_painter_chart_baruo_tabpage_painter_chart_bar3d

    uo_tabpage_painter_chart_barlineuo_tabpage_painter_chart_guageuo_tabpage_painter_chart_hbar

    uo_tabpage_painter_chart_lineuo_tabpage_painter_chart_npieuo_tabpage_painter_chart_percent

    uo_tabpage_painter_chart_pieuo_tabpage_painter_chart_radaruo_tabpage_painter_chart_scatter

    uo_tabpage_painter_clip、uo_tabpage_painter_imageuo_tabpage_painter_reuo_tabpage_wav

uo_tabpage_speakuo_tabpage_recognize

③ 截图

4.11 数据窗口增强

① 提供功能

  • datawindow与excel导入与导出
  • 拖拽功能,可用于排班、排房间等业务
  • 超大文本文件导入(几百兆txt文件导入)
  • 鼠标拖拽选取获取datawindow数据
  • 数据窗口解析为json数据
  • 实时生成图片

②涉及uo对象及可视化uo

  • uo_datawindowexuo_drag_datawindowvuo_selected_datawindowuo_json
  • uo_tabpage_exceluo_tabpage_drag_datawindowuo_tabpage_datawindowuo_tabpage_datawindow_seletect

uo_tabpage_datawindow_syntaxuo_tabpage_datawindow_dimage

③ 截图

4.12 websocket和tcp/ip客户端

① 提供功能

  • websocket客户端
  • socket客户端
  • ping、支持带端口的ping
  • 基于smtp协议发送邮件
  • 基于pop协议接收邮件,并将接收到的邮件解析为json结构方便使用

② 涉及uo对象及可视化uo

  • uo_websocket_clientuo_socket_clientuo_mail
  • uo_tabpage_ws_clientuo_tabpage_socket_clientuo_tabpage_pinguo_tabpage_mail

③ 截图

4.13 高并发组件

① 提供功能

  • 提供RibbitMQ 功能
  • 提供kafka功能
  • 提供mqtt功能
  • 提供redis缓存共功能

② 涉及uo对象及可视化uo

  • uo_rabbitmquo_rabbitmq_exchangeuo_rabbitmq_queueuo_kafka_consumeruo_kafka_producer

uo_mqttuo_redis

  • uo_tabpage_hc_rabbitmquo_tabpage_hc_kafkauo_tabpage_hc_mqttuo_tabpage_hc_redis

③ 截图

4.14 物联网开发和只能设备

① 提供功能

  • 提供modbus-tcp功能
  • 海康指纹仪
  • 串口通讯
  • 读取身份证信息

② 涉及uo对象及可视化uo

  • uo_modbus_tcpuo_fingerprintuo_serialuo_sdtapi
  • uo_tabpage_modbusuo_tabpage_fingerprintuo_tabpage_serialuo_tabpage_sdtapi

③ 截图

1.15 计算机/打印机及系统

① 提供功能

  • 打印机控制相关功能
  • 无驱动打印机
  • 取ip、cpu序列号等信息
  • 多显示器管理
  • 窗口子类化处理、拦截窗口信息,自己做出判断处理
  • 多线程和进程数据共享
  • 系统环境变量管理

② 涉及uo对象及可视化uo

  • uo_printeruo_printer_usbuo_hardwareuo_monitoruo_subclassuo_thread_factoryuo_threaduo_sysenv
  • uo_tabpage_printeruo_tabpage_printer_usbuo_tabpage_printer_hardwareuo_tabpage_printer_monitor

uo_tabpage_systemuo_tabpage_subclassuo_tabpage_threaduo_tabpage_env

③ 截图

1.16 控件与界面美观

① 提供功能

  • 打开和保存对话框美化
  • 编辑器语法高亮功能
  • 计算器控件
  • 漂亮日历控件,支持鼠标、键盘 操作日期可快速跳转
  • 不同类型进度条
  • 内置字体图标
  • 基于微软最新edge webview2的浏览器控件

② 涉及uo对象及可视化uo

  • uo_scintillauo_calculatoruo_calendaruo_wait_boxuo_progressuo_messagewidgetuo_webview2

  • uo_tabpage_opensaveuo_tabpage_scintillauo_tabpage_calculatoruo_tabpage_calendaruo_tabpage_progress

    uo_tabpage_awesome uo_tabpage_webview2uo_tabpage_webview2_2

③ 截图

1.17 其他PowerBuilder扩展功能

① 提供功能

  • 各种杂项函数和功能集合
  • 保护pbd不受反编译
  • 文件读写操作增强功能
  • dll函数调用
  • pb动态编译
  • 配置文件及序列化

②涉及uo对象及可视化uo

  • uo_utilsuo_fileuo_blobuo_stringuo_logfileuo_dlluo_orcauo_config
  • uo_tabpage_pb_readeruo_tabpage_pb_varuo_tabpage_pb_safeuo_tabpage_file_op

uo_tabpage_dlluo_tabpage_orcauo_tabpage_config

③ 截图

1.18 行业应用和案例

① 提供的功能

  • 阿里cbs签名

  • 内蒙古预算管理一体化系统接口签名

  • 农业银行商户接口签名

  • 赣州银行开放接口平台

  • 工商银行二维码被扫支付接口

  • 建行互联网银企直连请求加密及返回验签方法

  • 国家医保目录上传下载接口

  • 诺诺企业发票接口加密

②涉及uo对象及可视化uo

  • uo_cryptouo_httpclientuo_curl
  • uo_tabpage_bussess_csbuo_tabpage_bussess_nmysuo_tabpage_bussess_nyyhsh

uo_tabpage_bussess_gzbankuo_tabpage_bussess_ghpayuo_tabpage_bussess_yb_ud

uo_tabpage_bussess_nnfp

③ 截图

以上对Pbidea 提供的18个功能做了简要说明,有什么不清楚的就多看看demo。

五、怎么在项目中使用Pbidea

5.1 新项目

如果是新项目,新建项目之后,直接将Pbidea.dll放入到指定路径,并将websuite.pblsciter.pblsql.pblweb.pblweb_client.pblpainter.pblhaikang.pbl 加入到工作空间中即可,当然了如果你只用到其中的部分功能,可以先只加入websuite.pbl

① 将Pbidea.dll拷贝到项目跟目录

②右键选择Properties...

③ 选择需要添加的pbl文件(pbl文件路径和项目路径同一个目录)

5.2 老项目

如果是老项目,项目中新建的uo可能与Pbidea中的uo冲突,真个引入进去可能会影响原来代码功能

我们只能按需引入,确保引入的uo和之前项目中的uo不冲突

六、小结

工欲善其事必先利其器,多花费一点时间研究下Pbidea,尽量每个demo都点一点,做到心中有数。

当我们在工作中遇到类似的需求时,就可以参考着demo中实现即可。

用了这么久PB,Pbidea最好的扩展功能动态库了,没有之一

本期内容到此就结束了,希望对你有所帮助。

我们下期再见 (●'◡'●)

PB从入坑到放弃(七)PBer们的福音来了的更多相关文章

  1. 通过CVE-2017-17215学习路由器漏洞分析,从入坑到放弃

    1.基本信息: 2017/11/27,Check Point 软件技术部门报告了一个华为 HG532 产品的远程命令执行漏洞(CVE-2017-17215),Mirai的升级版变种中已经使用该漏洞.看 ...

  2. 微信小程序从入坑到放弃之坑十二:navigator无法跳转的坑

    转自:http://www.yilingsj.com/xwzj/2018-11-25/weixin-miniprogram-navigator.html 微信小程序中的页面跳转用navigator就行 ...

  3. Python从入坑到放弃!

    Python基础  python基础 python基础之 while 逻辑运算符 格式化输出等 python基础之 基本数据类型,str方法和for循环 python基础之 列表,元组,字典 pyth ...

  4. web前端入坑第二篇:web前端到底怎么学?干货资料! 【转】

    http://blog.csdn.net/xllily_11/article/details/52145172 版权声明:本文为博主[小北]原创文章,如要转载请评论回复.个人前端公众号:前端你别闹,J ...

  5. 【Xbox one S】开箱&开机&初入坑心得

    再来一发水贴,先上产品标准照镇贴: 前言 身为一个资深单机游戏玩家,常年混迹在PC平台,但内心深处一直对主机有种迷之向往,感觉那才是单机游戏的正处之地,坐沙发上拿着手柄对着电视跌宕起伏才是正确的游戏姿 ...

  6. 3-STM32带你入坑系列(自己封装点亮一个灯的库--Keil)

    2-STM32带你入坑系列(点亮一个灯--Keil) 首先建一个stm32f103x.h的文件,然后 #include "stm32f103x.h" 还记得上一节 现在呢就是做一个 ...

  7. 2-STM32带你入坑系列(点亮一个灯--Keil)

    1-STM32带你入坑系列(STM32介绍) 首先是安装软件 这一节用Kei来实现,需要安装MDK4.7这个软件,怎么安装,自己百度哈.都学习32的人了,不会连个软件都不会安装吧....还是那句话 没 ...

  8. c#调用c++ dll 入坑记录

    1.DLL引用坑 [DllImport("NetDLL.dll", CharSet = CharSet.Ansi, CallingConvention = CallingConve ...

  9. Vue入坑教程(二)——项目结构详情介绍

    之前已经介绍了关于Vue的脚手架vue-cli的安装,以及一些文件目录介绍.具体可以查看<vue 入坑教程(一)--搭建vue-cli脚手架> 下面简单说一下具体的文件介绍 (一) pac ...

  10. 反爬虫:利用ASP.NET MVC的Filter和缓存(入坑出坑) C#中缓存的使用 C#操作redis WPF 控件库——可拖动选项卡的TabControl 【Bootstrap系列】详解Bootstrap-table AutoFac event 和delegate的分别 常见的异步方式async 和 await C# Task用法 c#源码的执行过程

    反爬虫:利用ASP.NET MVC的Filter和缓存(入坑出坑)   背景介绍: 为了平衡社区成员的贡献和索取,一起帮引入了帮帮币.当用户积分(帮帮点)达到一定数额之后,就会“掉落”一定数量的“帮帮 ...

随机推荐

  1. ubuntu实时查看网速

    可以使用ifstat这个命令 安装 apt install ifstat   1 使用,直接打命令就行 ifstat

  2. 研发三维GIS系统笔记/实现wgs84投影-002

    四叉树代码修改完善 原来的代码中,没有使用投影转换,直接使用的是世界坐标(单位是米), CELLQuadTree::CELLQuadTree( CELLTerrainInterface* pInter ...

  3. 【短道速滑十一】标准的Gabor滤波器及Log_Gabor滤波器的实现、解析、速度优化及其和Halcon中gen_gabor的比较。

    最近有朋友在研究Halcon中gen_gabor的函数,和我探讨,因为我之前也没有怎么去关注这个函数,因此,前前后后大概也折腾了有一个星期去模拟实现这个东西,虽然最终没有实现这个函数,但是也是有所收获 ...

  4. 2023平台工程崭露头角,AI 带来新机遇与挑战

    在今年,平台工程正在迅速在 IT 企业中崭露头角,成为软件开发团队的必要实践.根据 CloudBees 发布的最新报告<2023年平台工程:快速采纳和影响>,83%的受访者已经完全实施了平 ...

  5. 2023 SHCTF-校外赛道 Crypto—Wp

    WEEK1 立正 wl hgrfhg 4gNUx4NgQgEUb4NC64NHxZLg636V6CDBiDNUHw8HkapH :jdoi vl vlkw ~xrb wd nrrT Y: 凯撒解密,偏 ...

  6. 22. 从零用Rust编写正反向代理,一个数据包的神奇HTTP历险记!

    wmproxy wmproxy已用Rust实现http/https代理, socks5代理, 反向代理, 静态文件服务器,四层TCP/UDP转发,内网穿透,后续将实现websocket代理等,会将实现 ...

  7. JUC并发编程学习笔记(六)Callable(简单)

    Callable(简单) callable接口和runnable接口类似,都是为了执行另外一条线程而设计的,区别是Runnable不会返回结果也不会抛出异常. 1.可以有返回值 2.可以抛出异常 3. ...

  8. JUC并发编程学习笔记(七)常用的辅助类

    常用的辅助类 CountDownLatch 这是一个JUC计数器辅助类,计数器有加有减,这是减. 使用方法 package org.example.demo; import java.util.con ...

  9. JUC并发编程学习笔记(八)读写锁

    读写锁 ReadWriteLock ReadWriteLock只存在一个实现类那就是ReentrantReadWriteLock,他可以对锁实现更加细粒化的控制 读的时候可以有多个阅读器线程同时参与, ...

  10. 第1章 .NET起步

    1.1 什么是.NET? .NET 8.0 SDK下载地址:https://dotnet.microsoft.com/zh-cn/download/dotnet/8.0 .NET 是一个免费的跨平台开 ...