bcariveau / vcard
这个 VCard PHP 类可以生成包含一些数据的 vCard。当在 iOS 设备上使用时,将导出为 .ics 文件,因为 iOS 设备不支持默认的 .vcf 文件。
1.7.2
2019-03-02 13:21 UTC
Requires
- php: >=5.3.3
- behat/transliterator: ~1.0
Requires (Dev)
- phpunit/phpunit: 4.6.*
README
这个 VCard PHP 库可以生成包含一些数据的 vCard。当使用 iOS 设备(iOS 8 以下版本)时,将导出为 .ics 文件,因为 iOS 设备不支持默认的 .vcf 文件。
注意:我们正在开发一个全新的版本,用于与 vCard 4.0 版本一起工作,代码质量极高。请查看新版本
用法
安装
composer require jeroendesloovere/vcard
这将使用 Composer 安装 vcard 的最新版本
示例
use JeroenDesloovere\VCard\VCard; // define vcard $vcard = new VCard(); // define variables $lastname = 'Desloovere'; $firstname = 'Jeroen'; $additional = ''; $prefix = ''; $suffix = ''; // add personal data $vcard->addName($lastname, $firstname, $additional, $prefix, $suffix); // add work data $vcard->addCompany('Siesqo'); $vcard->addJobtitle('Web Developer'); $vcard->addRole('Data Protection Officer'); $vcard->addEmail('info@jeroendesloovere.be'); $vcard->addPhoneNumber(1234121212, 'PREF;WORK'); $vcard->addPhoneNumber(123456789, 'WORK'); $vcard->addAddress(null, null, 'street', 'worktown', null, 'workpostcode', 'Belgium'); $vcard->addLabel('street, worktown, workpostcode Belgium'); $vcard->addURL('http://www.jeroendesloovere.be'); $vcard->addPhoto(__DIR__ . '/landscape.jpeg'); // return vcard as a string //return $vcard->getOutput(); // return vcard as a download return $vcard->download(); // save vcard on disk //$vcard->setSavePath('/path/to/directory'); //$vcard->save();
解析示例
解析器可以传递一个 VCard 字符串,如下所示
// load VCardParser classes use JeroenDesloovere\VCard\VCardParser; $parser = new VCardParser($vcardString); echo $parser->getCardAtIndex(0)->fullname; // Prints the full name.
或使用一个带有文件名的工厂方法
$parser = VCardParser::parseFromFile('path/to/file.vcf'); echo $parser->getCardAtIndex(0)->fullname; // Prints the full name.
对框架的支持
我创建了一个 Symfony Bundle:VCard Bundle
例如在 Laravel 中的使用
return Response::make( $this->vcard->getOutput(), 200, $this->vcard->getHeaders(true) );
文档
类有良好的内联文档。如果您使用了一个不错的 IDE,您将看到每个方法都带有 PHPDoc 文档。
贡献
欢迎贡献,并将得到全面认可。
拉取请求
添加或更新代码
- 代码语法 - 请确保代码语法与该包的其他部分保持一致。
- 添加单元测试! - 如果您的补丁没有测试,则不会被接受。
- 记录任何行为变更 - 确保 README 和任何其他相关文档都保持最新。
- 考虑我们的发布周期 - 我们尝试遵循 semver。随机破坏公共 API 不是一种选择。
- 创建主题分支 - 请不要要求我们从您的 master 分支拉取。
- 每个特性一个拉取请求 - 如果您想做更多的事情,请发送多个拉取请求。
- 发送连贯的历史记录 - 确保您的拉取请求中的每个单独提交都是有意义的。如果您在开发过程中不得不进行多个中间提交,请在提交之前将它们压缩。
问题
用于错误报告或代码讨论。
有关在 help.github.com 上使用 GitHub 的更多信息。
鸣谢
许可证
该模块受 MIT 许可证的许可。简而言之,这个许可证允许您做任何事情,只要版权声明仍然存在。