TaobaoExport.php 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263
  1. <?php
  2. namespace app\home\controller;
  3. use think\facade\Lang;
  4. /**
  5. * ============================================================================
  6. *
  7. * ============================================================================
  8. * 版权所有 2014-2028 浙江惠利玛产业互联网有限公司,并保留所有权利。
  9. * 网站地址: https://www.valimart.net/
  10. * ----------------------------------------------------------------------------
  11. *
  12. * ============================================================================
  13. * 控制器
  14. */
  15. class TaobaoExport extends BaseGoods {
  16. public function initialize() {
  17. Lang::load(base_path() . 'home/lang/' . config('lang.default_lang') . '/taobao_export.lang.php');
  18. parent::initialize();
  19. }
  20. public function export_image(){
  21. $goods_id = intval(input('param.goods_id'));
  22. if (!$goods_id) {
  23. $this->error(lang('param_error'));
  24. }
  25. // 商品详细信息
  26. $goods_model = model('goods');
  27. $goods_detail = $goods_model->getGoodsDetail($goods_id);
  28. if (!$goods_detail || empty($goods_detail['goods_info'])) {
  29. $this->error(lang('goods_index_no_goods'));
  30. }
  31. $goods_info = $goods_detail['goods_info'];
  32. $exportPath = BASE_UPLOAD_PATH . DIRECTORY_SEPARATOR . ATTACH_TAOBAO . DIRECTORY_SEPARATOR . 'goods_image_' . $goods_info['goods_id'];
  33. if (!file_exists($exportPath.'.zip')) {
  34. if (!is_dir($exportPath)) {
  35. mkdir($exportPath, 0777, true);
  36. }//如果目录不存在,则创建
  37. //图片
  38. $image_path_1=iconv("UTF-8", "GBK", $exportPath . DIRECTORY_SEPARATOR . '主图');
  39. if (!is_dir($image_path_1)) {
  40. mkdir($image_path_1, 0777);
  41. }//如果目录不存在,则创建
  42. $image_path_2=iconv("UTF-8", "GBK", $exportPath . DIRECTORY_SEPARATOR . '详情图');
  43. if (!is_dir($image_path_2)) {
  44. mkdir($image_path_2, 0777);
  45. }//如果目录不存在,则创建
  46. foreach ($goods_detail['goods_image'] as $key_gi => $val_gi) {
  47. @file_put_contents($image_path_1 . DIRECTORY_SEPARATOR . basename($val_gi[2]), file_get_contents($val_gi[2]));
  48. }
  49. $goods_body=htmlspecialchars_decode($goods_info['goods_body']);
  50. if(preg_match_all("/<\s*img\s+[^>]*?src\s*=\s*(\'|\")(.*?)\\1[^>]*?\/?\s*>/i",$goods_body,$matches)){
  51. foreach($matches[2] as $match){
  52. @file_put_contents($image_path_2 . DIRECTORY_SEPARATOR . basename($match), file_get_contents($match));
  53. }
  54. }
  55. $zip = new \ZipArchive();
  56. if ($zip->open($exportPath . '.zip', \ZIPARCHIVE::OVERWRITE | \ZIPARCHIVE::CREATE) !== TRUE) {
  57. $this->error(lang('zip_create_fail'));
  58. }
  59. $this->createZip(opendir($exportPath), $zip, $exportPath);
  60. $zip->close();
  61. //删除
  62. $this->deldir($exportPath);
  63. }
  64. header('Content-Type:text/html;charset=utf-8');
  65. header('Content-disposition:attachment;filename='.'goods_image_' . $goods_info['goods_id'].'.zip');
  66. $filesize = filesize($exportPath.'.zip');
  67. readfile($exportPath.'.zip');
  68. header('Content-length:'.$filesize);
  69. exit;
  70. }
  71. public function export_csv() {
  72. $goods_id = intval(input('param.goods_id'));
  73. if (!$goods_id) {
  74. $this->error(lang('param_error'));
  75. }
  76. // 商品详细信息
  77. $goods_model = model('goods');
  78. $goods_detail = $goods_model->getGoodsDetail($goods_id);
  79. if (!$goods_detail || empty($goods_detail['goods_info'])) {
  80. $this->error(lang('goods_index_no_goods'));
  81. }
  82. $goods_info = $goods_detail['goods_info'];
  83. $exportPath = BASE_UPLOAD_PATH . DIRECTORY_SEPARATOR . ATTACH_TAOBAO . DIRECTORY_SEPARATOR . 'goods_csv_' . $goods_info['goods_id'];
  84. if (!file_exists($exportPath.'.zip')) {
  85. if (!is_dir($exportPath)) {
  86. mkdir($exportPath, 0777, true);
  87. }//如果目录不存在,则创建
  88. $str = "version 1.00
  89. title cid seller_cids stuff_status location_state location_city item_type price auction_increment num valid_thru freight_payer post_fee ems_fee express_fee has_invoice has_warranty approve_status has_showcase list_time description cateProps postage_id has_discount modified upload_fail_msg picture_status auction_point picture video skuProps inputPids inputValues outer_id propAlias auto_fill num_id local_cid navigation_type user_name syncStatus is_lighting_consigment is_xinpin foodparame features buyareatype global_stock_type global_stock_country sub_stock_type item_size item_weight sell_promise custom_design_flag wireless_desc barcode sku_barcode newprepay subtitle cpv_memo input_custom_cpv qualification add_qualification o2o_bind_service tmall_extend product_combine tmall_item_prop_combine taoschema_extend
  90. 宝贝名称 宝贝类目 店铺类目 新旧程度 省 城市 出售方式 宝贝价格 加价幅度 宝贝数量 有效期 运费承担 平邮 EMS 快递 发票 保修 放入仓库 橱窗推荐 开始时间 宝贝描述 宝贝属性 邮费模版ID 会员打折 修改时间 上传状态 图片状态 返点比例 新图片 视频 销售属性组合 用户输入ID串 用户输入名-值对 商家编码 销售属性别名 代充类型 数字ID 本地ID 宝贝分类 用户名称 宝贝状态 闪电发货 新品 食品专项 尺码库 采购地 库存类型 国家地区 库存计数 物流体积 物流重量 退换货承诺 定制工具 无线详情 商品条形码 sku 条形码 7天退货 宝贝卖点 属性值备注 自定义属性值 商品资质 增加商品资质 关联线下服务 tmall扩展字段 产品组合 tmall属性组合 taoschema扩展字段
  91. ";
  92. //图片
  93. if (!is_dir($exportPath . DIRECTORY_SEPARATOR . 'goods_' . $goods_info['goods_id'])) {
  94. mkdir($exportPath . DIRECTORY_SEPARATOR . 'goods_' . $goods_info['goods_id'], 0777);
  95. }//如果目录不存在,则创建
  96. $goods_image = "";
  97. foreach ($goods_detail['goods_image'] as $key_gi => $val_gi) {
  98. $temp = explode('.', basename($val_gi[2]));
  99. @file_put_contents($exportPath . DIRECTORY_SEPARATOR . 'goods_' . $goods_info['goods_id'] . DIRECTORY_SEPARATOR . $temp[0] . '.tbi', file_get_contents($val_gi[2]));
  100. $goods_image .= $temp[0] . ":1:" . $key_gi . "|;";
  101. }
  102. $str .= $goods_info['goods_name'] . " " . //宝贝名称
  103. "" . " " . //宝贝类目
  104. "" . " " . //店铺类目
  105. "1" . " " . //新旧程度
  106. "" . " " . //省
  107. "" . " " . //城市
  108. "1" . " " . //出售方式
  109. $goods_info['goods_price'] . " " . //宝贝价格
  110. "" . " " . //加价幅度
  111. $goods_info['goods_storage'] . " " . //宝贝数量
  112. "0" . " " . //有效期
  113. "2" . " " . //运费承担
  114. "5" . " " . //平邮
  115. "20" . " " . //EMS
  116. "15" . " " . //快递
  117. "0" . " " . //发票
  118. "0" . " " . //保修
  119. "2" . " " . //放入仓库
  120. "0" . " " . //橱窗推荐
  121. "" . " " . //开始时间
  122. '"'.str_replace('"', '""', htmlspecialchars_decode($goods_info['goods_body'])).'"' . " " . //宝贝描述
  123. "" . " " . //宝贝属性
  124. "" . " " . //邮费模版ID
  125. "" . " " . //会员打折
  126. "" . " " . //修改时间
  127. "" . " " . //上传状态
  128. "" . " " . //图片状态
  129. "0" . " " . //返点比例
  130. $goods_image . " " . //新图片
  131. "" . " " . //视频
  132. "" . " " . //销售属性组合
  133. "" . " " . //用户输入ID串
  134. "" . " " . //用户输入名-值对
  135. $goods_info['goods_serial'] . " " . //商家编码
  136. "" . " " . //销售属性别名
  137. "" . " " . //代充类型
  138. "0" . " " . //数字ID
  139. "-1" . " " . //本地ID
  140. "1" . " " . //宝贝分类
  141. "" . " " . //用户名称
  142. "" . " " . //宝贝状态
  143. "227" . " " . //闪电发货
  144. "224" . " " . //新品
  145. "" . " " . //食品专项
  146. "" . " " . //尺码库
  147. "0" . " " . //采购地
  148. "-1" . " " . //库存类型
  149. "" . " " . //国家地区
  150. "2" . " " . //库存计数
  151. "bulk:0" . " " . //物流体积
  152. "300" . " " . //物流重量
  153. "0" . " " . //退换货承诺
  154. "-1" . " " . //定制工具
  155. "" . " " . //无线详情
  156. "" . " " . //商品条形码
  157. ";;;" . " " . //sku 条形码
  158. "1" . " " . //7天退货
  159. $goods_info['goods_advword'] . " " . //宝贝卖点
  160. "" . " " . //属性值备注
  161. "" . " " . //自定义属性值
  162. "" . " " . //商品资质
  163. "" . " " . //增加商品资质
  164. "" . " " . //关联线下服务
  165. "" . " " . //tmall扩展字段
  166. "" . " " . //产品组合
  167. "" . " " . //tmall属性组合
  168. "" . " "; //taoschema扩展字段
  169. $str = iconv("UTF-8", "UTF-16LE", $str);
  170. $str = "\xFF\xFE" . $str; //添加BOM
  171. file_put_contents($exportPath . DIRECTORY_SEPARATOR . 'goods_' . $goods_info['goods_id'] . '.csv', $str);
  172. $zip = new \ZipArchive();
  173. if ($zip->open($exportPath . '.zip', \ZIPARCHIVE::OVERWRITE | \ZIPARCHIVE::CREATE) !== TRUE) {
  174. $this->error(lang('zip_create_fail'));
  175. }
  176. $this->createZip(opendir($exportPath), $zip, $exportPath);
  177. $zip->close();
  178. //删除
  179. $this->deldir($exportPath);
  180. }
  181. header('Content-Type:text/html;charset=utf-8');
  182. header('Content-disposition:attachment;filename='.'goods_csv_' . $goods_info['goods_id'].'.zip');
  183. $filesize = filesize($exportPath.'.zip');
  184. readfile($exportPath.'.zip');
  185. header('Content-length:'.$filesize);
  186. exit;
  187. }
  188. /* 压缩多级目录
  189. $openFile:目录句柄
  190. $zipObj:Zip对象
  191. $sourceAbso:源文件夹路径
  192. */
  193. private function createZip($openFile, $zipObj, $sourceAbso, $newRelat = '') {
  194. while (($file = readdir($openFile)) != false) {
  195. if ($file == "." || $file == "..")
  196. continue;
  197. /* 源目录路径(绝对路径) */
  198. $sourceTemp = $sourceAbso . '/' . $file;
  199. /* 目标目录路径(相对路径) */
  200. $newTemp = $newRelat == '' ? $file : $newRelat . '/' . $file;
  201. if (is_dir($sourceTemp)) {
  202. //echo '创建'.$newTemp.'文件夹<br/>';
  203. $zipObj->addEmptyDir($newTemp); /* 这里注意:php只需传递一个文件夹名称路径即可 */
  204. $this->createZip(opendir($sourceTemp), $zipObj, $sourceTemp, $newTemp);
  205. }
  206. if (is_file($sourceTemp)) {
  207. //echo '创建'.$newTemp.'文件<br/>';
  208. $zipObj->addFile($sourceTemp, $newTemp);
  209. }
  210. }
  211. }
  212. //删除指定文件夹以及文件夹下的所有文件
  213. private function deldir($dir) {
  214. //先删除目录下的文件:
  215. $dh = opendir($dir);
  216. while ($file = readdir($dh)) {
  217. if ($file != "." && $file != "..") {
  218. $fullpath = $dir . "/" . $file;
  219. if (!is_dir($fullpath)) {
  220. unlink($fullpath);
  221. } else {
  222. $this->deldir($fullpath);
  223. }
  224. }
  225. }
  226. closedir($dh);
  227. //删除当前文件夹:
  228. if (rmdir($dir)) {
  229. return true;
  230. } else {
  231. return false;
  232. }
  233. }
  234. }