You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
yanzong/vendor/huifurepo/dg-php-sdk/BsPayDemo/V2InvoiceOpenRequestDemo.php

152 lines
4.9 KiB

<?php
/**
* 发票开具 - 示例
*
* @author sdk-generator
* @Description
*/
namespace BsPayDemo;
// 1. 资源及配置加载
require_once dirname(__FILE__) . "/loader.php";
require_once dirname(__FILE__). "/../BsPaySdk/request/V2InvoiceOpenRequest.php";
use BsPaySdk\core\BsPayClient;
use BsPaySdk\request\V2InvoiceOpenRequest;
// 2.组装请求参数
$request = new V2InvoiceOpenRequest();
// 请求流水号
$request->setReqSeqId(date("YmdHis").mt_rand());
// 请求时间
$request->setReqDate(date("Ymd"));
// 渠道号汇付商户号为空时,必传;&lt;font color&#x3D;&quot;green&quot;&gt;示例值:6666000109812124&lt;/font&gt;
// $request->setChannelId("test");
// 发票类型
$request->setIvcType("1");
// 开票类型
$request->setOpenType("0");
// 购方单位名称
$request->setBuyerName("张三");
// 含税合计金额(元)
$request->setOrderAmt("70.00");
// 冲红原因open_type&#x3D;1时必填01:开票有误02:销货退回03:服务终止04:销售转让
// $request->setRedApplyReason("test");
// 冲红申请来源open_type&#x3D;1时必填01:销方02:购方
// $request->setRedApplySource("test");
// 原发票代码openType&#x3D;1时必填;参见[发票右上角](https://paas.huifu.com/partners/api/#/fp/api_fp_yanglitu.md);&lt;font color&#x3D;&quot;green&quot;&gt;示例值:144032209110&lt;/font&gt;
$request->setOriIvcCode("90222082");
// 原发票号码openType&#x3D;1时必填;参见[发票右上角](https://paas.huifu.com/partners/api/#/fp/api_fp_yanglitu.md);&lt;font color&#x3D;&quot;green&quot;&gt;示例值:20685767&lt;/font&gt;
$request->setOriIvcNumber("150000020026");
// 开票商品信息
$request->setGoodsInfos(getGoodsInfosRc());
// 开票人信息
$request->setPayerInfo(getPayerInfo());
// 设置非必填字段
$extendInfoMap = getExtendInfos();
$request->setExtendInfo($extendInfoMap);
// 3. 发起API调用
$client = new BsPayClient();
$result = $client->postRequest($request);
if (!$result || $result->isError()) { //失败处理
var_dump($result -> getErrorInfo());
} else { //成功处理
var_dump($result);
}
/**
* 非必填字段
*
*/
function getExtendInfos() {
// 设置非必填字段
$extendInfoMap = array();
// 汇付商户号
$extendInfoMap["huifu_id"]= "6666000107430944";
// 外部商户号
$extendInfoMap["ext_mer_id"]= "";
// 税控盘编号
$extendInfoMap["tax_device_id"]= "661919694739";
// 购方单位识别号
$extendInfoMap["buyer_no"]= "";
// 购方单位地址
$extendInfoMap["buyer_address"]= "";
// 购方单位电话
$extendInfoMap["buyer_tel"]= "";
// 购方开户行名称
$extendInfoMap["buyer_bank_name"]= "";
// 购方银行账号
$extendInfoMap["buyer_acct_no"]= "";
// 购方企业类型
$extendInfoMap["buyer_ent_type"]= "";
// 收票人手机号
$extendInfoMap["rec_ivc_phone"]= "";
// 收票人邮件
$extendInfoMap["rec_ivc_email"]= "test@126.com";
// 备注
$extendInfoMap["resv"]= "备注";
// 特殊票种标识
$extendInfoMap["special_flag"]= "00";
// 红字信息表编号
$extendInfoMap["red_info_number"]= "";
// 开票结果异步通知地址
$extendInfoMap["callback_url"]= "virgo://http://192.168.85.157:30031/sspm/testVirgo";
return $extendInfoMap;
}
function getGoodsInfosRc() {
$dto = array();
// 发票行性质
$dto["ivc_nature"] = "0";
// 商品序号ivc_type&#x3D;1 红票必填,要与开具的蓝票商品一致;&lt;font color&#x3D;&quot;green&quot;&gt;示例值:备注&lt;/font&gt;
$dto["goods_serial_num"] = "";
// 商品名称goodsCode不为空时必填;&lt;font color&#x3D;&quot;green&quot;&gt;示例值:&lt;/font&gt;
$dto["goods_name"] = "预付卡";
// 税率goodsCode不为空时必填,最多三位小数;&lt;font color&#x3D;&quot;green&quot;&gt;示例值:0.130&lt;/font&gt;
$dto["tax_rate"] = "0.03";
// 金额(元)
$dto["trans_amt"] = "70.00";
// 商品id
$dto["goods_id"] = "";
// 商品税收分类编码
$dto["goods_code"] = "6010000000000000000";
// 规格型号
$dto["goods_model"] = "";
// 计量单位
$dto["goods_unit"] = "";
// 优惠政策标识
$dto["preferential_flag"] = "0";
// 零税率标示
$dto["zero_tax_rate_flag"] = "";
// 增值税特殊管理
$dto["add_tax_spec_manage"] = "";
// 含税标识
$dto["is_price_con_tax"] = "1";
// 数量
$dto["goods_count"] = "7";
// 单价
$dto["goods_price"] = "10";
// 折扣金额(元)
$dto["sale_amt"] = "";
$dtoList = array();
array_push($dtoList, $dto);
return json_encode($dtoList,JSON_UNESCAPED_UNICODE|JSON_UNESCAPED_SLASHES);
}
function getPayerInfo() {
$dto = array();
// 开票人
$dto["payer_name"] = "开票人";
// 收款人
$dto["payee"] = "收款人";
// 复核人
$dto["reviewer"] = "复核";
return json_encode($dto,JSON_UNESCAPED_UNICODE|JSON_UNESCAPED_SLASHES);
}