HTML代码存入数据库转义问题(直接存会导致数据库迁移的时候出错)

11 篇文章 0 订阅

PHP 方法

htmlspecialchars
htmlspecialchars_decode

Python方法

import html
html.escape()
html.unescape()

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在将 HTML 代码储到数据库中之前,需要注意去除可能导致 SQL 语句出错的特殊字符,例如单引号、双引号、反斜杠等等。这些字符应该被转义,以避免数据库执行 SQL 语句时出现错误。 在 Python 中,可以使用 MySQL Connector 提供的 `escape_string` 函数来对字符串进行转义。该函数将字符串中的特殊字符转义成对应的转义字符,例如将单引号转义成两个单引号。 以下是一个示例代码,演示了如何使用 `escape_string` 函数对 HTML 代码进行转义储到 MySQL 数据库中: ```python import requests import re from bs4 import BeautifulSoup import mysql.connector # 发送 HTTP 请求获取 HTML 页面 url = 'https://www.example.com' response = requests.get(url) # 使用 BeautifulSoup 解析 HTML 页面 soup = BeautifulSoup(response.text, 'html.parser') # 获取页面标题和正文内容 title = soup.title.text content = str(soup.body) # 去除 HTML 标签和特殊字符 cleanr = re.compile('<.*?>') content = re.sub(cleanr, '', content) content = content.replace('\n', '').replace('\r', '').replace('\t', '') # 转义特殊字符 content = mysql.connector.escape_string(content) # 将标题和内容储到数据库中 cnx = mysql.connector.connect(user='root', password='password', host='127.0.0.1', database='test') cursor = cnx.cursor() add_page = ("INSERT INTO pages " "(title, content) " "VALUES (%s, %s)") data_page = (title, content) cursor.execute(add_page, data_page) cnx.commit() cursor.close() cnx.close() ``` 在上面的代码中,首先使用 `requests` 库发送 HTTP 请求获取 HTML 页面的源代码。然后,使用 `BeautifulSoup` 库解析 HTML 页面,获取页面的标题和正文内容。接着,使用正则表达式去除 HTML 标签和特殊字符,最后使用 `mysql.connector.escape_string` 函数对内容进行转义,并将标题和内容储到数据库中。 需要注意的是,在HTML 代码数据库之前,应该先去除其中的特殊字符,并对其进行转义,以避免储不必要的数据和 SQL 语句执行出错问题

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值