花魁直播高品质美女在线视频互动社区 - 花魁直播官方版

 歡迎來(lái)到素材無(wú)憂網(wǎng),按 + 收藏我們
登錄 注冊(cè) 退出 找回密碼

織夢(mèng)自定義表單中添加驗(yàn)證碼的方法和織夢(mèng)自定義表單提交后增加提

時(shí)間: 2019-05-13 10:30 閱讀: 作者:素材無(wú)憂網(wǎng)

織夢(mèng)dedecms網(wǎng)站給自定義表單加dede模板自帶驗(yàn)證碼的方法。

有時(shí)候,我們因?yàn)樾枰odede網(wǎng)站的自定義表單添加驗(yàn)證碼,防止惡意填寫(xiě)表單提交。

我們可以用以下的方法來(lái)實(shí)現(xiàn):

首先,我們要找到 /plus/diy.php 這個(gè)文件

在頭部引入文件:

require_once(DEDEINC.'/membermodel.cls.php');

然后找到

elseif($do == 2)

    {  在這個(gè)地方加入代碼塊  

       //驗(yàn)證碼驗(yàn)證

        $svali = GetCkVdValue();

         if(preg_match("/1/",$safe_gdopen)){

             if(strtolower($vdcode)!=$svali || $svali=='')

             {

                 ResetVdValue();

                 ShowMsg('驗(yàn)證碼錯(cuò)誤!', '-1');

                 exit();

             }  

         }

修改好后保存一下文件。

第二步:在使用驗(yàn)證碼的自定義表單靜態(tài)頁(yè)面中插入代碼塊

 

<input type="text" class="intxt w200" style="width: 50px; text-transform: uppercase;" id="vdcode" name="vdcode" class="code"/>

<img id="vdimgck" align="absmiddle" onclick="this.src=this.src+'?'" style="cursor: pointer;" alt="看不清?點(diǎn)擊更換" src="/include/vdimgck.php"/> 看不清? <a href="javascript:void(0)" onclick="changeAuthCode();">點(diǎn)擊更換</a>

在這個(gè)靜態(tài)頁(yè)面里還得引用JQuery

再加入 JS代碼塊

<script type="text/javascript"> 
 $ = jQuery;  
 function changeAuthCode() {  
 var num = new Date().getTime();  
 var rand = Math.round(Math.random() * 10000);  
 num = num + rand;  
 $('#ver_code').css('visibility','visible');  
 if ($("#vdimgck")[0]) {  
 $("#vdimgck")[0].src = "../include/vdimgck.php?tag=" + num;  
 }  
 return false;  
 }  
 </script>

好了,現(xiàn)在試一試,是不是可以實(shí)現(xiàn)驗(yàn)證碼的提交了?一個(gè)簡(jiǎn)單的dedecms自定義表單dede模板自帶驗(yàn)證碼的功能就實(shí)現(xiàn)了。

織夢(mèng)自定義表單的應(yīng)用非常方便,不管用在什么地方,收集信息特別方便制作和管理。

有如下幾個(gè)建議,把下拉框和單選按扭在后臺(tái)做成單行文本,這樣的話不管你提交的是下拉框或是單選,都可以有效的接收它的值。如果后臺(tái)就做成單選或下拉,如果改了默認(rèn)值,提交的表單值跟后臺(tái)默認(rèn)值對(duì)不上的話就會(huì)出現(xiàn)提交不成功的情況,就是前臺(tái)提交的時(shí)候選擇了,但后臺(tái)看不到數(shù)據(jù)。若是做成單行文本,提交的值就會(huì)以文本的形式寫(xiě)入到后臺(tái),表單修改值也更加顯得方便了。

提交之后會(huì)顯示織夢(mèng)的默認(rèn)提示信息“友情提示”幾秒過(guò)后就自動(dòng)轉(zhuǎn)到首頁(yè)。如何才能讓提交的信息停留,并讓用戶確認(rèn)所提交的信息。

我想了如下方式。給diy.php里提交成功后輸入固定值而不是自帶的跳轉(zhuǎn)方法。如下:

if($action == 'post')
{
 if(empty($do))
 {
  $postform = $diy->getForm(true);
  include DEDEROOT."/templets/plus/{$diy->postTemplate}";
  exit();
 }
 elseif($do == 2)
 {
  $dede_fields = empty($dede_fields) ? '' : trim($dede_fields);
  $dede_fieldshash = empty($dede_fieldshash) ? '' : trim($dede_fieldshash);
  if(!empty($dede_fields))
  {
   if($dede_fieldshash != md5($dede_fields.$cfg_cookie_encode))
   {
    showMsg('數(shù)據(jù)校驗(yàn)不對(duì),程序返回', '-1');
    exit();
   }
  }
  $diyform = $dsql->getOne("select * from where diyid='$diyid' ");
  if(!is_array($diyform))
  {
   showmsg('自定義表單不存在', '-1');
   exit();
  }

  $addvar = $addvalue = '';

  if(!empty($dede_fields))
  {

   $fieldarr = explode(';', $dede_fields);
   if(is_array($fieldarr))
   {
    foreach($fieldarr as $field)
    {
     if($field == '') continue;
     $fieldinfo = explode(',', $field);
     if($fieldinfo[1] == 'textdata')
     {
      ${$fieldinfo[0]} = FilterSearch(stripslashes(${$fieldinfo[0]}));
      ${$fieldinfo[0]} = addslashes(${$fieldinfo[0]});
     }
     else
     {
      ${$fieldinfo[0]} = GetFieldValue(${$fieldinfo[0]}, $fieldinfo[1],0,'add','','diy', $fieldinfo[0]);
     }
     $addvar .= ', `'.$fieldinfo[0].'`';
     $addvalue .= ", '".${$fieldinfo[0]}."'";
    }
   }

  }

  $query = "insert into `{$diy->table}` (`id`, `ifcheck` $addvar)  values (NULL, 0 $addvalue); ";

  if($dsql->executenonequery($query))
  {
   $id = $dsql->GetLastID();
   if($diy->public == 2)
   {
    //diy.php?action=view&diyid={$diy->diyid}&id=$id
    $goto = "diy.php?action=list&diyid={$diy->diyid}";
    $bkmsg = '發(fā)布成功,現(xiàn)在轉(zhuǎn)向表單列表頁(yè)...';
   }
   else
   {
    $goto = !empty($cfg_cmspath) ? $cfg_cmspath : '/';
    $bkmsg = '發(fā)布成功,請(qǐng)等待管理員處理...';
   }
   echo '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "">
<html xmlns="">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>訂單核對(duì) </title>
<link href="/img_cnosn/css_end.css" rel="stylesheet" type="text/css" />
</head>

<body>
<p id="ctent">
<h1>您已成功提交訂單,請(qǐng)仔細(xì)核對(duì)你的信息!</h1>
<ul>
<script language="javascript">
 function ReplaceAll(str,sptr,sptr1)
 {
  while (str.indexOf(sptr) >= 0)
  {
     str = str.replace(sptr, sptr1);
  }
  return str;
 }
 
 descria=",您的姓名:,聯(lián)系電話:,送貨地址:,購(gòu)買(mǎi)產(chǎn)品:,支付方式:,訂貨留言:,b";
 var descri=new Array();
 descri=descria.split(",");
 str= "'.$addvalue.'" ;
 str=ReplaceAll(str,"\'","");
 var strarray=new   Array();
 strarray=str.split(",") ;
 for(i=0;i<7;i++){
 document.write("<li>"+descri[i]+strarray[i]+"</li>");
 }
</script>
</ul>
<p class="info">友情提示:您的訂單已提交成功,我們的客服會(huì)盡快與你取得聯(lián)系 <a href="#" onclick="window.operner = null;window.open(\'\',\'_self\');window.close();">確認(rèn)并關(guān)閉</a> 或 <a href="#" onclick="window.operner = null;window.open(\'\',\'_self\');window.close();">返回修改</a></p>
</p>
</body>
</html>
';
  }
 }
}
 上是代碼。這樣就是固定提取前幾個(gè)表單信息給用戶確認(rèn),不過(guò)在后臺(tái)增加表單的時(shí)候一定要統(tǒng)一按以上數(shù)組的順序進(jìn)行添加字段。這樣才能對(duì)應(yīng)。

有一個(gè)不好的地方是,這個(gè)文件只要一改就是針對(duì)所有的表單提交,不過(guò)這只是一個(gè)方法,供參考,最終還得靈活應(yīng)用。

版權(quán)聲明: 本站資源均來(lái)自互聯(lián)網(wǎng)或會(huì)員發(fā)布,如果侵犯了您的權(quán)益請(qǐng)與我們聯(lián)系,我們將在24小時(shí)內(nèi)刪除!謝謝!

轉(zhuǎn)載請(qǐng)注明: 織夢(mèng)自定義表單中添加驗(yàn)證碼的方法和織夢(mèng)自定義表單提交后增加提

相關(guān)文章
模板推薦