mirror of
https://github.com/smarty-php/smarty.git
synced 2025-07-31 00:17:15 +02:00
@ -9,7 +9,8 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
|||||||
### Added
|
### Added
|
||||||
- PHP8.3 support [#925](https://github.com/smarty-php/smarty/issues/925)
|
- PHP8.3 support [#925](https://github.com/smarty-php/smarty/issues/925)
|
||||||
- Backlink to GitHub in docs
|
- Backlink to GitHub in docs
|
||||||
-
|
- Explain how to do escaping and set-up auto-escaping in docs [#865](https://github.com/smarty-php/smarty/issues/865)
|
||||||
|
|
||||||
### Fixed
|
### Fixed
|
||||||
- The {debug} tag was broken in v5 [#922](https://github.com/smarty-php/smarty/issues/922)
|
- The {debug} tag was broken in v5 [#922](https://github.com/smarty-php/smarty/issues/922)
|
||||||
|
|
||||||
|
@ -90,3 +90,4 @@ Run this, and you will see:
|
|||||||
|
|
||||||
Note how the [escape modifier](../designers/language-modifiers/language-modifier-escape.md)
|
Note how the [escape modifier](../designers/language-modifiers/language-modifier-escape.md)
|
||||||
translated the `&` character into the proper HTML syntax `&`.
|
translated the `&` character into the proper HTML syntax `&`.
|
||||||
|
Read more about auto-escaping in the [next section](./configuring.md).
|
@ -122,6 +122,24 @@ $smarty->setCacheDir('/data/caches');
|
|||||||
$cacheDir = $smarty->getCacheDir();
|
$cacheDir = $smarty->getCacheDir();
|
||||||
```
|
```
|
||||||
|
|
||||||
|
## Enabling auto-escaping
|
||||||
|
By default, Smarty does not escape anything you render in your templates. If you use
|
||||||
|
Smarty to render a HTML-page, this means that you will have to make sure that you do
|
||||||
|
not render any characters that have a special meaning in HTML, such as `&`, `<` and `>`,
|
||||||
|
or apply the [escape modifier](../designers/language-modifiers/language-modifier-escape.md)
|
||||||
|
to anything you want to render.
|
||||||
|
|
||||||
|
If you forget to do so, you may break your HTML page, or even create a vulnerability for
|
||||||
|
attacks known as [XSS or Cross Site Scripting](https://cheatsheetseries.owasp.org/cheatsheets/Cross_Site_Scripting_Prevention_Cheat_Sheet.html).
|
||||||
|
|
||||||
|
Luckily, you can tell Smarty to automatically apply the escape modifier to any dynamic part of your template.
|
||||||
|
It's like Smarty magically adds `|escape` to every variable you use on a web page.
|
||||||
|
|
||||||
|
Enable auto-escaping for HTML as follows:
|
||||||
|
```php
|
||||||
|
$smarty->setEscapeHtml(true);
|
||||||
|
```
|
||||||
|
|
||||||
## Disabling compile check
|
## Disabling compile check
|
||||||
By default, Smarty tests to see if the
|
By default, Smarty tests to see if the
|
||||||
current template has changed since the last time
|
current template has changed since the last time
|
||||||
|
@ -86,7 +86,7 @@ needs to be located in the [`$template_dir`](./programmers/api-variables/variabl
|
|||||||
|
|
||||||
```smarty
|
```smarty
|
||||||
{* Smarty *}
|
{* Smarty *}
|
||||||
Hello {$name}, welcome to Smarty!
|
<h1>Hello {$name|escape}, welcome to Smarty!</h1>
|
||||||
```
|
```
|
||||||
|
|
||||||
> **Note**
|
> **Note**
|
||||||
@ -132,6 +132,20 @@ Now, run your PHP file. You should see *"Hello Ned, welcome to Smarty!"*
|
|||||||
|
|
||||||
You have completed the basic setup for Smarty!
|
You have completed the basic setup for Smarty!
|
||||||
|
|
||||||
|
## Escaping
|
||||||
|
You may have noticed that the example template above renders the `$name` variable using
|
||||||
|
the [escape modifier](./designers/language-modifiers/language-modifier-escape.md). This
|
||||||
|
modifier makes string 'safe' to use in the context of an HTML page.
|
||||||
|
|
||||||
|
If you are primarily using Smarty for HTML-pages, it is recommended to enable automatic
|
||||||
|
escaping. This way, you don't have to add `|escape` to every variable you use on a web page.
|
||||||
|
Smarty will handle it automatically for you!
|
||||||
|
|
||||||
|
Enable auto-escaping for HTML as follows:
|
||||||
|
```php
|
||||||
|
$smarty->setEscapeHtml(true);
|
||||||
|
```
|
||||||
|
|
||||||
## Extended Setup
|
## Extended Setup
|
||||||
|
|
||||||
This is a continuation of the [basic installation](#installation), please read that first!
|
This is a continuation of the [basic installation](#installation), please read that first!
|
||||||
@ -157,6 +171,8 @@ class My_GuestBook extends Smarty {
|
|||||||
$this->setConfigDir('/web/www.example.com/guestbook/configs/');
|
$this->setConfigDir('/web/www.example.com/guestbook/configs/');
|
||||||
$this->setCacheDir('/web/www.example.com/guestbook/cache/');
|
$this->setCacheDir('/web/www.example.com/guestbook/cache/');
|
||||||
|
|
||||||
|
$this->setEscapeHtml(true);
|
||||||
|
|
||||||
$this->caching = Smarty::CACHING_LIFETIME_CURRENT;
|
$this->caching = Smarty::CACHING_LIFETIME_CURRENT;
|
||||||
$this->assign('app_name', 'Guest Book');
|
$this->assign('app_name', 'Guest Book');
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user