国内流行的内容管理系统(CMS)多端全媒体解决方案 https://www.dedebiz.com
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.

269 lines
9.1KB

  1. <?php
  2. /**
  3. * 支付接口
  4. *
  5. * @version $Id: sys_info_mark.php 1 22:28 2010年7月20日Z tianya $
  6. * @package DedeCMS.Administrator
  7. * @copyright Copyright (c) 2007 - 2020, DesDev, Inc.
  8. * @license http://help.dedecms.com/usersguide/license.html
  9. * @link http://www.dedecms.com
  10. */
  11. require_once(dirname(__FILE__)."/config.php");
  12. require_once(DEDEINC.'/datalistcp.class.php');
  13. CheckPurview('sys_Data');
  14. $dopost = (empty($dopost))? '' : $dopost;
  15. $pid = (empty($pid))? 0 : intval($pid);
  16. /*
  17. 下面数数组格式的例子:
  18. */
  19. //一个简单的[数组<->表单]解析类
  20. /*数组结构应该为:
  21. array(
  22. [name]=>array(
  23. [title]=>'当前表单项的名称',
  24. [type]=>'text|select',
  25. [description]=>'表单内容的介绍说明'
  26. [iterm]=>'1:使用标准双接口,使用担保交易接口', //如果含有":",则前面为value值,后面为显示内容
  27. [value]=>'使用担保交易接口',
  28. ),
  29. ...
  30. )
  31. 使用方法:
  32. 将上述的格式传入到数组中去,然后进行解析:
  33. 1.声明类,并创建数组
  34. $af = new Array2form($config);
  35. 2.设置一个表单模板(可选,如果不设置载入默认)
  36. $af->SetDefaultTpl($templets); $templets:为一个底册模板文件
  37. 表单模板格式为:
  38. <p>~title~:~form~<small>~description~</small></p>
  39. 3.获取特定项目表单
  40. $af->GetIterm('alipay', 1) //1.表示获取一个默认模板下的完整表单,2.仅获取一个表单项
  41. 4.获取所有表单内容
  42. $af->GetAll() //获取表单所有解析后的内容
  43. */
  44. class Array2form
  45. {
  46. var $FormArray = array();
  47. var $ArrFromTPL = '';
  48. function __construct($formarray = array())
  49. {
  50. if(count($formarray) > 1)
  51. {
  52. $this->FormArray = $formarray;
  53. //var_dump($this->FormArray);
  54. $this->SetDefaultTpl();
  55. }
  56. }
  57. //析构函数,兼容PHP4
  58. /*
  59. function Array2form($formarray = array())
  60. {
  61. $this->__construct($formarray);
  62. }
  63. */
  64. //获取一个特定项目的表单
  65. function GetIterm($itermid = '', $itermtype = 1)
  66. {
  67. $reval = $reval_form = $reval_title = $reval_des = $myformItem = '';
  68. if(is_array($this->FormArray))
  69. {
  70. foreach ($this->FormArray as $key => $val) {
  71. if($key == $itermid)
  72. {
  73. $reval_title = $val['title'];
  74. $reval_des = $val['description'];
  75. $reval_form = $this->GetForm($key,$val, $val['type']);
  76. //进行模板标签替换
  77. if($itermtype == 1)
  78. $reval = preg_replace(array("/~title~/","/~form~/","/~description~/"),
  79. array($reval_title, $reval_form, $reval_des), $this->ArrFromTPL);
  80. else return $reval_form;
  81. }
  82. }
  83. } else {
  84. return FALSE;
  85. }
  86. return empty($reval)? '' : $reval;
  87. }
  88. function GetForm($key, $formarry = array(), $formtype='text')
  89. {
  90. switch ($formtype)
  91. {
  92. case 'text':
  93. //生成文本编辑框
  94. $valstr=(empty($formarry['value']))? "value=''" : "value='{$formarry['value']}'";
  95. $reval_form = "<input type='text' name='{$key}' id='{$key}' style='width:300px' class='text'{$valstr}>";
  96. break;
  97. case 'select':
  98. //生成选择框
  99. $reval_title = $formarry['title'];
  100. $items = explode(',',$formarry['iterm']);
  101. $reval_form = "<select name='{$key}' class='text'>";
  102. if(is_array($items))
  103. {
  104. foreach($items as $v)
  105. {
  106. $v = trim($v);
  107. if($v=='') continue;
  108. //统一将中文冒号转为英文
  109. $v = str_replace(":", ":", $v);
  110. if( preg_match("/[\:]/",$v) )
  111. {
  112. list($value, $name) = preg_split('#:#', $v);
  113. $reval_form .= ($formarry['value'] == $value)? "<option value='$value' selected>$name</option>\r\n" : "<option value='$value'>$name</option>\r\n";
  114. } else {
  115. $reval_form .= ($formarry['value'] == $v)? "<option value='$v' selected>$v</option>\r\n" : "<option value='$v'>$v</option>\r\n";
  116. }
  117. }
  118. }
  119. $reval_form .= "</select>\r\n";
  120. break;
  121. }
  122. return $reval_form;
  123. }
  124. //获取所有的表单内容
  125. function GetAll()
  126. {
  127. $reval=empty($reval)? '' : $reval;
  128. if(is_array($this->FormArray))
  129. {
  130. foreach ($this->FormArray as $key => $val)
  131. {
  132. $reval .= $this->GetIterm($key);
  133. }
  134. return $reval;
  135. }else{
  136. return FALSE;
  137. }
  138. }
  139. //获取一个特定项目的表单
  140. function SetDefaultTpl($tplname = '')
  141. {
  142. if(empty($tplname))
  143. {
  144. $this->ArrFromTPL = '<p>~title~:~form~<small>~description~</small></p>';
  145. } else {
  146. if(file_exists($tplname)) $this->ArrFromTPL = file_get_contents($tplname);
  147. else $this->ArrFromTPL = $tplname;
  148. }
  149. }
  150. }
  151. $tplstring = "
  152. <tr>
  153. <td height='25' align='center'>~title~:</td>
  154. <td>~form~ <small>~description~</small></td>
  155. </tr>
  156. ";
  157. //安装支付接口
  158. if($dopost=='install')
  159. {
  160. $row = $dsql->GetOne("SELECT * FROM `#@__payment` WHERE id='$pid'");
  161. if(is_array($row))
  162. {
  163. if($cfg_soft_lang == 'utf-8')
  164. {
  165. $config_row = AutoCharset(unserialize(utf82gb($row['config'])));
  166. }else if($cfg_soft_lang == 'gb2312'){
  167. $config_row = unserialize($row['config']);
  168. }
  169. //print_r($config_row);exit;
  170. $af = new Array2form($config_row);
  171. $af->SetDefaultTpl($tplstring);
  172. $reval = $af->GetAll();
  173. }
  174. include DedeInclude('templets/sys_payment_install.htm');
  175. exit;
  176. }
  177. //配置支付接口
  178. else if($dopost=='config')
  179. {
  180. if($pay_name=="" || $pay_desc=="" || $pay_fee=="")
  181. {
  182. ShowMsg("您有未填写的项目!","-1");
  183. exit();
  184. }
  185. $row = $dsql->GetOne("SELECT * FROM `#@__payment` WHERE id='$pid'");
  186. if($cfg_soft_lang == 'utf-8')
  187. {
  188. $config = AutoCharset(unserialize(utf82gb($row['config'])));
  189. }else if($cfg_soft_lang == 'gb2312'){
  190. $config = unserialize($row['config']);
  191. }
  192. $payments = "'code' => '".$row['code']."',";
  193. foreach ($config as $key => $v)
  194. {
  195. $config[$key]['value'] = ${$key};
  196. $payments .= "'".$key."' => '".$config[$key]['value']."',";
  197. }
  198. $payments = substr($payments, 0, -1);
  199. $payment = "\$payment=array(".$payments.")";
  200. $configstr = "<"."?php\r\n".$payment."\r\n?".">\r\n";
  201. if(!empty($payment))
  202. {
  203. $m_file = DEDEDATA."/payment/".$row['code'].".php";
  204. $fp = fopen($m_file,"w") or die("写入文件 $safeconfigfile 失败,请检查权限!");
  205. fwrite($fp,$configstr);
  206. fclose($fp);
  207. }
  208. if($cfg_soft_lang == 'utf-8')
  209. {
  210. $config = AutoCharset($config,'utf-8','gb2312');
  211. $config = serialize($config);
  212. $config = gb2utf8($config);
  213. }else{
  214. $config = serialize($config);
  215. }
  216. $query = "UPDATE `#@__payment` SET name = '$pay_name',fee='$pay_fee',description='$pay_desc',config='$config',enabled='1' WHERE id='$pid'";
  217. $dsql->ExecuteNoneQuery($query);
  218. if($pm=='edit') $msg="保存修改成功";
  219. else $msg="安装成功!";
  220. ShowMsg($msg, "sys_payment.php");
  221. exit();
  222. }
  223. //删除支付接口
  224. else if($dopost=='uninstall')
  225. {
  226. $row = $dsql->GetOne("SELECT * FROM `#@__payment` WHERE id='$pid'");
  227. if($cfg_soft_lang == 'utf-8')
  228. {
  229. $config = AutoCharset(unserialize(utf82gb($row['config'])));
  230. }else if($cfg_soft_lang == 'gb2312'){
  231. $config = unserialize($row['config']);
  232. }
  233. foreach ($config as $key => $v) $config[$key]['value']="";
  234. if($cfg_soft_lang == 'utf-8')
  235. {
  236. $config = AutoCharset($config,'utf-8','gb2312');
  237. $config = serialize($config);
  238. $config = gb2utf8($config);
  239. }else{
  240. $config = serialize($config);
  241. }
  242. $query = "UPDATE `#@__payment` SET fee='',config='$config',enabled='0' WHERE id='$pid'";
  243. $dsql->ExecuteNoneQuery($query);
  244. //同时需要删除对应的缓存
  245. $m_file = DEDEDATA."/payment/".$row['code'].".php";
  246. @unlink($m_file);
  247. ShowMsg("删除成功!", "sys_payment.php");
  248. exit();
  249. }
  250. $sql = "SELECT * FROM `#@__payment` ORDER BY rank ASC";
  251. $dlist = new DataListCP();
  252. $dlist->SetTemplet(DEDEADMIN."/templets/sys_payment.htm");
  253. $dlist->SetSource($sql);
  254. $dlist->display();