├── .gitignore ├── api ├── booktitles.js ├── type.js ├── book.js ├── search.js ├── shelf.js ├── booklist.js ├── lately.js ├── checkShelf.js ├── login.js ├── insert-shelf.js ├── lastread.js └── register.js ├── README.md ├── package.json ├── connect └── index.js └── app.js /.gitignore: -------------------------------------------------------------------------------- 1 | .DS_Store 2 | node_modules/ 3 | 4 | # Editor directories and files 5 | .idea 6 | .vscode 7 | -------------------------------------------------------------------------------- /api/booktitles.js: -------------------------------------------------------------------------------- 1 | const connect = require('../connect'); 2 | 3 | const booktitles = (req, res) => { 4 | const id = req.query.id; 5 | 6 | connect(`SELECT * FROM booktitles WHERE id=${id};`, function (err, results, fields) { 7 | if (err) throw err; 8 | res.send(results[0]); 9 | }) 10 | } 11 | 12 | module.exports = booktitles 13 | -------------------------------------------------------------------------------- /api/type.js: -------------------------------------------------------------------------------- 1 | const connect = require('../connect'); 2 | 3 | const type = (req, res) => { 4 | const type = req.query.type; 5 | connect(`SELECT * FROM booklist WHERE type='${type}'`, function (err, results, fileds) { 6 | if (err) throw err; 7 | console.log(results); 8 | res.send(results) 9 | }) 10 | } 11 | module.exports = type; 12 | -------------------------------------------------------------------------------- /api/book.js: -------------------------------------------------------------------------------- 1 | const connect = require('../connect'); 2 | 3 | const book = (req, res) => { 4 | const book = req.query.book; 5 | const bookId = req.query.id; 6 | connect(`SELECT * FROM book${book} WHERE id=${bookId}`, function (err, results, fileds) { 7 | if (err) throw err; 8 | res.send(results[0]) 9 | }) 10 | } 11 | 12 | module.exports = book; 13 | -------------------------------------------------------------------------------- /api/search.js: -------------------------------------------------------------------------------- 1 | const connect = require('../connect'); 2 | 3 | const search = (req, res) => { 4 | const keyword = req.query.keyword; 5 | connect(`SELECT * FROM booklist WHERE name LIKE "%${keyword}%" OR author LIKE "%${keyword}%";`, function (err, results, fileds) { 6 | if (err) throw err; 7 | res.send(results); 8 | }) 9 | } 10 | 11 | module.exports = search; 12 | -------------------------------------------------------------------------------- /api/shelf.js: -------------------------------------------------------------------------------- 1 | const connect = require('../connect'); 2 | 3 | const shelf = (req, res) => { 4 | const userId = req.query.userId; 5 | console.log(req.query.userId); 6 | connect(`SELECT * FROM bookshelf WHERE userid=${userId}`, function (err, results, fileds) { 7 | if (err) throw err; 8 | res.send(results) 9 | }) 10 | } 11 | 12 | module.exports = shelf; 13 | -------------------------------------------------------------------------------- /api/booklist.js: -------------------------------------------------------------------------------- 1 | const connect = require('../connect'); 2 | 3 | const booklist = (req, res) => { 4 | const id = req.query.id; 5 | connect(id ? `SELECT * FROM booklist WHERE id=${id};` : `SELECT * FROM booklist;`, function (err, results, fields) { 6 | if (err) throw err; 7 | id ? res.send(results[0]) : res.send(results) 8 | }) 9 | } 10 | 11 | module.exports = booklist; 12 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | 本地使用方法: 2 | ```shell 3 | # 克隆项目 4 | git clone git@github.com:YepFury/reader-api.git 5 | 6 | # 进入到项目根目录,安装依赖 7 | cd read-api 8 | npm install 9 | 10 | # 启动接口 11 | node app.js 12 | ``` 13 | 14 | 服务器使用方法: 15 | ```shell 16 | # 克隆项目 17 | git clone git@github.com:YepFury/reader-api.git 18 | 19 | # 进入到项目根目录,安装依赖 20 | cd read-api/ 21 | npm install 22 | 23 | # 使用pm2启动服务 24 | pm2 start app.js 25 | ``` 26 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "reader-api", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1" 8 | }, 9 | "author": "", 10 | "license": "ISC", 11 | "dependencies": { 12 | "body-parser": "^1.18.3", 13 | "connect-history-api-fallback": "^1.5.0", 14 | "express": "^4.16.4", 15 | "md5": "^2.2.1", 16 | "mysql": "^2.16.0" 17 | } 18 | } 19 | -------------------------------------------------------------------------------- /api/lately.js: -------------------------------------------------------------------------------- 1 | const connect = require('../connect'); 2 | 3 | const late = (req, res) => { 4 | const userId = req.query.userId; 5 | const bookId = req.query.bookId; 6 | connect(`SELECT * FROM lately_read WHERE userid='${userId}' AND book_id='${bookId}'`, function (err, results, fileds) { 7 | if (err) throw err; 8 | if(results.length>0) { 9 | res.send(results[0]); 10 | }else { 11 | res.send(false); 12 | } 13 | }) 14 | } 15 | 16 | module.exports = late; 17 | -------------------------------------------------------------------------------- /api/checkShelf.js: -------------------------------------------------------------------------------- 1 | const connect = require('../connect'); 2 | 3 | const checkShelf = (req, res) => { 4 | const userId = req.query.userId; 5 | const bookId = req.query.bookId; 6 | connect(`SELECT * FROM bookshelf WHERE userid=${userId} AND bookid=${bookId}`, function (err, results, fileds) { 7 | if (err) throw err; 8 | if (results.length === 1) { 9 | res.send(true) 10 | } 11 | else { 12 | res.send(false) 13 | } 14 | }) 15 | } 16 | 17 | module.exports = checkShelf; 18 | -------------------------------------------------------------------------------- /connect/index.js: -------------------------------------------------------------------------------- 1 | const mysql = require('mysql'); 2 | 3 | const pool = new mysql.createPool({ 4 | host: '192.168.74.129', 5 | user: 'root', 6 | password: 'fuyafeng', 7 | database: 'books', 8 | port: 8071 9 | }) 10 | 11 | const connectMysql = function (sql, callback) { 12 | pool.getConnection(function (err, connection) { 13 | connection.query(sql, function (error, results, fields) { 14 | connection.release(); 15 | callback(error, results, fields) 16 | }) 17 | }) 18 | } 19 | 20 | module.exports = connectMysql 21 | -------------------------------------------------------------------------------- /api/login.js: -------------------------------------------------------------------------------- 1 | const connect = require('../connect'); 2 | 3 | const login = (req, res) => { 4 | const user = req.body.user; 5 | const pwd = req.body.pwd; 6 | 7 | connect(`SELECT * FROM users WHERE user_name="${user}" AND password="${pwd}";`, function (err, results, fileds) { 8 | if (err) throw err; 9 | if(results.length === 1) { 10 | connect(`SELECT * FROM user_info WHERE user="${user}";`, function (err, results, fileds) { 11 | if (err) throw err; 12 | if(results.length === 1) { 13 | res.send(results[0]) 14 | } 15 | else { 16 | res.send(false) 17 | } 18 | }) 19 | } 20 | else { 21 | res.send(false) 22 | } 23 | }) 24 | 25 | } 26 | 27 | module.exports = login; 28 | -------------------------------------------------------------------------------- /api/insert-shelf.js: -------------------------------------------------------------------------------- 1 | const connect = require('../connect'); 2 | 3 | const inShelf = (req, res) => { 4 | const userId = req.body.userId; 5 | const sql = `INSERT INTO \`books\`.\`bookshelf\`(\`userid\`, \`bookid\`, \`bookname\`, \`author\`, \`images\`, \`wordcount\`, \`type\`, \`intro\`, \`serialize\`) 6 | VALUES ('${userId}','${req.body['userInfo[id]']}','${req.body['userInfo[name]']}','${req.body['userInfo[author]']}','${req.body['userInfo[images]']}','${req.body['userInfo[wordcount]']}','${req.body['userInfo[type]']}','${req.body['userInfo[intro]']}','${req.body['userInfo[serialize]']}');` 7 | 8 | connect(sql, function (err, results, fileds) { 9 | if (err) throw err; 10 | if (results.affectedRows === 1) { 11 | res.send(true) 12 | } else { 13 | res.send(false) 14 | } 15 | }) 16 | 17 | } 18 | 19 | module.exports = inShelf; 20 | -------------------------------------------------------------------------------- /api/lastread.js: -------------------------------------------------------------------------------- 1 | const connect = require('../connect'); 2 | 3 | const lately = (req, res) => { 4 | const userId = req.body.userId; 5 | const bookId = req.body.bookId; 6 | const chapterId = req.body.chapterId; 7 | connect(`SELECT * FROM lately_read WHERE userid='${userId}' AND book_id='${bookId}'`, function (err, results, fileds) { 8 | if (err) throw err; 9 | if (results.length > 0) { 10 | connect(`UPDATE lately_read SET chapter='${chapterId}' WHERE userid='${userId}' AND book_id='${bookId}';`, function (err, result, fields) { 11 | if (err) throw err; 12 | if (result.affectedRows === 1) { 13 | res.send('修改成功') 14 | } 15 | }) 16 | } else { 17 | connect(`INSERT INTO lately_read (userid, book_id, chapter) VALUES ('${userId}', '${bookId}', '${chapterId}');`, function (err, result, fields) { 18 | if (err) throw err; 19 | if (result.affectedRows === 1) { 20 | res.send('插入成功') 21 | } 22 | }) 23 | } 24 | // res.send(results[0]) 25 | }) 26 | } 27 | 28 | module.exports = lately; 29 | -------------------------------------------------------------------------------- /app.js: -------------------------------------------------------------------------------- 1 | const express = require('express'); 2 | const bodyParse = require('body-parser'); 3 | const history = require('connect-history-api-fallback'); 4 | 5 | const app = express(); 6 | app.use(history()); 7 | app.use(bodyParse.json()); //数据JSON类型 8 | app.use(bodyParse.urlencoded({ 9 | extended: false 10 | })); //解析post请求数据 11 | 12 | app.all('*', function(req, res, next) { 13 | res.header("Access-Control-Allow-Credentials", true) 14 | res.header("Access-Control-Allow-Origin", "*") 15 | res.header("Access-Control-Allow-Headers", "X-Requested-With") 16 | res.header("Access-Control-Allow-Methods", "PUT,POST,GET,DELETE,OPTIONS") 17 | res.header("X-Powered-By", ' 3.2.1') 18 | res.header("Content-Type", "application/json;charset=utf-8") 19 | next() 20 | }); 21 | // get 22 | app.get('/book', require('./api/book')); 23 | app.get('/booklist', require('./api/booklist')); 24 | app.get('/booktitles', require('./api/booktitles')); 25 | app.get('/type', require('./api/type')); 26 | app.get('/shelf', require('./api/shelf')); 27 | app.get('/checkShelf', require('./api/checkShelf')); 28 | app.get('/late', require('./api/lately')); 29 | app.get('/search', require('./api/search')); 30 | 31 | // post 32 | app.post('/login', require('./api/login')); 33 | app.post('/register', require('./api/register')); 34 | app.post('/inShelf', require('./api/insert-shelf')); 35 | app.post('/lately', require('./api/lastread')); 36 | 37 | app.listen(7123, () => { 38 | console.log('接口运行在7070'); 39 | }) 40 | -------------------------------------------------------------------------------- /api/register.js: -------------------------------------------------------------------------------- 1 | const connect = require('../connect'); 2 | 3 | const register = (req, res) => { 4 | const user = req.body.user; 5 | const pwd = req.body.pwd; 6 | const email = req.body.email; 7 | 8 | connect(`SELECT * FROM users WHERE user_name="${user}";`, function (err, results, fileds) { 9 | if (err) throw err; 10 | if (results.length === 1) { 11 | res.send({ 12 | insertStatus: 2 13 | }) 14 | } else { 15 | let id = new Date().getTime(); 16 | let sql = `INSERT INTO \`books\`.\`users\`(\`user_id\`, \`user_name\`, \`password\`, \`email\`) VALUES ('${id}', '${user}', '${pwd}', '${email}');` 17 | connect(sql, function (err, results, fileds) { 18 | if (err) throw err; 19 | if (results.affectedRows === 1) { 20 | let sql2 = `INSERT INTO \`books\`.\`user_info\`(\`id\`, \`user\`, \`font_size\`, \`style_model\`, \`night\`, \`head_img\`) VALUES ('${id}', '${user}', 16, 'style1', 'false', '');`; 21 | connect(sql2, function (err, results, fileds) { 22 | if (err) throw err; 23 | if (results.affectedRows === 1) { 24 | connect(`SELECT * FROM user_info WHERE user="${user}";`, function (err, results, fileds) { 25 | if (err) throw err; 26 | if (results.length === 1) { 27 | res.send({ 28 | insertStatus: 1, 29 | userInfo: results[0] 30 | }) 31 | } else { 32 | res.send({ 33 | insertStatus: 0 34 | }) 35 | } 36 | }) 37 | } else { 38 | res.send({ 39 | insertStatus: 0 40 | }) 41 | } 42 | }) 43 | } else { 44 | res.send({ 45 | insertStatus: 0 46 | }) 47 | } 48 | }) 49 | } 50 | }) 51 | } 52 | 53 | module.exports = register; 54 | --------------------------------------------------------------------------------