BBS-添加文章及文章中图片
BBS项目中的添加文章
1.添加文章的时候,我们需要特别注意的是这个地方需要利用到到BeautifulSoup这个模块,因为我们在input的框中输入的内容,到了后端我们需要通过BeautifulSoup模块进行转成后端可以使用的文档
from bs4 import BeautifulSoup
# 添加文章
def add_article(request):
tag_list = models.Tag.objects.filter(blog=request.user.blog)
categroy_list = models.Categroy.objects.filter(blog=request.user.blog)
if request.method == 'POST':
title = request.POST.get('title')
content = request.POST.get('content')
tags_list_id = request.POST.getlist('tags_list')
categroy_id = request.POST.get('tategroy')
print('获取分类id', categroy_id)
# 先生成一个模块对象,将文章放进去,获得一个转义后的文章对象
soup = BeautifulSoup(content, 'html.parser')
# print(soup.text),获取的是纯文本
tags = soup.find_all()
# print(tags)获取文章全部标签
for tag in tags:
if tag.name == 'script': # 找到标签名叫script的标签
tag.decompose() # 删除标签
# 截取文章获取文章的150个字符串
desc = soup.text[0:150]
# 操作文章表添加数据到数据库
article_obj = models.Article.objects.create(title=title, content=str(soup), desc=desc, category_id=categroy_id,
blog=request.user.blog)
# 操作第三张表
obj_list = []
for tag_id in tags_list_id:
obj_list.append(models.Article2Tag(article=article_obj, tag=tag_id))
models.Article2Tag.objects.bulk_create(obj_list) # 这里我们可以通过bulk_create来进行批量创建
return redirect('/backend/')
return render(request, 'backend/add_article.html', locals())
2.在文章编辑的时候可以使用kindeditor编辑器,我们需要从网上下载下来,保存到我们的本地静态文件中,然后导入就可以使用了
//导入kindeditor编辑器
<script charset="utf-8" src="/static/kindeditor/kindeditor-all-min.js"></script>
//使用kindeditor编辑器
<script>
KindEditor.ready(function (K) {
window.editor = K.create('#id_comment',{
width: '100%',
height:'450px',
resizeType:0,
uploadJson : '/upload_img/',//上传到这个URL
extraFileUploadParams : {
csrfmiddlewaretoken : '{{ csrf_token }}',
}
});
});
</script>
BBS项目中的添加文章中的图片
文章内上传图片这里需要特别注意点,我们使用什么编辑器,从编辑器中找适合我们所需要上传图片的方法。这里我们需要手动拼存放图片/静态文件的文件路径。
# media配置,能够将用户上传的所有文件都统一指定到这个文件夹下
MEDIA_ROOT = os.path.join(BASE_DIR, 'media')
# 上传静态文件或者图片
import os
from BBS import settings
def upload_img(request):
'''
上传图片这里需要特别注意点,
我们用的什么编辑器,从使用的编辑器中找,
适合我们所需要上传图片的方法
:param request:
:return:
'''
back_dic = {'error': 0}
# 获取用户上传的图片,然后保存到本地
if request.method == 'POST':
# 获取文件或图片
file_obj = request.FILES.get('imgFile')
# 手动拼接文件存储的文件路径
file_path = os.path.join(settings.BASE_DIR, 'media', 'article_img')
if not os.path.isdir(file_path): # 判断是否有这个文件夹,
os.mkdir(file_path) # 如果没有就创建一个这样的文件夹
# 文件操作
# 手动拼接文件名全路径,(地址加文件名)
img_path = os.path.join(file_path, file_obj.name)
with open(img_path, 'wb') as f:
for line in file_obj:
f.write(line)
"""
//成功时
{
"error" : 0,
"url" : "http://www.example.com/path/to/file.ext"
这个路径是文件或者是图片的全路径
}
//失败时
{
"error" : 1,
"message" : "错误信息"
}
"""
_url = '/media/article_img/%s' % file_obj.name
back_dic['url'] = _url
return JsonResponse(back_dic)
BBS-添加文章及文章中图片的更多相关文章
- php笔记之:文章中图片处理的使用
array_diff($arr1,$arr2)php数组函数之一,用来计算数组的差集.正则匹配html图片标签用sinaeditor添加的图片删除操作用法之一,今天晚上在用新浪编辑器发表文章的过程中. ...
- 实现app上对csdn的文章查看,以及文章中图片的保存 (制作csdn app 完结篇)
转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/24022165 今天给大家带来CSDN的完结篇,即增加文章的查看和文章中图片的保存 ...
- 基于.NetCore开发博客项目 StarBlog - (17) 自动下载文章里的外部图片
系列文章 基于.NetCore开发博客项目 StarBlog - (1) 为什么需要自己写一个博客? 基于.NetCore开发博客项目 StarBlog - (2) 环境准备和创建项目 基于.NetC ...
- wordpress添加post_type自定义文章类型
wordpress很强大,能当博客也能进行二次开发出很完善的内容管理系统满足企业运营需求,比如可以添加products产品模型.汽车模型等,如何实现呢?添加post_type自定义文章类型就可以了 p ...
- iOS 把图片从Mac本地添加到iOS Simulator中
[把图片从Mac本地添加到iOS Simulator中] 1. 把图片从Mac本机拖动到iOS Simulator中: 2. iOS Simulator会自动打开Safari去打开对应的图片,然后你用 ...
- 为你的网页图标(Favicon)添加炫丽的动画和图片
Favico.js 在让你的网页图标显示徽章,图像或视频.你设置可以轻松地在网页图标中使用动画,可以自定义类型的动画,背景颜色和文字颜色.它支持的动画,像幻灯片,渐变,弹出等等. 您可能感兴趣的相关文 ...
- 关于Android中图片大小、内存占用与drawable文件夹关系的研究与分析
原文:关于Android中图片大小.内存占用与drawable文件夹关系的研究与分析 相关: Android drawable微技巧,你所不知道的drawable的那些细节 经常会有朋友问我这个问题: ...
- Bootstrap轮播(carousel)插件中图片变形的终极解决方案——使用jqthumb.js
在顶求网的首页中我使用了BootStrap的轮播(carousel)插件来展示文章中的图片.我在程序中自动抓取文章的第一张图片作为该轮播控件中要显示的图片,由于文章的图片大小不一,而轮播插件的大小基本 ...
- Android 中图片压缩分析(上)
作者: shawnzhao,QQ音乐技术团队一员 一.前言 在 Android 中进行图片压缩是非常常见的开发场景,主要的压缩方法有两种:其一是质量压缩,其二是下采样压缩. 前者是在不改变图片尺寸的情 ...
随机推荐
- linux文本处理三剑客命令及用法
grep:文本过滤工具 功能说明: sed :字符流编辑器 功能说明: awk :
- PYTHON 100days学习笔记004:循环结构
目录 Day04 - 循环结构 1. 循环结构的应用场景 2.for-in循环 3. while循环 4. 练习 4.1 输入一个数判断是不是素数. 4.2 输入两个正整数,计算最大公约数和最小公倍数 ...
- windows下,给golang编译的exe添加一个图标
通过go build生成的exe文件,通常是一个默认的图标,发给别人的时候,总觉得像病毒,下面我们来给他加一个好看的图标,让他看起来正经一些. 1.找到一个喜欢的图片. 2.通过工具或是在线工具生成. ...
- ssm框架的小总结
一.mybatis框架 mybatis框架主要就是完成持久层的实现,简化了持久层的开发, 1.首先是配置文件的编写,我们这里就命名为mybatis-config.xml,先配置文件头,然后加载连接数据 ...
- 【LOJ】#3123. 「CTS2019 | CTSC2019」重复
LOJ3123 60pts 正难则反,熟练转成总方案数减掉每个片段都大于等于s的字典序的方案 按照一般的套路建出kmp上每个点加一个字符的转移边的图(注意这个图开始字母必须是nxt链中下一个相邻的字符 ...
- django F与Q查询 事务 only与defer
F与Q 查询 class Product(models.Model): name = models.CharField(max_length=32) #都是类实例化出来的对象 price = mode ...
- MySql 枚举和集合 详解
枚举与集合 枚举类型,enum 每个枚举值均有一个索引值: 在列说明中列表值所允许的成员值被从 1 开始编号. 一般来说就是单选,在定义枚举的时候列出所有的可能性: 代码如下 1. create ta ...
- 垃圾分类API
###自从上月开始实行垃圾分类,整个上海人都已经“疯掉”了.那么,我们应该怎么识别什么是“垃圾”呢? 这里,我提供了并整理了几个api,其中包括图像识别,垃圾分类查找,根据关键字或者图片的内容来进行查 ...
- 进阶Java编程(8)反射应用案例
1,反射实例化对象 经过一系列分析之后可以发现虽然获得了Class类的实例化对象但是依然觉得这个对象获取的意义不是很大,所以为了进一步的帮助大家理解反射的核心意义所在,下面将通过几个案例进行说明(都是 ...
- win10上使用php与python实现与arduino串口通信
注意: php 需要php7,安装及开启php_dio.dll com口按照实际的进行设置,如果不知道可以打开arduino编辑器进行查看 可以与用户实现命令行交互,但是效率过慢,不清楚如何优化,使用 ...