bbs--文章后台

需求分析

在个人文章后台中

1 有添加文章的接口

  展示文章标题输入框

  文本编辑框

  标签 分类 选择框

  提交

2 编辑文章的接口

  页面与添加文章相同,就是把该文章的内容展示到文本编辑框中

3 删除文章的接口

  点击删除,文章清除

4 页面2 10布局,左侧有添加文章功能

  右侧以列表形式展现每一条文章,且有分页功能 

文章发布

模块及插件引入

kindeditor插件<\a>

BS4模块<\a>

  安装

  pip install beautifulsoup4

  简单使用

1. from bs4 import BeautifulSoup
# 对一段HTML格式的内容做解析
soup = BeautifulSoup('html内容', 'html.parser')
2. 找标签:
soup.a
3. 找标签的样式:
soup.a["class"]
4. 找特定的标签
soup.select("script")
5. 删除标签
.decompose()
6. 取text文本内容
soup.text
7. 格式化html内容
soup.prettify()

代码思路

页面展示

1 前端页面布局,然后添加文本编辑按照kindeditor插件的说明,进行配置

2 这里说一下图片展示

  前端方面按照kindeditor插件的说明

  后端单独写一个专门对图片的视图函数

  1 接受前端发送的图片文件对象

  2 把文件对象写入我们自己定义的media下的文件夹中

  3 将文件路径,以url形式返回给前端

文章发布

1 前端通过form的post请求,发送 文章标题  内容  标签

2 后端接受上面的数据,保存数据 文章记录 和 文章详情记录 事务链接

  这里要注意的是接受的文章内容为html标签

  我们要通过bs4模块将接受的内容进行编辑

  1 将文本内容,切前150个数据作为文章描述

  2 将得到的文章格式化成字符串,保存在文章详情数据库中

如果想用ajax获取文本内容

实际操作

  html 

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>添加新页面</title>
<link rel="stylesheet" href="/static/bootstrap-3.3.7/css/bootstrap.css">
</head>
<body>
<div class="container">
<div class="row">
<div class="col-md-12">
<form action="" method="post">
{% csrf_token %}
<div class="form-group">
<label for="title">标题</label>
<input type="text" class="form-control" id="title" name="title" placeholder="标题">
</div>
<div class="form-group">
<label for="content">内容</label>
<textarea class="form-control" name="content" id="content" cols="" rows=""></textarea>
</div> <div class="form-group">
<label for="category">文章分类</label>
<select name="category" id="category" class="form-control">
{% for category in category_list %}
<option value="{{ category.id }}">{{ category.title }}</option>
{% endfor %}
</select>
</div>
<button type="submit" class="btn btn-success">发布</button>
</form>
</div>
</div>
</div>
<script src="/static/js/jquery.js"></script>
<script charset="utf-8" src="/static/plugins/kindeditor/kindeditor-all.js"></script>
<script charset="utf-8" src="/static/plugins/kindeditor/lang/zh-CN.js"></script>
<script>
KindEditor.ready(function(K) {
window.editor = K.create('#content', {
"uploadJson": "/blog/upload/",
"extraFileUploadParams": {"csrfmiddlewaretoken": $("[name='csrfmiddlewaretoken']").val()}
});
});
</script>
</body>
</html>

views

# 添加新文章
def add_article(request):
if request.method == "POST":
# 获取用户填写的文章内容
title = request.POST.get("title")
content = request.POST.get("content")
category_id = request.POST.get("category") # 清洗用户发布的文章的内容,去掉script标签
soup = BeautifulSoup(content, "html.parser")
script_list = soup.select("script")
for i in script_list:
i.decompose()
# print(soup.text)
# print(soup.prettify()) # 写入数据库
with transaction.atomic():
# 1. 先创建文章记录
article_obj = models.Article.objects.create(
title=title,
desc=soup.text[0:150],
user=request.user,
category_id=category_id
)
# 2. 创建文章详情记录
models.ArticleDetail.objects.create(
content=soup.prettify(),
article=article_obj
)
return redirect("/blog/backend/") # 把当前博客的文章分类查询出来
category_list = models.Category.objects.filter(blog__userinfo=request.user)
return render(request, "add_article.html", {"category_list": category_list}) # 富文本编辑器的图片上传
def upload(request):
res = {"error": 0}
print(request.FILES)
file_obj = request.FILES.get("imgFile")
file_path = os.path.join(settings.MEDIA_ROOT, "article_imgs", file_obj.name)
with open(file_path, "wb") as f:
for chunk in file_obj.chunks():
f.write(chunk)
# url = settings.MEDIA_URL + "article_imgs/" + file_obj.name
url = "/media/article_imgs/" + file_obj.name
res["url"] = url
return JsonResponse(res)

删除文章

代码思路

1 js 点击删除,获取对应这条文章的id,传给后端

2 后端删除数据

修改文章

与文章发布相同

1 点击编辑,通过get请求得到文章的id,

2 后端通过文章id,查询出文章内容,传给后端。

代码思路

bbs--文章后台的更多相关文章

  1. 1210 BBS admin后台管理及侧边栏筛选个人站点

    目录 昨日内容 django admin后台管理 使用 建表 用户图片的显示 MEDIA用户配置 查找照片 搭建个人站点 防盗链 新建css文件 侧边栏展示标签 定义分类栏与标签栏 定义时间栏 侧边栏 ...

  2. BBS论坛 后台管理

    七.后台管理 后台管理页面: <!DOCTYPE html> <html lang="en"> <head> <meta charset= ...

  3. day75 bbs项目☞后台管理+修改头像

    目录 一.后台管理之添加文章 二.修改用户头像 bbs项目总结 一.后台管理之添加文章 添加文章有两个需要注意的问题: 文章的简介切取,应该想办法获取到当前文章的文本内容后再截取字符 XSS攻击,由于 ...

  4. BBS - 文章详细页、点赞、踩灭

    一.文章详细页 文章详细页:1.链接:<div><h5><a href="/blog/{{ article.user.username }}/articles/ ...

  5. BBS - 文章评论

    一.文章评论 <div class="comment_region"> <div class="row"> <div class= ...

  6. dede后台删除文章后台还有分页显示解决方法

    打开dede目录中content_list.php 大概在100行左右 $sql = "SELECT COUNT(*) AS dd FROM `#@__arctiny` $tinyQuery ...

  7. 编辑bbs文章 获取前端标题内容 和前端内容的方法

  8. BBS - 后台管理

    一.添加文章 注: 后台管理页面,应该有个新得 app /blog/backend/ # 文章列表页/blog/add_article/ # 添加文章 # 后台管理re_path(r'backend/ ...

  9. BBS项目之后台管理

    一:后台管理,添加文章样式编写 创建 一个后台管理模板前段页面 <!DOCTYPE html> <html lang="en"> <head> ...

  10. Django - 学习目录

    Django 基础 web应用/http协议/web框架 Django简介 Django - 路由层(URLconf) Django - 视图层 Django - 模板层 Django - 模型层 - ...

随机推荐

  1. 关于python中的包,模块导入的问题详解(一)

    最近由于初学python,对包,模块的导入问题进行了资料的搜集,查阅,在这里做一个总结: 一: import 模块 在import的过程中发生了什么?我们用一个实验来说明: 以上截图表明:在impor ...

  2. Unity Cube一面显示图片

    Cube加plane 把plane调整到和cube的一面一样大小,并放到那一面的位置,然后再Hierarchy面板选中plane,把图片拖到Inspector的plane下.

  3. HTML Ueditor加载空白问题

    问题描述 Ueditor打开时加载不出内容 原因分析 Ueditor重复加载时,会存在缓存问题 Ueditor采用异步加载方式,所以数据获取和赋值要写在Ueditor异步回调里 解决方案 UE.del ...

  4. javaScript节流与防抖

    一.节流(throttle) 用来实现阻止在短时间内重复多次触发同一个函数.主要用途:防止使用脚本循环触发网络请求的函数的恶意行为,确保请求的真实性(当然也包括其他阻止高频触发行为的应用): 实现原理 ...

  5. 如何部署自定义的servlet

    1 首先找到与exlipse绑定的tomcat安装位置 2 打开web.xml添加如下信息: <display-name>servletDemo</display-name> ...

  6. java之JVM学习--简单了解GC算法

    JVM内存组成结构: (1)堆 所有通过new创建的对象都是在堆中分配内存,其大小可以通过-Xmx和-Xms来控制,堆被划分为新生代和旧生代,新生代又被进一步划分为Eden和Survivor区.Sur ...

  7. HashMap闭环(死循环)的详细原因(转)

    为何出现死循环简要说明 HashMap是非线程安全的,在并发场景中如果不保持足够的同步,就有可能在执行HashMap.get时进入死循环,将CPU的消耗到100%. HashMap采用链表解决Hash ...

  8. linux 下安装python2.7.13

    1.下载所必要的依赖包 yum -y install python-devel openssl openssl-devel gcc sqlite sqlite-devel mysql-devel li ...

  9. sklearn--数据集的处理 模型参数选择

    1.随机划分训练集和测试集 sklearn.model_selection.train_test_split 一般形式: train_test_split是交叉验证中常用的函数,功能是从样本中随机的按 ...

  10. java中的集合总结

    知识点: 集合框架和List.set.Map相关集合特点的描述 Collection接口常用方法,List中相对Collection新增的方法,Collection的遍历(一般for循环,增强for循 ...