PHP模板引擎就是一个PHP类库,使用它可以使PHP代码和HTML代码进行分离,使代码的可读性和维护性得到显著提高。而且这样做的好处是,让美工专心设计HTML前台页面,程序员专心去写PHP业务逻辑。因此,模化引擎很适合公司的Web开发团队使用,使每个人都能发挥其特长
下面我们就来看看如何简单的来实现php的模板引擎
parser.class.php
<?php /** * 模版解析类 */ class Parser { // 字段,接收模版文件内容 private $_tpl; // 构造方法,获取模版文件内容 public function __construct($_tplFile) { if (! $this->_tpl = file_get_contents($_tplFile)) { exit('ERROR:模版文件读取错误'); } } // 解析普通变量 private function parvar() { $_patten = '/<!--\s+\{\$([\w]+)\}\s+-->/'; if (preg_match($_patten,$this->_tpl)) { $this->_tpl = preg_replace($_patten, "<?php echo \$this->_vars['$1'];?>",$this->_tpl); } } //解析IF语句 private function parif(){ $_pattenif = '/<!--\s+\{if\s+\$([\w]+)\}\s+-->/'; $_pattenElse = '/<!--\s+\{else\}\s+-->/'; $_pattenEndif = '/<!--\s+\{\/if\}\s+-->/'; if (preg_match($_pattenif,$this->_tpl)) { if (preg_match($_pattenEndif,$this->_tpl)) { $this->_tpl = preg_replace($_pattenif,"<?php if (\$this->_vars['$1']){?>",$this->_tpl); $this->_tpl = preg_replace($_pattenEndif,"<?php } ?>",$this->_tpl); if (preg_match($_pattenElse,$this->_tpl)) { $this->_tpl = preg_replace($_pattenElse,"<?php }else{?>",$this->_tpl); } }else{ echo 'ERROR:IF语句没有关闭!'; } } } //PHP注释解析 private function parCommon(){ $_pattenCommon = '/<!--\s+\{#\}(.*)\{#\}\s+-->/'; if (preg_match($_pattenCommon,$this->_tpl)) { $this->_tpl = preg_replace($_pattenCommon,"<?php /* $1 */ ?>",$this->_tpl); } } //解析foreach语句 private function parForeach(){ $_pattenForeach = '/<!--\s+\{foreach\s+\$([\w]+)\(([\w]+),([\w]+)\)\}\s+-->/'; $_pattenForeachEnd = '/<!--\s+\{\/foreach\}\s+-->/'; $_pattenForeachValue = '/<!--\s+\{@([\w]+)\}\s+-->/'; if (preg_match($_pattenForeach,$this->_tpl)) { if (preg_match($_pattenForeachEnd,$this->_tpl)) { $this->_tpl = preg_replace($_pattenForeach, "<?php foreach (\$this->_vars['$1'] as \$$2=>\$$3) {?>", $this->_tpl); $this->_tpl = preg_replace($_pattenForeachEnd, "<?php }?>", $this->_tpl); if (preg_match($_pattenForeachValue, $this->_tpl)) { $this->_tpl = preg_replace($_pattenForeachValue,"<?php echo \$$1;?>",$this->_tpl); } }else{ echo 'ERROR:Foreach语句没有关闭!'; } } } //解析include方法 private function parInclude(){ $_pattenInclude = '/<!--\s+\{include\s+file=\"([\w\.\-]+)\"\}\s+-->/'; if (preg_match($_pattenInclude,$this->_tpl,$_file,$_file)) { if (!file_exists($_file[1])||empty($_file)) { echo 'ERROR:包含文件出错!'; } $this->_tpl = preg_replace($_pattenInclude,"<?php include '$1';?>",$this->_tpl); } } //解析系统变量方法 private function parConfig(){ $_pattenConfig = '/<!--\s+\{([\w]+)\}\s+-->/'; if (preg_match($_pattenConfig,$this->_tpl)) { $this->_tpl = preg_replace($_pattenConfig,"<?php echo \$this->_config['$1'];?>",$this->_tpl); } } // 对外公共方法 public function compile($_path) { // 解析模版文件 $this->parvar(); $this->parif(); $this->parForeach(); $this->parInclude(); $this->parCommon(); $this->parConfig(); // 生成编译文件 if (! file_put_contents($_path, $this->_tpl)) { exit('ERROR:编译文件生成错误!'); } } } ?>
Templates.class.php
<?php /** * 模版类 */ class Templates { //注入变量 private $_vars = array(); //保存系统变量数组字段 private $_config = array(); //创建一个构造方法,来检测各个目录是否存在 public function __construct() { if (! is_dir(TPL_DIR) || ! is_dir(TPL_C_DIR) || ! is_dir(CACHE) || !is_dir(CONFIG)) { echo 'ERROR:模版目录或编译目录,缓存目录不存在!自动创建!'."<br />"; if (!is_dir(TPL_DIR)) { mkdir(TPL_DIR); echo '模版目录'.TPL_DIR.'建立'."<br />"; } if (!is_dir(TPL_C_DIR)) { mkdir(TPL_C_DIR); echo '编译目录'.TPL_C_DIR.'建立'."<br />"; } if (!is_dir(CACHE)) { mkdir(CACHE); echo '缓存目录'.CACHE.'建立'."<br />"; } if (!is_dir(CONFIG)) { mkdir(CONFIG); echo '缓存目录'.CONFIG.'建立'."<br />"; } exit(); } //保存系统变量 $_sxe = simplexml_load_file(CONFIG.'/config.xml'); $_tagLib = $_sxe->xpath('/root/taglib'); foreach ($_tagLib as $_tag) { $this->_config["$_tag->name"] = $_tag->value; } } //assign()方法,用于注入变量 public function assign($_var,$_value){ //$_var用于同步模版里的变量名 //$_value表示值 if (isset($_var)&&!empty($_var)) { $this->_vars[$_var] = $_value; }else{ exit('ERROR:设置模版变量!'); } } //display()方法 public function display($_file) { $_tplFile = TPL_DIR . $_file; // 判断文件是否存在 if (! file_exists($_tplFile)) { echo 'ERROR:模版文件不存在!自动创建Index.tpl模版文件!'; file_put_contents($_tplFile,'Index'); exit(); } //生成编译文件 $_path = TPL_C_DIR.md5($_file).'-'.$_file.'.php'; //缓存文件 $_cacheFile = CACHE.md5($_file).'-'.$_file.'.html'; //当第二次运行相同文件,直接载入缓存文件 if (IS_CACHE) { //判断缓存文件和编译文件都存在 if (file_exists($_cacheFile)&&file_exists($_path)) { //判断模版文件是否修改过 if (filemtime($_path)>=filemtime($_tplFile)&&filemtime($_cacheFile)>=filemtime($_path)) { include $_cacheFile; echo '<!--cache-->'; return; } } } //当编译文件不存在或者文件发生改变则重新生成 if (!file_exists($_path)||filemtime($_path)<filemtime($_tplFile)) { require ROOT_PATH.'/Class/parser.class.php'; //构造方法是传入模版文件地址 $_parser = new Parser($_tplFile); //传入编译文件地址 $_parser->compile($_path); } //载入编译文件 include $_path; if (IS_CACHE) { //获取缓冲区数据 file_put_contents($_cacheFile,ob_get_contents()); //清楚缓冲区 ob_end_clean(); //载入缓存文件 include $_cacheFile; } } } ?>
templates.php
<?php //设置字符编码UTF-8 header('Content-Type:text/html;charset=utf-8'); //网站根目录 define('ROOT_PATH',dirname(__FILE__)); //存放模版文件夹 define('TPL_DIR',ROOT_PATH.'/Templates/'); //编译文件夹 define('TPL_C_DIR',ROOT_PATH.'/Templates_c/'); //缓存文件夹 define('CACHE',ROOT_PATH.'/Cache/'); //系统变量配置目录 define('CONFIG',ROOT_PATH.'/Config/'); //是否开启缓冲区 define('IS_CACHE',false);//false //判断是否需要开启 IS_CACHE ? ob_start() : null; //引入模版类 require ROOT_PATH.'/Class/Templates.class.php'; //实例化模版类 $_tpl=new Templates(); $_tpl->display('index.tpl'); ?>
templates/index.tpl
<!DOCTYPE html> <html lang="zn-cn"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no"> <meta name="description" content=""> <meta name="keywords" content=""> <meta name="author" content=""> <meta name="author" content=""> <title><!-- {WebName} --></title> <link rel="stylesheet" type="text/css" href="css/bootstrap.min.css"> <link rel="stylesheet" type="text/css" href="css/style.css"> </head> <body> <!-- {#}php注释{#} --> <!-- {if $a} --> 123 <!-- {else} --> 321 <!-- {/if} --> <br /> <!-- {foreach $array(key,value)} --> <!-- {@key} -->...<!-- {@value} --><br /> <!-- {/foreach} --> 系统变量<!-- {WebName} --><br /> 普通变量<!-- {$name} --><br /> <script src="/js/jquery-2.2.1.min.js" type="text/javascript"></script> <script src="/js/bootstrap.min.js" type="text/javascript"></script> <script type="text/javascript"> </script> </body> </html>
config/config.xml
<?xml version="1.0" encoding="UTF-8"?> <root> <taglib> <name>WebName</name> <value>XXX网站</value> </taglib> </root>

데이터베이스 스토리지 세션 사용의 주요 장점에는 지속성, 확장 성 및 보안이 포함됩니다. 1. 지속성 : 서버가 다시 시작 되더라도 세션 데이터는 변경되지 않아도됩니다. 2. 확장 성 : 분산 시스템에 적용하여 세션 데이터가 여러 서버간에 동기화되도록합니다. 3. 보안 : 데이터베이스는 민감한 정보를 보호하기 위해 암호화 된 스토리지를 제공합니다.

SessionHandlerInterface 인터페이스를 구현하여 PHP에서 사용자 정의 세션 처리 구현을 수행 할 수 있습니다. 특정 단계에는 다음이 포함됩니다. 1) CustomsessionHandler와 같은 SessionHandlerInterface를 구현하는 클래스 만들기; 2) 인터페이스의 방법 (예 : Open, Close, Read, Write, Despare, GC)의 수명주기 및 세션 데이터의 저장 방법을 정의하기 위해 방법을 다시 작성합니다. 3) PHP 스크립트에 사용자 정의 세션 프로세서를 등록하고 세션을 시작하십시오. 이를 통해 MySQL 및 Redis와 같은 미디어에 데이터를 저장하여 성능, 보안 및 확장 성을 향상시킬 수 있습니다.

SessionId는 웹 애플리케이션에 사용되는 메커니즘으로 사용자 세션 상태를 추적합니다. 1. 사용자와 서버 간의 여러 상호 작용 중에 사용자의 신원 정보를 유지하는 데 사용되는 무작위로 생성 된 문자열입니다. 2. 서버는 쿠키 또는 URL 매개 변수를 통해 클라이언트로 생성하여 보낸다. 3. 생성은 일반적으로 임의의 알고리즘을 사용하여 독창성과 예측 불가능 성을 보장합니다. 4. 실제 개발에서 Redis와 같은 메모리 내 데이터베이스를 사용하여 세션 데이터를 저장하여 성능 및 보안을 향상시킬 수 있습니다.

JWT 또는 쿠키를 사용하여 API와 같은 무국적 환경에서 세션을 관리 할 수 있습니다. 1. JWT는 무국적자 및 확장 성에 적합하지만 빅 데이터와 관련하여 크기가 크다. 2. 쿠키는보다 전통적이고 구현하기 쉽지만 보안을 보장하기 위해주의해서 구성해야합니다.

세션 관련 XSS 공격으로부터 응용 프로그램을 보호하려면 다음 조치가 필요합니다. 1. 세션 쿠키를 보호하기 위해 Httponly 및 Secure 플래그를 설정하십시오. 2. 모든 사용자 입력에 대한 내보내기 코드. 3. 스크립트 소스를 제한하기 위해 컨텐츠 보안 정책 (CSP)을 구현하십시오. 이러한 정책을 통해 세션 관련 XSS 공격을 효과적으로 보호 할 수 있으며 사용자 데이터가 보장 될 수 있습니다.

PHP 세션 성능을 최적화하는 방법 : 1. 지연 세션 시작, 2. 데이터베이스를 사용하여 세션을 저장, 3. 세션 데이터 압축, 4. 세션 수명주기 관리 및 5. 세션 공유 구현. 이러한 전략은 높은 동시성 환경에서 응용의 효율성을 크게 향상시킬 수 있습니다.

THESESSION.GC_MAXLIFETIMESETTINGINSTTINGTINGSTINGTERMINESTERMINESTERSTINGSESSIONDATA, SETINSECONDS.1) IT'SCONFIGUDEDINPHP.INIORVIAINI_SET ()

PHP에서는 Session_Name () 함수를 사용하여 세션 이름을 구성 할 수 있습니다. 특정 단계는 다음과 같습니다. 1. Session_Name () 함수를 사용하여 Session_Name ( "my_session")과 같은 세션 이름을 설정하십시오. 2. 세션 이름을 설정 한 후 세션을 시작하여 세션을 시작하십시오. 세션 이름을 구성하면 여러 응용 프로그램 간의 세션 데이터 충돌을 피하고 보안을 향상시킬 수 있지만 세션 이름의 독창성, 보안, 길이 및 설정 타이밍에주의를 기울일 수 있습니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

WebStorm Mac 버전
유용한 JavaScript 개발 도구

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기
