Safely add untrusted strings to HTML/XML markup. (LADI project)
Go to file
David Lord cdeec53145
always build extension in cibuildwheel env
2021-01-29 15:00:45 -08:00
.github/workflows Build aarch64 wheels 2021-01-29 13:49:03 -08:00
bench add style checks 2018-11-03 15:31:24 -07:00
docs update docs config 2020-04-09 13:40:19 -07:00
src/markupsafe release 1.1.1 2019-02-23 14:35:18 -08:00
tests Add NULL check after native call to __html__ method 2019-02-20 07:17:42 -08:00
.editorconfig add style checks 2018-11-03 15:31:24 -07:00
.gitignore update project files 2018-05-02 14:07:33 -07:00
.pre-commit-config.yaml finish Azure Pipelines config 2020-01-26 10:09:36 -08:00
.readthedocs.yaml update docs config 2020-04-09 13:40:19 -07:00
CHANGES.rst update docs config 2020-04-09 13:40:19 -07:00
LICENSE.rst update license data 2019-02-23 14:20:43 -08:00
MANIFEST.in finish Azure Pipelines config 2020-01-26 10:09:36 -08:00
README.rst update test status link 2020-01-26 16:21:09 -08:00
setup.cfg finish Azure Pipelines config 2020-01-26 10:09:36 -08:00
setup.py always build extension in cibuildwheel env 2021-01-29 15:00:45 -08:00
tox.ini Add Python 3.9 support for 1.1.x (#163) 2021-01-29 13:15:20 -08:00

README.rst

MarkupSafe
==========

MarkupSafe implements a text object that escapes characters so it is
safe to use in HTML and XML. Characters that have special meanings are
replaced so that they display as the actual characters. This mitigates
injection attacks, meaning untrusted user input can safely be displayed
on a page.


Installing
----------

Install and update using `pip`_:

.. code-block:: text

    pip install -U MarkupSafe

.. _pip: https://pip.pypa.io/en/stable/quickstart/


Examples
--------

.. code-block:: pycon

    >>> from markupsafe import Markup, escape
    >>> # escape replaces special characters and wraps in Markup
    >>> escape('<script>alert(document.cookie);</script>')
    Markup(u'&lt;script&gt;alert(document.cookie);&lt;/script&gt;')
    >>> # wrap in Markup to mark text "safe" and prevent escaping
    >>> Markup('<strong>Hello</strong>')
    Markup('<strong>hello</strong>')
    >>> escape(Markup('<strong>Hello</strong>'))
    Markup('<strong>hello</strong>')
    >>> # Markup is a text subclass (str on Python 3, unicode on Python 2)
    >>> # methods and operators escape their arguments
    >>> template = Markup("Hello <em>%s</em>")
    >>> template % '"World"'
    Markup('Hello <em>&#34;World&#34;</em>')


Donate
------

The Pallets organization develops and supports MarkupSafe and other
libraries that use it. In order to grow the community of contributors
and users, and allow the maintainers to devote more time to the
projects, `please donate today`_.

.. _please donate today: https://palletsprojects.com/donate


Links
-----

*   Website: https://palletsprojects.com/p/markupsafe/
*   Documentation: https://markupsafe.palletsprojects.com/
*   Releases: https://pypi.org/project/MarkupSafe/
*   Code: https://github.com/pallets/markupsafe
*   Issue tracker: https://github.com/pallets/markupsafe/issues
*   Test status: https://dev.azure.com/pallets/markupsafe/_build
*   Official chat: https://discord.gg/t6rrQZH