PHP+jQuery注册模块改进教程(三):更新到Smarty3.1
沉沙 2018-06-14 来源 : 阅读 1050 评论 0

摘要:Smarty3.1X( 最新版本 3.1.19) 比起Smarty2.x修改了不少特性。本文由职坐标整理发布,更多相关内容,请关注职坐标WEB前端jQuery频道!

Smarty3.1X( 最新版本 3.1.19) 比起Smarty2.x修改了不少特性。把这个模块使用Smarty3.1.18 ( 下载地址//www.smarty.net/files/Smarty-3.1.18.zip )重新修改了一遍,是项目文件和目录看起来更干净更有调理。

把Smarty压缩包中的libs文件夹拷贝至模块根目录下,然后根目录创建init.inc.php:

代码如下:

<?php/**    file:init.inc.php Smarty对象的实例化及初始化文件*/
/* *********************Smarty设置*********************** *///根目录路径方式,用于Smarty设置define("ROOT",str_replace("\\","/",dirname(__FILE__))."/");
require ROOT.'libs/Smarty.class.php';$smarty = new Smarty();
//Smarty3设置默认路径$smarty ->setTemplateDir(ROOT.'templates/')        ->setCompileDir(ROOT.'templates_c/')        ->setPluginsDir(ROOT.'plugins/')        ->setCacheDir(ROOT.'cache/')        ->setConfigDir(ROOT.'configs');
$smarty->caching = false;$smarty->cache_lifetime = 60*60*24; //模版缓存有效时间为1天$smarty->left_delimiter = '<{';$smarty->right_delimiter = '}>';
/***********************************************************/
//根目录url方式$PHP_SELF=$_SERVER['PHP_SELF'];$ROOT_URL='//'.$_SERVER['HTTP_HOST'].substr($PHP_SELF,0,strrpos($PHP_SELF,'/')+1);define(ROOT_URL,$ROOT_URL);
//模版目录url方式define("Template_Dir",$ROOT_URL.'templates');

创建初始化文件中出现的templates,templates_c,plugins,cache,configs文件夹。

修改的文件都比较相似,而且也非常easy,这里列出register.html和register.php文件的修改。

register.html是注册的前台页面,路径是/templates/register.html

代码如下:

<!DOCTYPE html><html><head><meta charset="utf-8"><title>注册页面</title><link href="<{$Template_Dir}>/css/common.css"  rel="stylesheet" type="text/css"><link href="<{$Template_Dir}>/css/register.css"  rel="stylesheet" type="text/css">
<script src="<{$Template_Dir}>/js/jquery-1.8.3.min.js"></script><script src="<{$Template_Dir}>/js/register.js"></script><!--邮箱下拉--><script src="<{$Template_Dir}>/js/emailup.js"></script></head>
<body><{*导入header.html*}><{include file="header.html"}>
<!-- 内容区 --><div id="container">
    <!--注册区-->    <div id="register">
        <!-- 注册表单 -->        <form id="register-form" action="register_chk.php" method="post">                        <!-- 用户名 -->                    <!-- placeholder HTML5的属性,提供提示信息。输入字段为空时显示,并会在字段获得焦点时消失 -->            <div class="ipt fipt">                <input type="text" name="uname" id="uname" value="" placeholder="输入用户名"  autocomplete="off" />                <!--提示文字-->                <span id="unamechk"></span>            </div>
            <!-- email -->                        <div>                <input type="text" name="uemail" id="uemail" value="" placeholder="常用邮箱地址" autocomplete="off" /><span id="uemailchk"></span><ul></ul>            </div>
            <!-- 密码 -->            <div>                <input type="password" name="upwd" id="upwd" value="" placeholder="设置密码" /><div><span id="upwdchk"></span><img id="pictie" /></div>            </div>                        <!-- 重复密码 -->            <div>                <input type="password" name="rupwd" id="rupwd" value="" placeholder="确认密码" /><span id="rupwdchk"></span>            </div>
            <!--验证码-->            <div class="ipt iptend">                <input type='text' id='yzm' name='yzm' placeholder="验证码" autocomplete="off" />                <img id='yzmpic' src='valcode.php?num=<{showval}>' style="cursor:pointer" alt="验证码" title="验证码">                <a style="cursor:pointer" id='changea'>                    <img id="refpic" src="<{$Template_Dir}>/images/ref.jpg" alt="刷新验证码">                </a>                <span id='yzmchk'></span>            </div>
            <!-- 提交 -->            <button type="button" id="sub">立即注册</button>
            <!-- 服务条款 -->            <span>                <input type="checkbox" name="agree" id="agree" checked="checked">                <label for="agree">我同意  <a href="#">" 服务条款  "</a> 和  <a href="#">" 网络游戏用户隐私权保护和个人信息利用政策 "</a>                </label>            </span>
        </form>
    </div>
</div></body></html>

register.php:

代码如下:

<?php
session_start();
require_once 'init.inc.php';
//设置模版目录,用于模版页头部引用CSS、JS、Images$smarty->assign("Template_Dir",Template_Dir);
$smarty->display('register.html');

同时扩充了生成验证码插件,路径是/plugins/function.showval.php

代码如下:

<?php
//生成验证码function smarty_function_showval($params,$smarty){
    $num = "";    for($i=0;$i<4;$i++){
        $tmp = rand(1,15);        if ($tmp > 9) {            switch ($tmp) {                case(10):                    $num .= 'a';                    break;                case(11):                    $num .= 'b';                    break;                case(12):                    $num .= 'c';                    break;                case(13):                    $num .= 'd';                    break;                case(14):                    $num .= 'e';                    break;                case(15):                    $num .= 'f';                    break;            }        } else {            $num .= $tmp;        }        }
    $mdnum = md5($num);    $_SESSION['num'] = $num;    $_SESSION['mdnum'] = $mdnum;
    //写在session之后    return $mdnum;}
$_SESSION['num'] = smarty_function_showval($params,$smarty);$_SESSION['mdnum'] = md5(smarty_function_showval($params,$smarty));

注意插件的命名:

文件名要放在根目录的plugins目录下,命名规则是 function.函数名.php,文件中函数的命名规则是 smarty_function_函数名($params,$smarty),其中第一个参数是传递给模板的关联数组,第二个参数是接收自动传入的smarty对象,函数要有返回值。


本文由职坐标整理并发布,希望对同学们有所帮助。了解更多详情请关注职坐标WEB前端jQuery频道!

本文由 @沉沙 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程