Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/thinkjs/think-session-mysql
Use Mysql to store session for ThinkJS 3.x
https://github.com/thinkjs/think-session-mysql
mysql session-mysql thinkjs
Last synced: 2 months ago
JSON representation
Use Mysql to store session for ThinkJS 3.x
- Host: GitHub
- URL: https://github.com/thinkjs/think-session-mysql
- Owner: thinkjs
- License: mit
- Created: 2017-03-30T03:19:17.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2021-07-02T00:21:21.000Z (over 3 years ago)
- Last Synced: 2024-10-04T03:13:50.944Z (3 months ago)
- Topics: mysql, session-mysql, thinkjs
- Language: JavaScript
- Homepage:
- Size: 20.5 KB
- Stars: 0
- Watchers: 12
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- think-awesome - think-session-mysql
README
# think-session-mysql
Use Mysql to store session for ThinkJS## Install
```
npm install think-session-mysql
```## How to use
config file `src/config/adapter.js`, add options:
```js
const mysqlSession = require('think-session-mysql');
exports.session = {
type: 'mysql',
common: {
cookie: {
name: 'thinkjs',
//maxAge: '',
//expires: '',
path: '/', //a string indicating the path of the cookie
//domain: '',
//secure: false,
//keys: [],
httpOnly: true,
sameSite: false,
signed: false,
overwrite: false
}
},
mysql:{
handle:mysqlSession,
// optional config fields,merge model.mysql if empty
database:'think_test',
prefix:'think_',
host:'127.0.0.1',
port:'3306',
user:'root',
password:'',
gcInterval: 3600 * 1000 //gc interval
}
}
```if some fields also in model config, you can use Spread Properties.
```js
const mysqlConfig = {
database:'think_test',
prefix:'think_',
host:'127.0.0.1',
port:'3306',
user:'root',
password:'',
}
exports.model = {
type: 'mysql',
mysql: {
handle: mysqlModel,
...mysqlConfig
}
}
exports.session = {
type: 'mysql',
mysql: {
handle: mysqlSession,
...mysqlConfig
}
}
```## Create Database
`think_` is the prefix in `adapter.js`
```
CREATE TABLE `think_session` (
`id` int(11) unsigned NOT NULL AUTO_INCREMENT,
`cookie` varchar(255) NOT NULL DEFAULT '',
`data` text,
`expire` bigint(11) NOT NULL DEFAULT '0',
`maxage` int(11) NOT NULL DEFAULT '0',
PRIMARY KEY (`id`),
UNIQUE KEY `cookie` (`cookie`),
KEY `expire` (`expire`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
```