uniapp+node.js+mysql上传图片加表单数据,代码很粗糙将就着看适用于新手

前端这里图片限制了暂时是一张,没有做太多的条件约束

<template>
	<view class="form_list">
		<u-form :model="form" ref="uForm">
			<u-form-item label="标题">
				<u-input v-model="form.title" />
			</u-form-item>
			<u-form-item label="内容">
				<u-input v-model="form.intro" />
			</u-form-item>
			<u-form-item label="图片">
				<u-button @click="checkimg">上传</u-button>
				<img class="img_one" :src="filesArr" alt="" />
			</u-form-item>
			<u-button @click="submit">提交</u-button>
		</u-form>
	</view>
</template>

<script>
	export default {
		data() {
			return {
				form: {
					title: '',
					intro: '',
				},
				filesArr: '',
			};
		},

		methods: {
			checkimg() {
				uni.chooseImage({
					count: 1,
					success: (res) => {
						console.log(res, '返回临时路径');
						this.filesArr = res.tempFilePaths[0];
					}
				});
			},

			submit() {
				if (this.filesArr) {
					uni.uploadFile({
						url: 'http://127.0.0.1:3000/chat',
						filePath: this.filesArr,
						name: 'pic',
						formData: {
							'title': this.form.title,
							'info': this.form.intro,
						},
						success: (res) => {
							console.log('Chat submitted successfully:', res.data);

						},
						fail: (err) => {
							console.error('Chat submission failed:', err);

						},
					});
				} else {
					console.error('No file selected');
				}
			},

		},
	};
</script>

<style scoped>
	.form_list {
		width: 95%;
		margin: 0 auto;
	}

	.img_one {
		width: 50px;
		height: 50px;
	}
</style>

后端

记得托管静态文件

还有配置一下multer

const multer = require('multer');
// 配置multer用于处理文件上传
const storage = multer.diskStorage({
  destination: (req, file, cb) => {
    cb(null, 'uploads/'); // 设置文件存储路径
  },
  filename: (req, file, cb) => {
    cb(null, Date.now() + '-' + file.originalname); // 设置文件名
  },
});

const upload = multer({ storage });
//托管静态文件
app.use('/uploads', express.static('uploads'));

app.post('/chat', upload.single('pic'), (req, res) => {
  const { title, info } = req.body;

  // Assuming you want to store the uploaded picture in the database
  const pic = req.file ? req.file.filename : null;
  const picUrl = pic ? `http://127.0.0.1:3000/uploads/${pic}` : null;

  if (!title || !info) {
      return res.status(400).json({ error: 'Incomplete data for adding a chat' });
  }

  const sql = 'INSERT INTO chat (title, info, pic) VALUES (?, ?, ?)';
  db.query(sql, [title, info, picUrl], (err, results) => {
      if (err) throw err;

      res.json({ message: 'Chat added successfully', chatId: results.insertId });
  });
});

数据库字段

数据名chat列名id,title,info

  • 7
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
MySQL 是一款广受欢迎的开源关系型数据库管理系统(RDBMS),由瑞典MySQL AB公司开发,现隶属于美国甲骨文公司(Oracle)。自1998年首次发布以来,MySQL以其卓越的性能、可靠性和可扩展性,成为全球范围内Web应用程序、企业级解决方案以及其他各种数据处理场景的首选数据库平台之一。 以下是对MySQL数据库的详细介绍: 核心特性与优势 开源与跨平台 MySQL遵循GPL开源协议,这意味着任何人都可以免费下载、使用和修改其源代码。这种开放性促进了广泛的社区支持和第三方插件、工具的发展。此外,MySQL支持多种操作系统,包括Windows、Linux、macOS、Solaris等,确保了其在不同环境下的兼容性和部署灵活性。 关系型模型与SQL支持 MySQL基于关系型数据库模型,数据以表格形式组织,并通过预定义的键(如主键、外键)在表之间建立关联。它完全支持结构化查询语言(SQL),允许用户进行数据查询、插入、更新、删除、创建和管理数据库结构等操作。SQL标准的广泛支持使得MySQL易于学习,且与其他关系型数据库系统有良好的互操作性。 存储引擎 MySQL支持多种存储引擎,如InnoDB、MyISAM、MEMORY等,每种引擎都有特定的优势和适用场景。例如,InnoDB提供事务安全、行级锁定和外键约束,适合处理高并发事务性的应用;MyISAM则更侧重于读取密集型操作,提供全文索引支持,适用于读多写少的场景。这种多引擎架构使得MySQL能够适应不同业务需求,提供高度定制化的存储解决方案。 性能与可扩展性 MySQL通过高效的缓存机制、查询优化器以及对硬件资源的有效利用,保证了在高负载情况下的稳定性和快速响应。它支持水平扩展(如通过分片、复制等技术)和垂直扩展(如增硬件资源),以应对大规模数据存储和高并发访问的需求。 安全性与管理工具 MySQL提供了一系列安全措施,如用户账户管理、访问权限控制、SSL/TLS密连接、审计日志等功能,确保数据的安全性和合规性。同时,MySQL附带了一系列管理工具,如MySQL Server、MySQL Workbench、MySQL Shell等,便于用户进行数据库配置、监控、备份、恢复、迁移等工作。 社区与生态系统 MySQL拥有庞大的开发者社区和丰富的第三方插件、库、中间件支持,提供了丰富的文档、教程、论坛以及专业服务,极大地简化了开发、运维和故障排查过程。 关键组件与日志 系统数据MySQL内部包含几个特殊的系统数据库,如: information_schema:提供关于所有数据库、表、列、索引等元数据信息,是查询数据库结构的标准接口。 mysql:存储MySQL自身的系统信息,如用户权限、服务器配置、事件调度等。 performance_schema:自MySQL 5.5版本引入,用于收集服务器性能数据,帮助诊断和优化系统性能。 test(非必要):默认提供的测试数据库,通常用于学习和实验,生产环境中可考虑删除。 sys(自MySQL 5.7版本):提供更易用的视图来访问performance_schema中的信息,简化性能分析工作。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值