Files
all-in-one-sys/scripts/test-permissions.js

93 lines
3.0 KiB
JavaScript
Raw Normal View History

/**
* 测试数据库权限
*/
require('dotenv').config();
const mysql = require('mysql2/promise');
const dbConfig = {
host: process.env.DB_HOST,
port: process.env.DB_PORT,
user: process.env.DB_USER,
password: process.env.DB_PASSWORD,
database: process.env.DB_DATABASE || 'ddcz_platform'
};
async function testPermissions() {
let connection;
try {
console.log('🔌 正在连接到MySQL数据库...');
console.log(` 主机: ${dbConfig.host}:${dbConfig.port}`);
console.log(` 用户: ${dbConfig.user}`);
console.log(` 数据库: ${dbConfig.database}\n`);
connection = await mysql.createConnection(dbConfig);
console.log('✅ 数据库连接成功!\n');
// 测试1: 查看当前用户权限
console.log('📋 测试1: 查看用户权限...');
const [grants] = await connection.query('SHOW GRANTS');
console.log('✅ 当前用户权限:');
grants.forEach(grant => {
console.log(` ${Object.values(grant)[0]}`);
});
console.log('');
// 测试2: 创建测试表
console.log('📋 测试2: 测试创建表权限...');
await connection.query(`
CREATE TABLE IF NOT EXISTS test_permissions (
id INT AUTO_INCREMENT PRIMARY KEY,
name VARCHAR(50),
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
)
`);
console.log('✅ 创建表权限正常\n');
// 测试3: 插入数据
console.log('📋 测试3: 测试插入数据权限...');
await connection.query(`
INSERT INTO test_permissions (name) VALUES ('test_data')
`);
console.log('✅ 插入数据权限正常\n');
// 测试4: 修改表结构
console.log('📋 测试4: 测试修改表结构权限...');
await connection.query(`
ALTER TABLE test_permissions ADD COLUMN description TEXT
`);
console.log('✅ 修改表结构权限正常\n');
// 测试5: 删除表
console.log('📋 测试5: 测试删除表权限...');
await connection.query(`
DROP TABLE IF EXISTS test_permissions
`);
console.log('✅ 删除表权限正常\n');
console.log('🎉 所有权限测试通过!');
console.log('✅ 您的账号具有完整的数据库操作权限');
console.log('📌 可以继续运行 npm run init-db 创建所有表\n');
} catch (error) {
console.error('\n❌ 权限测试失败:');
console.error(error.message);
if (error.code === 'ER_DBACCESS_DENIED_ERROR') {
console.error('\n💡 没有访问数据库的权限');
} else if (error.code === 'ER_TABLEACCESS_DENIED_ERROR') {
console.error('\n💡 没有操作表的权限');
}
process.exit(1);
} finally {
if (connection) {
await connection.end();
console.log('🔌 数据库连接已关闭');
}
}
}
testPermissions();