No Description
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.

alipay_template.htm 17KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310
  1. {include file="public/layout" /}
  2. <style type="text/css">
  3. .ncap-form-default dt.tit em.none{
  4. display: none;
  5. }
  6. </style>
  7. <body class="bodystyle" style="cursor: default; -moz-user-select: inherit; min-width:400px;">
  8. <div id="append_parent"></div>
  9. <div id="ajaxwaitid"></div>
  10. <div class="page min-hg-c-10" style="min-width: 400px;">
  11. <div class="flexigrid">
  12. <form class="form-horizontal" id="postAlipayForm" onselectstart="return false;">
  13. <input type="hidden" name="pay_id" value="{$Config.pay_id}">
  14. <div class="ncap-form-default"/>
  15. <dl class="row">
  16. <dt class="tit">
  17. <label>支付功能</label>
  18. </dt>
  19. <dd class="opt">
  20. <label class="curpoin"><input id="is_open_alipay0" name="pay_info[is_open_alipay]" value="0" type="radio" {if condition="!isset($pay_info.is_open_alipay) || empty($pay_info.is_open_alipay)"} checked="checked"{/if}>开启</label>
  21. &nbsp;
  22. <label class="curpoin"><input id="is_open_alipay1" name="pay_info[is_open_alipay]" value="1" type="radio" {if condition="isset($pay_info.is_open_alipay) && $pay_info.is_open_alipay == 1"} checked="checked"{/if}>关闭</label>
  23. </dd>
  24. </dl>
  25. <dl class="row">
  26. <dt class="tit">
  27. <label for="uname"><em></em>使用支付宝版本</label>
  28. </dt>
  29. <dd class="opt">
  30. <label>
  31. <input type="radio" name="pay_info[version]" onclick="switch_set(this);" value="0" {if condition="empty($php_version) && empty($pay_info.version)"}checked="checked"{/if} />新版接口
  32. <span style="padding-left: 10px; color: #C0C0C0;">支持<font color="red">php5.5.0</font>或更高版本!(阿里云空间必须php7.0或以上)</span>
  33. </label>
  34. <br/>
  35. <label>
  36. <input type="radio" name="pay_info[version]" onclick="switch_set(this);" value="1" {if condition="$pay_info.version == 1 || $php_version == 1"}checked="checked"{/if} />旧版接口
  37. <span style="padding-left: 10px; color: #C0C0C0;">可支持<font color="red">php5.4</font>或更高版本!</span>
  38. </label>
  39. </dd>
  40. </dl>
  41. <div id="new_version" {if condition="$pay_info.version == 1 || $php_version == 1"}class="none"{/if}>
  42. <dl class="row">
  43. <dt class="tit">
  44. <label><em class="em_empty {notempty name='$pay_info.is_open_alipay'} none {/notempty}">*</em>支付终端</label>
  45. </dt>
  46. <dd class="opt">
  47. <ul class="nc-row ncap-waybill-list">
  48. <li style="width: 100%;">
  49. <label class="label">
  50. <input class="check" type="checkbox" name="pay_terminal[computer]" value="1" {if condition="!empty($Config.pay_terminal.computer)"} checked="checked" {/if} onclick="ConfigDetect(this);">电脑端
  51. <input type="hidden" name="pay_terminal[c_mark]" id="computer_mark" value="{$Config.pay_terminal.c_mark}">
  52. </label>
  53. &nbsp; &nbsp;
  54. <label class="label">
  55. <input class="check" type="checkbox" name="pay_terminal[mobile]" value="2" {if condition="!empty($Config.pay_terminal.mobile)"} checked="checked" {/if} onclick="ConfigDetect(this);">移动端
  56. <input type="hidden" name="pay_terminal[m_mark]" id="mobile_mark" value="{$Config.pay_terminal.m_mark}">
  57. </label>
  58. <a href="JavaScript:void(0);" onclick="click_to_eyou_1575506523('https://www.eyoucms.com/plus/view.php?aid=11848&origin_eycms=1', '终端签约教程');" style="font-size: 12px; padding-left: 10px; position: absolute;">[终端签约教程]</a>
  59. <!-- <a href="JavaScript:void(0);" onclick="click_to_eyou_1575506523('https://www.eyoucms.com/plus/view.php?aid=11848&origin_eycms=1', '终端签约教程');" id="UseTutorial" {if condition="in_array(2, $Config.pay_terminal)"} style="font-size: 12px; padding-left: 10px; position: absolute;" {else/} style="font-size: 12px; padding-left: 10px; position: absolute; display: none;" {/if}>[使用教程]</a> -->
  60. </li>
  61. </ul>
  62. </dd>
  63. </dl>
  64. <dl class="row">
  65. <dt class="tit">
  66. <label for="username"><em class="em_empty {notempty name='$pay_info.is_open_alipay'} none {/notempty}">*</em>支付宝APPID</label>
  67. </dt>
  68. <dd class="opt">
  69. <input type="text" name="pay_info[app_id]" id="app_id" value="{$pay_info.app_id|default=''}" class="input-txt" autocomplete="off">
  70. <p class="notic">请输入您的支付宝APPID,用于支付宝支付。</p>
  71. </dd>
  72. </dl>
  73. <dl class="row">
  74. <dt class="tit">
  75. <label for="username"><em class="em_empty {notempty name='$pay_info.is_open_alipay'} none {/notempty}">*</em>商户私钥</label>
  76. </dt>
  77. <dd class="opt">
  78. <textarea rows="5" cols="80" id="merchant_private_key" name="pay_info[merchant_private_key]" style="height:120px;" autocomplete="off">{$pay_info.merchant_private_key|default=''}</textarea>
  79. <p class="notic">请输入您的商户私钥,用于支付宝支付。</p>
  80. </dd>
  81. </dl>
  82. <dl class="row">
  83. <dt class="tit">
  84. <label for="username"><em class="em_empty {notempty name='$pay_info.is_open_alipay'} none {/notempty}">*</em>支付宝公钥</label>
  85. </dt>
  86. <dd class="opt">
  87. <textarea rows="5" cols="80" id="alipay_public_key" name="pay_info[alipay_public_key]" style="height:106px;" autocomplete="off">{$pay_info.alipay_public_key|default=''}</textarea>
  88. <p class="notic">请输入您的支付宝公钥,用于支付宝支付。</p>
  89. </dd>
  90. </dl>
  91. </div>
  92. <div id="old_version" {if condition="empty($php_version) && empty($pay_info.version)"}class="none"{/if}>
  93. <dl class="row">
  94. <dt class="tit">
  95. <label for="username"><em class="em_empty {notempty name='$pay_info.is_open_alipay'} none {/notempty}">*</em>支付宝账号</label>
  96. </dt>
  97. <dd class="opt">
  98. <input type="text" name="pay_info[account]" id="account" value="{$pay_info.account|default=''}" class="input-txt" autocomplete="off">
  99. <p class="notic">请输入您的支付宝账号,用于支付宝支付。</p>
  100. </dd>
  101. </dl>
  102. <dl class="row">
  103. <dt class="tit">
  104. <label for="username"><em class="em_empty {notempty name='$pay_info.is_open_alipay'} none {/notempty}">*</em>交易安全校验码</label>
  105. </dt>
  106. <dd class="opt">
  107. <input type="text" name="pay_info[code]" id="code" value="{$pay_info.code|default=''}" class="input-txt" autocomplete="off">
  108. <p class="notic">请输入您的交易安全校验码,用于支付宝支付。</p>
  109. </dd>
  110. </dl>
  111. <dl class="row">
  112. <dt class="tit">
  113. <label for="username"><em class="em_empty {notempty name='$pay_info.is_open_alipay'} none {/notempty}">*</em>合作者身份ID</label>
  114. </dt>
  115. <dd class="opt">
  116. <input type="text" name="pay_info[id]" id="id" value="{$pay_info.id|default=''}" class="input-txt" autocomplete="off">
  117. <p class="notic">请输入您的合作者身份ID,用于支付宝支付。</p>
  118. </dd>
  119. </dl>
  120. </div>
  121. <dl class="row">
  122. <div class="bot" style="padding-bottom: 0px;">
  123. <a href="JavaScript:void(0);" onclick="alipayset();" class="ncap-btn-big ncap-btn-green" id="submitAlipayBtn">确认提交</a>
  124. &nbsp;<a href="JavaScript:void(0);" onclick="click_to_eyou_1575506523('https://www.eyoucms.com/plus/view.php?aid=11284&origin_eycms=1','支付宝支付配置教程')" style="font-size: 12px;padding-left: 10px;position:absolute;top: 30px">不会配置?</a>
  125. </div>
  126. </dl>
  127. </div>
  128. </form>
  129. </div>
  130. </div>
  131. <script type="text/javascript">
  132. var parentObj = parent.layer.getFrameIndex(window.name); //先得到当前iframe层的索引
  133. $(function(){
  134. $("input[name='pay_info[is_open_alipay]']").click(function(){
  135. if(1 == $(this).val()){
  136. $('.em_empty').hide();
  137. } else {
  138. $('.em_empty').show();
  139. }
  140. });
  141. });
  142. function php_version(is){
  143. var php_version = {$php_version};
  144. // php_version=1,表示php本版低于5.5.0,不可用新版支付方式
  145. if (php_version == 1) {
  146. if (is == true) {
  147. layer.alert('PHP版本低于5.5.0,不可用新版支付方式,请使用旧版!', {icon: 2, title:false});
  148. }
  149. $("#postAlipayForm input[name='pay_info[version]'][value=1]").attr("checked","checked");
  150. return false;
  151. }
  152. return true;
  153. }
  154. function switch_set(obj){
  155. var switch_set = $(obj).val();
  156. if (switch_set == 0) {
  157. if (php_version(true)) {
  158. $("#postAlipayForm #new_version").show();
  159. $("#postAlipayForm #old_version").hide();
  160. }
  161. }else if (switch_set == 1) {
  162. $("#postAlipayForm #new_version").hide();
  163. $("#postAlipayForm #old_version").show();
  164. }
  165. }
  166. function alipayset(){
  167. var is_open_alipay = $("#postAlipayForm input[name='pay_info[is_open_alipay]']:checked").val();
  168. if (is_open_alipay == 0){
  169. var switch_set = $("#postAlipayForm input[name='pay_info[version]']:checked").val();
  170. if (switch_set == 0) {
  171. // 新版判断
  172. if($('#postAlipayForm input[name="pay_terminal[computer]"]:checked').val() != 1 && $('#postAlipayForm input[name="pay_terminal[mobile]"]:checked').val() != 1){
  173. layer.alert('至少勾选一个支付终端!', {icon: 2, title:false});
  174. return false;
  175. }
  176. if($('#postAlipayForm #app_id').val() == ''){
  177. layer.alert('支付APPID不能为空!', {icon: 2, title:false});
  178. return false;
  179. }
  180. if($('#postAlipayForm #merchant_private_key').val() == ''){
  181. layer.alert('商户私钥不能为空!', {icon: 2, title:false});
  182. return false;
  183. }
  184. if($('#postAlipayForm #alipay_public_key').val() == ''){
  185. layer.alert('支付宝公钥不能为空!', {icon: 2, title:false});
  186. return false;
  187. }
  188. }else if (switch_set == 1) {
  189. // 旧版判断
  190. if($('#postAlipayForm #account').val() == ''){
  191. layer.alert('支付宝账号不能为空!', {icon: 2, title:false});
  192. return false;
  193. }
  194. if($('#postAlipayForm #code').val() == ''){
  195. layer.alert('交易安全校验码不能为空!', {icon: 2, title:false});
  196. return false;
  197. }
  198. if($('#postAlipayForm #id').val() == ''){
  199. layer.alert('合作者身份ID不能为空!', {icon: 2, title:false});
  200. return false;
  201. }
  202. }
  203. }
  204. layer_loading('正在处理');
  205. $.ajax({
  206. url: "{:url('PayApi/save_pay_api_config', ['_ajax'=>1])}",
  207. type: 'POST',
  208. dataType: 'JSON',
  209. data: $('#postAlipayForm').serialize(),
  210. success: function(res){
  211. layer.closeAll();
  212. if (1 == res.code) {
  213. var _parent = parent;
  214. _parent.layer.close(parentObj);
  215. _parent.layer.msg(res.msg, {shade: layer_shade, time: 1000});
  216. } else {
  217. showErrorAlert(res.msg);
  218. }
  219. },
  220. error: function(e){
  221. layer.closeAll();
  222. showErrorAlert(e.responseText);
  223. return false;
  224. }
  225. });
  226. }
  227. // 记录支付宝支付配置支付终端是否已签约
  228. function ConfigDetect(obj) {
  229. if ($(obj).prop('checked')) {
  230. // 检测是否完善支付宝配置
  231. var AppID = $('#app_id').val();
  232. var MerchantPrivateKey = $('#merchant_private_key').val();
  233. var AlipayPublicKey = $('#alipay_public_key').val();
  234. if (!AppID || !MerchantPrivateKey || !AlipayPublicKey) {
  235. $(obj).attr('checked', false);
  236. layer.alert('请先完善支付宝配置再选择', {icon: 2, title: false});
  237. return false;
  238. }
  239. // 是否签约
  240. if (1 == $(obj).val()) {
  241. var computerMark = $('#computer_mark').val();
  242. if (1 != computerMark) {
  243. var msg = '<span style="color: red;">【电脑网站支付】</span>';
  244. layer.confirm('是否已在支付宝应用能力列表中签约'+msg+'能力?', {
  245. shade: layer_shade,
  246. area: ['480px', '190px'],
  247. move: false,
  248. title: '提示',
  249. btnAlign:'r',
  250. closeBtn: 3,
  251. btn: ['已签约,不再提醒', '未签约'],
  252. success: function () {
  253. $(".layui-layer-content").css('text-align', 'left');
  254. }
  255. }, function() {
  256. $('#computer_mark').val(1);
  257. layer.closeAll();
  258. }, function(index) {
  259. $(obj).attr('checked', false);
  260. layer.closeAll(index);
  261. });
  262. }
  263. } else {
  264. var mobileMark = $('#mobile_mark').val();
  265. if (2 != mobileMark) {
  266. var msg = '<span style="color: red;">【手机网站支付】</span>';
  267. layer.confirm('是否已在支付宝应用能力列表中签约'+msg+'能力?', {
  268. shade: layer_shade,
  269. area: ['480px', '190px'],
  270. move: false,
  271. title: '提示',
  272. btnAlign:'r',
  273. closeBtn: 3,
  274. btn: ['已签约,不再提醒', '未签约'],
  275. success: function () {
  276. $(".layui-layer-content").css('text-align', 'left');
  277. }
  278. }, function() {
  279. $('#mobile_mark').val(2);
  280. layer.closeAll();
  281. }, function(index) {
  282. $(obj).attr('checked', false);
  283. layer.closeAll(index);
  284. });
  285. }
  286. }
  287. // 勾选移动端则执行
  288. // if (2 == $(obj).val()) $('#UseTutorial').show();
  289. } else {
  290. // 取消勾选移动端则执行
  291. // if (2 == $(obj).val()) $('#UseTutorial').hide();
  292. }
  293. }
  294. </script>
  295. {include file="public/footer" /}