index.php 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. <?php
  2. defined('IN_PHPCMS') or exit('No permission resources.');
  3. define('CACHE_MODEL_PATH',PHPCMS_PATH.'caches'.DIRECTORY_SEPARATOR.'caches_model'.DIRECTORY_SEPARATOR.'caches_data'.DIRECTORY_SEPARATOR);
  4. class index {
  5. private $db, $m_db, $M;
  6. function __construct() {
  7. $this->db = pc_base::load_model('sitemodel_model');
  8. $this->m_db = pc_base::load_model('sitemodel_field_model');
  9. $this->M = new_html_special_chars(getcache('formguide', 'commons'));
  10. $this->siteid = intval($_GET[siteid]) ? intval($_GET[siteid]) : get_siteid();
  11. $this->M = $this->M[$this->siteid];
  12. }
  13. /**
  14. * 表单向导首页
  15. */
  16. public function index() {
  17. $siteid = $this->siteid;
  18. $SEO = seo($this->siteid, '', L('formguide_list'));
  19. $page = max(intval($_GET['page']), 1);
  20. $r = $this->db->get_one(array('siteid'=>$this->siteid, 'type'=>3, 'disabled'=>0), 'COUNT(`modelid`) AS sum');
  21. $total = $r['sum'];
  22. $pages = pages($total, $page, 20);
  23. $offset = ($page-1)*20;
  24. $datas = $this->db->select(array('siteid'=>$this->siteid, 'type'=>3, 'disabled'=>0), 'modelid, name, addtime', $offset.',20', '`modelid` DESC');
  25. include template('formguide', 'index');
  26. }
  27. private function _session_start() {
  28. $session_storage = 'session_'.pc_base::load_config('system','session_storage');
  29. pc_base::load_sys_class($session_storage);
  30. }
  31. /**
  32. * 表单展示
  33. */
  34. public function show() {
  35. $this->_session_start();
  36. if (!isset($_GET['formid']) || empty($_GET['formid'])) {
  37. $_GET['action'] ? exit : showmessage(L('form_no_exist'), HTTP_REFERER);
  38. }
  39. $siteid = $_GET['siteid'] ? intval($_GET['siteid']) : 1;
  40. $formid = intval($_GET['formid']);
  41. $r = $this->db->get_one(array('modelid'=>$formid, 'siteid'=>$siteid, 'disabled'=>0), 'tablename, setting');
  42. if (!$r) {
  43. $_GET['action'] ? exit : showmessage(L('form_no_exist'), HTTP_REFERER);
  44. }
  45. $setting = string2array($r['setting']);
  46. if ($setting['enabletime']) {
  47. if ($setting['starttime']>SYS_TIME || ($setting['endtime']+3600*24)<SYS_TIME) {
  48. $_GET['action'] ? exit : showmessage(L('form_expired'), APP_PATH.'index.php?m=formguide&c=index&a=index');
  49. }
  50. }
  51. $userid = param::get_cookie('_userid');
  52. if ($setting['allowunreg']==0 && !$userid && $_GET['action']!='js') showmessage(L('please_login_in'), APP_PATH.'index.php?m=member&c=index&a=login&forward='.urlencode(HTTP_REFERER));
  53. if (isset($_POST['dosubmit'])) {
  54. // if (empty($_SESSION['connectid']) && $_SESSION['code'] != strtolower($_POST['code'])) {
  55. // showmessage(L('code_error')); exit;
  56. // }
  57. $tablename = 'form_'.$r['tablename'];
  58. $this->m_db->change_table($tablename);
  59. $data = array();
  60. require CACHE_MODEL_PATH.'formguide_input.class.php';
  61. $formguide_input = new formguide_input($formid);
  62. $data = $formguide_input->get($_POST['info']);
  63. $data['userid'] = $userid;
  64. $data['username'] = param::get_cookie('_username');
  65. $data['datetime'] = SYS_TIME;
  66. $data['ip'] = ip();
  67. $dataid = $this->m_db->insert($data, true);
  68. if ($dataid) {
  69. if ($setting['sendmail']) {
  70. pc_base::load_sys_func('mail');
  71. $mails = explode(',', $setting['mails']);
  72. if (is_array($mails)) {
  73. foreach ($mails as $m) {
  74. sendmail($m, L('tips'), $this->M['mailmessage']);
  75. }
  76. }
  77. }
  78. $this->db->update(array('items'=>'+=1'), array('modelid'=>$formid, 'siteid'=>$this->siteid));
  79. }
  80. if( $tablename=='form_xxcj'){
  81. // session_start();
  82. // // // 存储session数据
  83. // $_SESSION['x'] = 'xz';
  84. setcookie("xz", 'xz', time()+120, "/");
  85. showmessage(L('thanks'), HTTP_REFERER);
  86. // $referer = $_SERVER['HTTP_REFERER'];
  87. // $urlParts = parse_url($referer);
  88. // parse_str($urlParts['query'], $params);
  89. // $catid = $params['catid'];
  90. // header("Location:".APP_PATH."index.php?m=content&c=index&a=lists&catid=$catid&v=1");//多了下载字段
  91. }else{
  92. showmessage(L('thanks'), HTTP_REFERER);
  93. }
  94. } else {
  95. if ($setting['allowunreg']==0 && !$userid && $_GET['action']=='js') {
  96. $no_allowed = 1;
  97. }
  98. pc_base::load_sys_class('form', '', '');
  99. $f_info = $this->db->get_one(array('modelid'=>$formid, 'siteid'=>$this->siteid));
  100. extract($f_info);
  101. $tablename = 'form_'.$r['tablename'];
  102. $this->m_db->change_table($tablename);
  103. $ip = ip();
  104. $where = array();
  105. if ($userid) $where = array('userid'=>$userid);
  106. else $where = array('ip'=>$ip);
  107. $re = $this->m_db->get_one($where, 'datetime');
  108. $setting = string2array($setting);
  109. if (($setting['allowmultisubmit']==0 && $re['datetime']) || ((SYS_TIME-$re['datetime'])<$this->M['interval']*60)) {
  110. $_GET['action'] ? exit : showmessage(L('had_participate'), APP_PATH.'index.php?m=formguide&c=index&a=index');
  111. }
  112. require CACHE_MODEL_PATH.'formguide_form.class.php';
  113. $formguide_form = new formguide_form($formid, $no_allowed);
  114. $forminfos_data = $formguide_form->get();
  115. $SEO = seo($this->siteid, L('formguide'), $name);
  116. if (isset($_GET['action']) && $_GET['action']=='js') {
  117. if(!function_exists('ob_gzhandler')) ob_clean();
  118. ob_start();
  119. }
  120. $template = ($_GET['action']=='js') ? $js_template : $show_template;
  121. include template('formguide', $template, $default_style);
  122. if (isset($_GET['action']) && $_GET['action']=='js') {
  123. $data=ob_get_contents();
  124. ob_clean();
  125. exit(format_js($data));
  126. }
  127. }
  128. }
  129. }
  130. ?>