aliPayChannelForm.vue 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349
  1. <template>
  2. <div>
  3. <el-dialog :visible.sync="transferParam.aliPayOpen" :title="title" @closed="close" append-to-body width="800px">
  4. <el-form ref="aliPayForm" :model="form" :rules="rules" size="medium" label-width="100px"
  5. v-loading="transferParam.loading">
  6. <el-form-item label-width="180px" label="渠道费率" prop="feeRate">
  7. <el-input v-model="form.feeRate" placeholder="请输入渠道费率" clearable :style="{width: '100%'}">
  8. <template slot="append">%</template>
  9. </el-input>
  10. </el-form-item>
  11. <el-form-item label-width="180px" label="开放平台APPID" prop="aliPayConfig.appId">
  12. <el-input v-model="form.aliPayConfig.appId" placeholder="请输入开放平台APPID" clearable :style="{width: '100%'}">
  13. </el-input>
  14. </el-form-item>
  15. <el-form-item label-width="180px" label="渠道状态" prop="status">
  16. <el-radio-group v-model="form.status" size="medium">
  17. <el-radio v-for="dict in statusDictDatas" :key="parseInt(dict.value)" :label="parseInt(dict.value)">
  18. {{ dict.label }}
  19. </el-radio>
  20. </el-radio-group>
  21. </el-form-item>
  22. <el-form-item label-width="180px" label="网关地址" prop="aliPayConfig.serverUrl">
  23. <el-radio-group v-model="form.aliPayConfig.serverUrl" size="medium">
  24. <el-radio v-for="dict in aliPayServerDatas" :key="dict.value" :label="dict.value">
  25. {{ dict.label }}
  26. </el-radio>
  27. </el-radio-group>
  28. </el-form-item>
  29. <el-form-item label-width="180px" label="算法类型" prop="aliPayConfig.signType">
  30. <el-radio-group v-model="form.aliPayConfig.signType" size="medium">
  31. <el-radio v-for="dict in aliPaySignTypeDatas" :key="dict.value" :label="dict.value">
  32. {{ dict.label }}
  33. </el-radio>
  34. </el-radio-group>
  35. </el-form-item>
  36. <el-form-item label-width="180px" label="公钥类型" prop="aliPayConfig.mode">
  37. <el-radio-group v-model="form.aliPayConfig.mode" size="medium">
  38. <el-radio v-for="dict in aliPayModeDatas" :key="parseInt(dict.value)" :label="parseInt(dict.value)">
  39. {{ dict.label }}
  40. </el-radio>
  41. </el-radio-group>
  42. </el-form-item>
  43. <div v-if="form.aliPayConfig.mode === 1">
  44. <el-form-item label-width="180px" label="商户私钥" prop="aliPayConfig.privateKey">
  45. <el-input type="textarea" :autosize="{minRows: 8, maxRows: 8}" v-model="form.aliPayConfig.privateKey"
  46. placeholder="请输入商户私钥" clearable :style="{width: '100%'}">
  47. </el-input>
  48. </el-form-item>
  49. <el-form-item label-width="180px" label="支付宝公钥字符串" prop="aliPayConfig.alipayPublicKey">
  50. <el-input
  51. type="textarea"
  52. :autosize="{minRows: 8, maxRows: 8}"
  53. v-model="form.aliPayConfig.alipayPublicKey"
  54. placeholder="请输入支付宝公钥字符串" clearable
  55. :style="{width: '100%'}">
  56. </el-input>
  57. </el-form-item>
  58. </div>
  59. <div v-if="form.aliPayConfig.mode === 2">
  60. <el-form-item label-width="180px" label="商户公钥应用证书" prop="aliPayConfig.appCertContent">
  61. <el-input v-model="form.aliPayConfig.appCertContent" type="textarea"
  62. placeholder="请上传商户公钥应用证书"
  63. readonly :autosize="{minRows: 8, maxRows: 8}" :style="{width: '100%'}"></el-input>
  64. </el-form-item>
  65. <el-form-item label-width="180px" label="">
  66. <el-upload
  67. action=""
  68. ref="privateKeyContentFile"
  69. :limit="1"
  70. :accept="fileAccept"
  71. :http-request="appCertUpload"
  72. :before-upload="fileBeforeUpload">
  73. <el-button size="small" type="primary" icon="el-icon-upload">点击上传</el-button>
  74. </el-upload>
  75. </el-form-item>
  76. <el-form-item label-width="180px" label="支付宝公钥证书" prop="aliPayConfig.alipayPublicCertContent">
  77. <el-input v-model="form.aliPayConfig.alipayPublicCertContent" type="textarea"
  78. placeholder="请上传支付宝公钥证书"
  79. readonly :autosize="{minRows: 8, maxRows: 8}" :style="{width: '100%'}"></el-input>
  80. </el-form-item>
  81. <el-form-item label-width="180px" label="">
  82. <el-upload
  83. ref="privateCertContentFile"
  84. action=""
  85. :limit="1"
  86. :accept="fileAccept"
  87. :before-upload="fileBeforeUpload"
  88. :http-request="alipayPublicCertUpload">
  89. <el-button size="small" type="primary" icon="el-icon-upload">点击上传</el-button>
  90. </el-upload>
  91. </el-form-item>
  92. <el-form-item label-width="180px" label="根证书" prop="aliPayConfig.rootCertContent">
  93. <el-input
  94. v-model="form.aliPayConfig.rootCertContent"
  95. type="textarea"
  96. placeholder="请上传根证书"
  97. readonly :autosize="{minRows: 8, maxRows: 8}"
  98. :style="{width: '100%'}">
  99. </el-input>
  100. </el-form-item>
  101. <el-form-item label-width="180px" label="">
  102. <el-upload
  103. ref="privateCertContentFile"
  104. :limit="1"
  105. :accept="fileAccept"
  106. action=""
  107. :before-upload="fileBeforeUpload"
  108. :http-request="rootCertUpload">
  109. <el-button size="small" type="primary" icon="el-icon-upload">点击上传</el-button>
  110. </el-upload>
  111. </el-form-item>
  112. </div>
  113. <el-form-item label-width="180px" label="备注" prop="remark">
  114. <el-input v-model="form.remark" :style="{width: '100%'}"></el-input>
  115. </el-form-item>
  116. </el-form>
  117. <div slot="footer" class="dialog-footer">
  118. <el-button @click="close">取消</el-button>
  119. <el-button type="primary" @click="handleConfirm">确定</el-button>
  120. </div>
  121. </el-dialog>
  122. </div>
  123. </template>
  124. <script>
  125. import {DICT_TYPE, getDictDatas} from "@/utils/dict";
  126. import {createChannel, getChannel, updateChannel} from "@/api/pay/channel";
  127. const defaultForm = {
  128. code: '',
  129. status: null,
  130. remark: '',
  131. feeRate: null,
  132. appId: '',
  133. aliPayConfig: {
  134. appId: '',
  135. serverUrl: null,
  136. signType: '',
  137. mode: null,
  138. privateKey: '',
  139. alipayPublicKey: '',
  140. appCertContent: '',
  141. alipayPublicCertContent: '',
  142. rootCertContent: ''
  143. }
  144. };
  145. export default {
  146. name: "aliPayChannelForm",
  147. components: {},
  148. props: {
  149. // 传输的参数
  150. transferParam: {
  151. // 加载动画
  152. "loading": false,
  153. // 是否修改
  154. "edit": false,
  155. // 是否显示
  156. "aliPayOpen": false,
  157. // 应用ID
  158. "appId": null,
  159. // 渠道编码
  160. "payCode": null,
  161. }
  162. },
  163. data() {
  164. return {
  165. title:'',
  166. form: JSON.parse(JSON.stringify(defaultForm)),
  167. rules: {
  168. feeRate: [{
  169. required: true,
  170. message: '请输入渠道费率',
  171. trigger: 'blur'
  172. }],
  173. 'aliPayConfig.appId': [{
  174. required: true,
  175. message: '请输入开放平台上创建的应用的 ID',
  176. trigger: 'blur'
  177. }],
  178. status: [{
  179. required: true,
  180. message: '渠道状态不能为空',
  181. trigger: 'blur'
  182. }],
  183. 'aliPayConfig.serverUrl': [{
  184. required: true,
  185. message: '请传入网关地址',
  186. trigger: 'blur'
  187. }],
  188. 'aliPayConfig.signType': [{
  189. required: true,
  190. message: '请传入签名算法类型',
  191. trigger: 'blur'
  192. }],
  193. 'aliPayConfig.mode': [{
  194. required: true,
  195. message: '公钥类型不能为空',
  196. trigger: 'blur'
  197. }],
  198. 'aliPayConfig.privateKey': [{
  199. required: true,
  200. message: '请输入商户私钥',
  201. trigger: 'blur'
  202. }],
  203. 'aliPayConfig.alipayPublicKey': [{
  204. required: true,
  205. message: '请输入支付宝公钥字符串',
  206. trigger: 'blur'
  207. }],
  208. 'aliPayConfig.appCertContent': [{
  209. required: true,
  210. message: '请上传商户公钥应用证书',
  211. trigger: 'blur'
  212. }],
  213. 'aliPayConfig.alipayPublicCertContent': [{
  214. required: true,
  215. message: '请上传支付宝公钥证书',
  216. trigger: 'blur'
  217. }],
  218. 'aliPayConfig.rootCertContent': [{
  219. required: true,
  220. message: '请上传指定根证书',
  221. trigger: 'blur'
  222. }],
  223. },
  224. fileAccept: ".crt",
  225. // 渠道状态 数据字典
  226. statusDictDatas: getDictDatas(DICT_TYPE.COMMON_STATUS),
  227. // 支付宝加密方式
  228. aliPaySignTypeDatas: getDictDatas(DICT_TYPE.PAY_CHANNEL_ALIPAY_SIGN_TYPE),
  229. // 版本状态 数据字典
  230. aliPayModeDatas: getDictDatas(DICT_TYPE.PAY_CHANNEL_ALIPAY_MODE),
  231. // 支付宝网关地址
  232. aliPayServerDatas: getDictDatas(DICT_TYPE.PAY_CHANNEL_ALIPAY_SERVER_TYPE),
  233. }
  234. },
  235. watch: {
  236. transferParam: {
  237. deep: true, // 深度监听
  238. handler(newVal) {
  239. if (newVal.aliPayOpen) {
  240. this.form.code = newVal.payCode;
  241. this.form.appId = newVal.appId;
  242. // 只有在初次进来为编辑 并且为加载中的时候才回去请求数据
  243. if (newVal.edit === true && newVal.loading) {
  244. this.title = "编辑支付渠道";
  245. this.init();
  246. } else {
  247. this.title = "创建支付渠道";
  248. }
  249. }
  250. }
  251. }
  252. },
  253. methods: {
  254. init() {
  255. getChannel(this.transferParam.appId, this.transferParam.payCode)
  256. .then(response => {
  257. this.form.id = response.data.id;
  258. this.form.feeRate = response.data.feeRate;
  259. this.form.status = response.data.status;
  260. this.form.remark = response.data.remark;
  261. let config = JSON.parse(response.data.config);
  262. this.form.aliPayConfig.appId = config.appId;
  263. this.form.aliPayConfig.serverUrl = config.serverUrl;
  264. this.form.aliPayConfig.signType = config.signType;
  265. this.form.aliPayConfig.mode = config.mode;
  266. this.form.aliPayConfig.privateKey = config.privateKey;
  267. this.form.aliPayConfig.alipayPublicKey = config.alipayPublicKey;
  268. this.form.aliPayConfig.appCertContent = config.appCertContent;
  269. this.form.aliPayConfig.alipayPublicCertContent = config.alipayPublicCertContent;
  270. this.form.aliPayConfig.rootCertContent = config.rootCertContent;
  271. this.transferParam.loading = false;
  272. })
  273. },
  274. close() {
  275. this.transferParam.aliPayOpen = false;
  276. this.form = JSON.parse(JSON.stringify(defaultForm));
  277. },
  278. handleConfirm() {
  279. this.$refs['aliPayForm'].validate(valid => {
  280. if (!valid) {
  281. return
  282. }
  283. let data = this.form;
  284. data.config = JSON.stringify(this.form.aliPayConfig);
  285. if (this.transferParam.edit) {
  286. updateChannel(data).then(response => {
  287. if (response.code === 0) {
  288. this.$modal.msgSuccess("修改成功");
  289. this.close();
  290. }
  291. })
  292. } else {
  293. createChannel(data).then(response => {
  294. if (response.code === 0) {
  295. this.$modal.msgSuccess("新增成功");
  296. this.$parent.refreshTable();
  297. this.close();
  298. }
  299. });
  300. }
  301. });
  302. },
  303. fileBeforeUpload(file) {
  304. let format = '.' + file.name.split(".")[1];
  305. if (format !== this.fileAccept) {
  306. this.$message.error('请上传指定格式"' + this.fileAccept + '"文件');
  307. return false;
  308. }
  309. let isRightSize = file.size / 1024 / 1024 < 2
  310. if (!isRightSize) {
  311. this.$message.error('文件大小超过 2MB')
  312. }
  313. return isRightSize
  314. },
  315. appCertUpload(event) {
  316. const readFile = new FileReader()
  317. readFile.onload = (e) => {
  318. this.form.aliPayConfig.appCertContent = e.target.result
  319. }
  320. readFile.readAsText(event.file);
  321. },
  322. alipayPublicCertUpload(event) {
  323. const readFile = new FileReader()
  324. readFile.onload = (e) => {
  325. this.form.aliPayConfig.alipayPublicCertContent = e.target.result
  326. }
  327. readFile.readAsText(event.file);
  328. },
  329. rootCertUpload(event) {
  330. const readFile = new FileReader()
  331. readFile.onload = (e) => {
  332. this.form.aliPayConfig.rootCertContent = e.target.result
  333. }
  334. readFile.readAsText(event.file);
  335. },
  336. }
  337. }
  338. </script>
  339. <style scoped>
  340. </style>