POCO(便携式组件)C++库是:
- 一个C++类库集合,在概念上类似于Java类库或.NET框架。
- 专注于解决常见实际问题。
- 专注于"互联网时代"的网络中心应用程序。
- 使用高效、现代、100%符合ANSI/ISO标准的C++编写。
- 基于并补充C++标准库/STL。
- 高度可移植,适用于从嵌入式到服务器的多种不同平台。
- 开源,采用Boost软件许可证。
快速入门(使用CMake)
先决条件
- CMake 3.5或更高版本
- 支持C++17的编译器(Visual C++ 2017、GCC 8.0、Clang 5或更新版本)
- OpenSSL头文件和库(可选,但推荐)
- MySQL、PostgreSQL和ODBC客户端库(可选)
大多数Unix/Linux系统已预装OpenSSL。如果您的系统没有OpenSSL,请从https://www.openssl.org或其他来源获取。您无需自行构建OpenSSL - 二进制发行版即可。例如,通过Debian APT:
$ apt-get install openssl libssl-dev
在macOS上,安装OpenSSL最简单的方法是通过Homebrew:
$ brew install openssl
在Windows上安装OpenSSL最简单的方法是使用二进制(预构建)版本,例如来自Shining Light Productions的Windows安装程序。OpenSSL也可以通过vcpkg
包管理器安装。
在Windows上,POCO也可以使用原生Windows TLS API(SChannel)。
安装所有依赖项(Linux和macOS)
所有依赖项可以通过以下命令安装:
Debian Linux(包括Ubuntu和Raspbian)
$ sudo apt-get -y update && sudo apt-get -y install git g++ make cmake libssl-dev libmysqlclient-dev libpq-dev
RedHat Linux
$ sudo yum install -y git gcc-c++ make cmake3 openssl-devel mysql-devel postgresql-devel
macOS(使用Homebrew)
$ brew install cmake openssl mysql-client libpq
使用CMake构建(Linux、macOS、Windows)
CMake(3.5版或更高版本)是推荐用于构建POCO C++库的构建系统。
$ git clone -b main https://github.com/pocoproject/poco.git
$ cd poco
$ mkdir cmake-build
$ cd cmake-build
$ cmake ..
$ cmake --build . --config Release
在macOS上,需要通过设置OPENSSL_ROOT_DIR
CMake变量来告诉CMake在哪里找到OpenSSL头文件和库。例如,如果OpenSSL是通过Homebrew安装的,cmake
调用变为:
$ cmake .. -DOPENSSL_ROOT_DIR=/opt/homebrew/opt/openssl@3
类似地,可以指定其他外部库的位置:
$ cmake .. -DOPENSSL_ROOT_DIR=/opt/homebrew/opt/openssl@3 -DMYSQL_ROOT_DIR=/opt/homebrew/opt/mysql-client -DPostgreSQL_ROOT_DIR=/opt/homebrew/opt/libpq
其他常见的CMake构建方式(如cmake-gui
)也可以使用。
还有一些项目特定的CMake变量可以更改。
交叉编译
通过适当的CMake工具链文件(通过CMAKE_TOOLCHAIN_FILE
CMake变量指定),POCO C++库可以交叉编译用于嵌入式Linux系统:
$ cmake .. -DCMAKE_TOOLCHAIN_FILE=/path/to/mytoolchain.cmake -DCMAKE_INSTALL_PREFIX=/path/to/target
安装
POCO C++库的头文件和库可以选择通过构建install
目标来安装。
$ sudo cmake --build . --target install
默认安装位置在Linux和macOS上是/usr/local/
,在Windows上是C:\Program Files (x64)\
,可以通过设置CMAKE_INSTALL_PREFIX
CMake变量来覆盖。
构建和安装 - 使用vcpkg
您可以使用vcpkg依赖管理器下载和安装poco:
$ git clone https://github.com/Microsoft/vcpkg.git
$ cd vcpkg
$ ./bootstrap-vcpkg.sh
$ ./vcpkg integrate install
$ ./vcpkg install poco
vcpkg中的poco端口由Microsoft团队成员和社区贡献者保持更新。如果版本过时,请在vcpkg仓库上创建问题或拉取请求。
构建和安装 - 使用Conan
您可以使用Conan(https://github.com/conan-io/conan)包管理器下载和安装poco。首先需要安装Conan(https://conan.io/downloads.html):
您可以从Conan Center(https://conan.io/center.html)安装Poco库:
$ conan install -r conancenter poco/1.12.0@
或者,您可以下载Poco配方并在本地构建:
$ conan install -r conancenter poco/1.12.0@ --build=poco
Conan Center中的Poco配方和包由Conan团队成员和社区贡献者保持更新。如果版本过时,或者您发现任何错误行为,请在Conan Center Index仓库上创建问题或拉取请求(https://github.com/conan-io/conan-center-index)。
不使用CMake构建
如果您不想或无法使用CMake,POCO也可以使用Visual Studio(包含项目和解决方案文件)或GNU Make(Linux、macOS和其他支持的Unix平台)构建。
请参阅文档以获取更多信息。
通过包管理器获取POCO
POCO也可以通过不同的包管理器获得。
社区和贡献
POCO拥有活跃的用户和贡献社区,请访问我们的网站和博客。POCO相关问题的答案也可以在Stack Overflow上找到。
请参阅CONTRIBUTING以提交贡献、错误报告、功能请求或安全问题。
POCO vs. Boost
关于Boost,尽管有一些功能重叠,POCO最好被视为Boost的补充(而不是替代)。并排使用Boost和POCO是非常常见的情况。