后端: 添加文件搜索API
This commit is contained in:
parent
48755f18b0
commit
35880e7d09
@ -6,6 +6,7 @@ const shareRoutes = require('./routes/share');
|
|||||||
const syncRoutes = require('./routes/sync');
|
const syncRoutes = require('./routes/sync');
|
||||||
const previewRoutes = require('./routes/preview');
|
const previewRoutes = require('./routes/preview');
|
||||||
const userRoutes = require('./routes/user');
|
const userRoutes = require('./routes/user');
|
||||||
|
const searchRoutes = require('./routes/search');
|
||||||
const errorHandler = require('./middleware/errorHandler');
|
const errorHandler = require('./middleware/errorHandler');
|
||||||
|
|
||||||
const app = express();
|
const app = express();
|
||||||
@ -21,6 +22,7 @@ app.use('/api/share', shareRoutes);
|
|||||||
app.use('/api/sync', syncRoutes);
|
app.use('/api/sync', syncRoutes);
|
||||||
app.use('/api/preview', previewRoutes);
|
app.use('/api/preview', previewRoutes);
|
||||||
app.use('/api/user', userRoutes);
|
app.use('/api/user', userRoutes);
|
||||||
|
app.use('/api/search', searchRoutes);
|
||||||
|
|
||||||
// Error handler
|
// Error handler
|
||||||
app.use(errorHandler);
|
app.use(errorHandler);
|
||||||
|
|||||||
40
backend/src/routes/search.js
Normal file
40
backend/src/routes/search.js
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
const express = require('express');
|
||||||
|
const db = require('../db');
|
||||||
|
|
||||||
|
const router = express.Router();
|
||||||
|
|
||||||
|
// Search files
|
||||||
|
router.get('/', (req, res) => {
|
||||||
|
const token = req.headers.authorization?.replace('Bearer ', '');
|
||||||
|
if (!token) return res.status(401).json({ error: 'No token' });
|
||||||
|
|
||||||
|
try {
|
||||||
|
const jwt = require('jsonwebtoken');
|
||||||
|
const decoded = jwt.verify(token, process.env.JWT_SECRET || 'clouddisk-secret-key');
|
||||||
|
|
||||||
|
const { q, type } = req.query;
|
||||||
|
|
||||||
|
if (!q || q.length < 2) {
|
||||||
|
return res.status(400).json({ error: 'Search query too short' });
|
||||||
|
}
|
||||||
|
|
||||||
|
let sql = 'SELECT * FROM files WHERE user_id = ? AND name LIKE ? AND deleted_at IS NULL';
|
||||||
|
const params = [decoded.userId, `%${q}%`];
|
||||||
|
|
||||||
|
if (type === 'folder') {
|
||||||
|
sql += ' AND is_folder = 1';
|
||||||
|
} else if (type === 'file') {
|
||||||
|
sql += ' AND is_folder = 0';
|
||||||
|
}
|
||||||
|
|
||||||
|
sql += ' ORDER BY name ASC LIMIT 50';
|
||||||
|
|
||||||
|
db.query(sql, params).then(files => {
|
||||||
|
res.json({ files, total: files.length });
|
||||||
|
});
|
||||||
|
} catch (error) {
|
||||||
|
res.status(500).json({ error: error.message });
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
module.exports = router;
|
||||||
Loading…
Reference in New Issue
Block a user