修改后端接口
This commit is contained in:
55
government-backend/scripts/init-admin-user.js
Normal file
55
government-backend/scripts/init-admin-user.js
Normal file
@@ -0,0 +1,55 @@
|
||||
const User = require('../models/User');
|
||||
const bcrypt = require('bcryptjs');
|
||||
|
||||
// 初始化管理员用户
|
||||
async function initAdminUser() {
|
||||
try {
|
||||
console.log('正在初始化管理员用户...');
|
||||
|
||||
// 检查是否已存在管理员用户
|
||||
const existingAdmin = await User.findOne({
|
||||
where: {
|
||||
username: 'admin',
|
||||
role: 'admin'
|
||||
}
|
||||
});
|
||||
|
||||
if (existingAdmin) {
|
||||
console.log('管理员用户已存在,更新密码...');
|
||||
// 加密密码
|
||||
const hashedPassword = await bcrypt.hash('123456', 10);
|
||||
|
||||
// 更新用户密码
|
||||
await existingAdmin.update({
|
||||
password: hashedPassword,
|
||||
status: 'active'
|
||||
});
|
||||
|
||||
console.log('管理员用户密码更新成功');
|
||||
} else {
|
||||
console.log('创建新的管理员用户...');
|
||||
// 加密密码
|
||||
const hashedPassword = await bcrypt.hash('123456', 10);
|
||||
|
||||
// 创建管理员用户
|
||||
await User.create({
|
||||
username: 'admin',
|
||||
password: hashedPassword,
|
||||
role: 'admin',
|
||||
status: 'active'
|
||||
});
|
||||
|
||||
console.log('管理员用户创建成功');
|
||||
}
|
||||
|
||||
console.log('初始化管理员用户完成');
|
||||
} catch (error) {
|
||||
console.error('初始化管理员用户失败:', error);
|
||||
} finally {
|
||||
// 关闭数据库连接
|
||||
process.exit(0);
|
||||
}
|
||||
}
|
||||
|
||||
// 执行初始化
|
||||
initAdminUser();
|
||||
95
government-backend/scripts/syncFarmersModel.js
Normal file
95
government-backend/scripts/syncFarmersModel.js
Normal file
@@ -0,0 +1,95 @@
|
||||
// 数据库模型同步脚本
|
||||
const sequelize = require('../config/database');
|
||||
const Farmer = require('../models/Farmer');
|
||||
|
||||
// 同步数据库模型并添加测试数据
|
||||
async function syncAndSeed() {
|
||||
try {
|
||||
// 同步模型到数据库
|
||||
await sequelize.sync({ alter: true });
|
||||
console.log('数据库模型同步成功');
|
||||
|
||||
// 检查是否已存在测试数据
|
||||
const existingCount = await Farmer.count();
|
||||
|
||||
if (existingCount === 0) {
|
||||
// 添加测试数据
|
||||
const testFarmers = [
|
||||
{
|
||||
account: 'farmer001',
|
||||
nickname: '牛场小王',
|
||||
real_name: '王小明',
|
||||
farm_name: '明辉养殖场',
|
||||
farm_type: '规模',
|
||||
animal_type: '牛',
|
||||
animal_count: 200,
|
||||
address: '内蒙古自治区通辽市科尔沁区',
|
||||
registrar: 'admin',
|
||||
status: 'active'
|
||||
},
|
||||
{
|
||||
account: 'farmer002',
|
||||
nickname: '草原小李',
|
||||
real_name: '李草原',
|
||||
farm_name: '草原牧业',
|
||||
farm_type: '规模',
|
||||
animal_type: '羊',
|
||||
animal_count: 500,
|
||||
address: '内蒙古自治区通辽市开鲁县',
|
||||
registrar: 'admin',
|
||||
status: 'active'
|
||||
},
|
||||
{
|
||||
account: 'farmer003',
|
||||
nickname: '家庭养殖户老张',
|
||||
real_name: '张家庭',
|
||||
farm_name: '张记养殖场',
|
||||
farm_type: '散养',
|
||||
animal_type: '猪',
|
||||
animal_count: 50,
|
||||
address: '内蒙古自治区通辽市扎鲁特旗',
|
||||
registrar: 'admin',
|
||||
status: 'active'
|
||||
},
|
||||
{
|
||||
account: 'farmer004',
|
||||
nickname: '家禽养殖',
|
||||
real_name: '刘家禽',
|
||||
farm_name: '刘家养殖场',
|
||||
farm_type: '规模',
|
||||
animal_type: '鸡',
|
||||
animal_count: 2000,
|
||||
address: '内蒙古自治区通辽市霍林郭勒市',
|
||||
registrar: 'admin',
|
||||
status: 'active'
|
||||
},
|
||||
{
|
||||
account: 'farmer005',
|
||||
nickname: '特种养殖',
|
||||
real_name: '赵特种',
|
||||
farm_name: '特种养殖场',
|
||||
farm_type: '其他',
|
||||
animal_type: '其他',
|
||||
animal_count: 100,
|
||||
address: '内蒙古自治区通辽市库伦旗',
|
||||
registrar: 'admin',
|
||||
status: 'inactive'
|
||||
}
|
||||
];
|
||||
|
||||
await Farmer.bulkCreate(testFarmers);
|
||||
console.log('测试数据添加成功');
|
||||
} else {
|
||||
console.log('已存在测试数据,跳过添加');
|
||||
}
|
||||
|
||||
// 关闭数据库连接
|
||||
await sequelize.close();
|
||||
} catch (error) {
|
||||
console.error('同步数据库模型或添加测试数据失败:', error);
|
||||
// 确保即使出错也关闭连接
|
||||
await sequelize.close();
|
||||
}
|
||||
}
|
||||
|
||||
syncAndSeed();
|
||||
Reference in New Issue
Block a user