我们有一个后端系统,在填写表格时会生成一个 PDF - 然后将此 PDF 上传到保管箱,并检索到文件的链接,然后将其添加到数据库中并且对我们的供应商可见。
我看了高低——但获得这些链接的唯一方法是使用createTemporaryDirectLink指令。但是,这些链接是临时的,会在几个小时后过期。
我正在寻找可共享的非过期链接。
这是我当前运行良好的代码
// Dropbox //
$dropbox_config = array(
'key' => 'xxxx',
'secret' => 'xxxx'
);
$accessToken='xxx-xxxxx';
$appInfo = dbx\AppInfo::loadFromJson($dropbox_config);
$webAuth = new dbx\WebAuthNoRedirect($appInfo, "PHP-Example/1.0");
$dbxClient = new dbx\Client($accessToken, "PHP-Example/1.0");
$sqlQuery = "select dropboxLink from get_order where orderId='".$lastOrderId."'";
$rsGetDropLink = mysqli_query($dbLink,$sqlQuery);
$rowGetDropLink = mysqli_fetch_assoc($rsGetDropLink);
$f = fopen("Orders/".$rowGetDropLink['dropboxLink'].'.pdf', "rb");
$result = $dbxClient->uploadFile("/Orders/".$rowGetDropLink['dropboxLink'].'.pdf', dbx\WriteMode::add(), $f);
fclose($f);
print_r($result);
$file = $dbxClient->getMetadata("/Orders/".$rowGetDropLink['dropboxLink'].'.pdf');
$dropboxPath = $file['path'];
$pathError = dbx\Path::findError($dropboxPath);
if ($pathError !== null) {
fwrite(STDERR, "Invalid <dropbox-path>: $pathError\n");
die;
}
$link = $dbxClient->createTemporaryDirectLink($dropboxPath);
$dw_link = $link[0]."?dl=1";
$sqlQuery = "update get_order set fullDropboxLink='".$dw_link."' where orderId='".$lastOrderId."'";
mysqli_query($dbLink,$sqlQuery);
// Dropbox ends//
header("location: thankyou.php?ordId=".$lastOrderId.'&categoryId='.$_REQUEST['categoryId']);
如您所见,我们使用了 createTemporaryDirectLink 方法,该方法会获取一个超时过期的临时链接。
我们的供应商经常每两天检查一次这些文件 - 所以这是一个不可用的解决方案。