index.php 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  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. setcookie("xz", 'xz', time()+300, "/");
  82. }
  83. showmessage(L('thanks'), HTTP_REFERER);
  84. } else {
  85. if ($setting['allowunreg']==0 && !$userid && $_GET['action']=='js') {
  86. $no_allowed = 1;
  87. }
  88. pc_base::load_sys_class('form', '', '');
  89. $f_info = $this->db->get_one(array('modelid'=>$formid, 'siteid'=>$this->siteid));
  90. extract($f_info);
  91. $tablename = 'form_'.$r['tablename'];
  92. $this->m_db->change_table($tablename);
  93. $ip = ip();
  94. $where = array();
  95. if ($userid) $where = array('userid'=>$userid);
  96. else $where = array('ip'=>$ip);
  97. $re = $this->m_db->get_one($where, 'datetime');
  98. $setting = string2array($setting);
  99. if (($setting['allowmultisubmit']==0 && $re['datetime']) || ((SYS_TIME-$re['datetime'])<$this->M['interval']*60)) {
  100. $_GET['action'] ? exit : showmessage(L('had_participate'), APP_PATH.'index.php?m=formguide&c=index&a=index');
  101. }
  102. require CACHE_MODEL_PATH.'formguide_form.class.php';
  103. $formguide_form = new formguide_form($formid, $no_allowed);
  104. $forminfos_data = $formguide_form->get();
  105. $SEO = seo($this->siteid, L('formguide'), $name);
  106. if (isset($_GET['action']) && $_GET['action']=='js') {
  107. if(!function_exists('ob_gzhandler')) ob_clean();
  108. ob_start();
  109. }
  110. $template = ($_GET['action']=='js') ? $js_template : $show_template;
  111. include template('formguide', $template, $default_style);
  112. if (isset($_GET['action']) && $_GET['action']=='js') {
  113. $data=ob_get_contents();
  114. ob_clean();
  115. exit(format_js($data));
  116. }
  117. }
  118. }
  119. }
  120. ?>