简约 写文章

1、pom.xml依赖,增加fastjson依赖
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.56</version>
</dependency>

2、数据库表和entity已完成
3、mapper
ArticleMapper,新增文章方法,增加@Options注解,返回自增主键
@Insert("INSERT INTO t_article (u_id,title,content,create_time) VALUES (#{uId},#{title},#{content},#{createTime}) ")
@Options(useGeneratedKeys = true, keyProperty = "id", keyColumn = "id")
void insertArticle(Article article);

ImgMapper,新增图片接口
@Insert("INSERT INTO t_img(a_id,img_url) VALUES (#{aId},#{imgUrl})")
void insertImg(Img img);

4、service
ArticleService接口增加方法
void insertArticle(Article article);

ImgServie接口增加方法
void insertImg(Img img);

5、controller
ArticleController
@PostMapping("/add")
public ResponseResult postArticle(@RequestParam("uId") int uId,
@RequestParam("title") String title,
@RequestParam("content") String content) {
Article article = new Article();
article.setUId(uId);
article.setTitle(title);
article.setContent(content);
article.setCreateTime(new Date());
articleService.insertArticle(article);
//新增文章后,将获取到的自增主键返回给客户端,用于图片地址的写入
return ResponseResult.success(article.getId());
}
新建ImgController,注入ImgService,编写如下方法

@PostMapping("/add")
public ResponseResult addImg(@RequestParam("aId") int aId,
@RequestParam("imgs") String imgs) {
//调用FastJson的序列化工具,将前端传过来的图片数组字符串反序列化为Java的List对象
List<String> imgList = JSONArray.parseArray(imgs, String.class);
//遍历图片List,创建Img对象写入数据库
for (String imgUrl:imgList) {
Img img = new Img();
img.setAId(aId);
img.setImgUrl(imgUrl);
imgService.insertImg(img);
}
return ResponseResult.success();
}

6、swagger测试自行完成
7、前端
注意:在首页点击“写文章”按钮,要判定登录状态,如果没登录,跳转到登录页面;如果已经登录,跳转到写文章页面
write.vue文件的HTML部分
<template>
<view class="container">

<input type="text" v-model="title" placeholder="请输入标题" />

<button class="add-btn" @tap="chooseImg">+图片</button>

<textarea placeholder="输入内容" v-model="content" class="content" />
<text>预览</text>

<view class="grace-text">、
<rich-text :nodes="content" bindtap="tap"></rich-text>
</view>
<button class="green-btn" @tap="postArticle">发布文章</button>
</view>
</template>

js部分
data区

  return {
        title: '',
        content: '',
        userId: uni.getStorageSync('login_key').userId,
        imgs: []
    };

methods区
选择图片上传方法
chooseImg: function() {
var _this = this;
uni.chooseImage({
count: 1,
sizeType: ['original', 'compressed'],
sourceType: ['album'],
success: function(res) {
console.log(JSON.stringify(res.tempFilePaths));
uni.uploadFile({
url: _this.apiServer + '/upload',
filePath: res.tempFilePaths[0],
name: 'file',
success: uploadFileRes => {
//图片上传成功,回显图片地址
console.log(uploadFileRes.data);
//将图片地址加入imgs数组
_this.imgs.push(uploadFileRes.data);
//将图片地址拼接HTML标签,加入文章内容
_this.content += '<img src="' + uploadFileRes.data + '" width = "100%"/>';
}
});
}
});
}

选择图片上传方法
chooseImg: function() {
var _this = this;
uni.chooseImage({
count: 1,
sizeType: ['original', 'compressed'],
sourceType: ['album'],
success: function(res) {
console.log(JSON.stringify(res.tempFilePaths));
uni.uploadFile({
url: _this.apiServer + '/upload',
filePath: res.tempFilePaths[0],
name: 'file',
success: uploadFileRes => {
//图片上传成功,回显图片地址
console.log(uploadFileRes.data);
//将图片地址加入imgs数组
_this.imgs.push(uploadFileRes.data);
//将图片地址拼接HTML标签,加入文章内容
_this.content += '<img src="' + uploadFileRes.data + '" width = "100%"/>';
}
});
}
});
}

发布文章方法
postArticle: function() {
var _this = this;
uni.request({
url: this.apiServer + '/article/add',
method: 'POST',
header: { 'content-type': 'application/x-www-form-urlencoded' },
data: {
uId: this.userId,
title: this.title,
content: '<div>' + this.content + '</div>'
},
success: res => {
if (res.data.code === 0) {
//获得发布文章成功返回的文章id
var aId = res.data.data;
console.log(aId);
uni.showToast({
title: '发布成功'
});
//将文章id和文章对应的图片地址数组传到后台,存入数据库
uni.request({
url: this.apiServer + '/img/add',
method: 'POST',
header: { 'content-type': 'application/x-www-form-urlencoded' },
data: {
aId: aId,
imgs: JSON.stringify(_this.imgs) //序列化imgs数组
},
success: res => {
if (res.data.code === 0) {
console.log('文章图片地址已写入数据库');
}
}
});
uni.switchTab({
url: '../index/index'
});
}
}
});
}

省略css部分

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,386评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,142评论 3 394
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,704评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,702评论 1 294
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,716评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,573评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,314评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,230评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,680评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,873评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,991评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,706评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,329评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,910评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,038评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,158评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,941评论 2 355

推荐阅读更多精彩内容

  • 2.解决问题 超过三张图片:横排三张图(选最后三张图)图片少于3张:图文左右排列(选最后一张图)无图片:只显示文章...
    dnasn阅读 575评论 0 0
  • 1.添加pom依赖<dependency><groupId>com.alibaba</groupId> fastj...
    dnasn阅读 305评论 0 0
  • # 一度蜜v3.0协议 --- # 交互协议 [TOC] ## 协议说明 ### 请求参数 下表列出了v3.0版协...
    c5e350bc5b40阅读 648评论 0 0
  • rljs by sennchi Timeline of History Part One The Cognitiv...
    sennchi阅读 7,332评论 0 10
  • 今天一上午就聊了个天,下午倒干了点事,给淘宝店重新弄了下,还没弄好。晚上开车回家听电台,主要关于男人出轨之...
    一根藤阅读 195评论 0 0